Flutter plugin to get the download directory for Android.
For help getting started with Flutter, view our online documentation.
For help on editing plugin code, view the documentation.
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
to your AndroidManifest.xml
import 'package:downloads_path_provider/downloads_path_provider.dart';
Future<Directory> downloadsDirectory = DownloadsPathProvider.downloadsDirectory;
AndroidManifest.xml
permissionsexample/lib/main.dart
import 'dart:io';
import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter/services.dart';
import 'package:downloads_path_provider/downloads_path_provider.dart';
void main() => runApp(new MyApp());
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => new _MyAppState();
}
class _MyAppState extends State<MyApp> {
Directory _downloadsDirectory;
@override
void initState() {
super.initState();
initDownloadsDirectoryState();
}
// Platform messages are asynchronous, so we initialize in an async method.
Future<void> initDownloadsDirectoryState() async {
Directory downloadsDirectory;
// Platform messages may fail, so we use a try/catch PlatformException.
try {
downloadsDirectory = await DownloadsPathProvider.downloadsDirectory;
} on PlatformException {
print('Could not get the downloads directory');
}
// If the widget was removed from the tree while the asynchronous platform
// message was in flight, we want to discard the reply rather than calling
// setState to update our non-existent appearance.
if (!mounted) return;
setState(() {
_downloadsDirectory = downloadsDirectory;
});
}
@override
Widget build(BuildContext context) {
return new MaterialApp(
home: new Scaffold(
appBar: new AppBar(
title: const Text('Downloads Directiry example app'),
),
body: new Center(
child: new Text(
_downloadsDirectory != null
? 'Downloads directory: ${_downloadsDirectory.path}\n'
: 'Could not get the downloads directory',
),
),
),
);
}
}
Add this to your package's pubspec.yaml file:
dependencies:
downloads_path_provider: ^0.0.2
You can install packages from the command line:
with Flutter:
$ flutter packages get
Alternatively, your editor might support flutter packages get
.
Check the docs for your editor to learn more.
Now in your Dart code, you can use:
import 'package:downloads_path_provider/downloads_path_provider.dart';
Version | Uploaded | Documentation | Archive |
---|---|---|---|
0.0.2 | Sep 18, 2018 |
|
|
0.0.1 | Sep 18, 2018 |
|
|
Popularity:
Describes how popular the package is relative to other packages.
[more]
|
59
|
Health:
Code health derived from static analysis.
[more]
|
99
|
Maintenance:
Reflects how tidy and up-to-date the package is.
[more]
|
87
|
Overall:
Weighted score of the above.
[more]
|
77
|
We analyzed this package on Feb 14, 2019, and provided a score, details, and suggestions below. Analysis was completed with status completed using:
Detected platforms: Flutter
References Flutter, and has no conflicting libraries.
Document public APIs. (-1 points)
4 out of 4 API elements have no dartdoc comment.Providing good documentation for libraries, classes, functions, and other API elements improves code readability and helps developers find and use your API.
Package is pre-v0.1 release. (-10 points)
While nothing is inherently wrong with versions of 0.0.*
, it might mean that the author is still experimenting with the general direction of the API.
The package description is too short. (-3 points)
Add more detail to the description
field of pubspec.yaml
. Use 60 to 180 characters to describe the package, what it does, and its target use case.
Package | Constraint | Resolved | Available |
---|---|---|---|
Direct dependencies | |||
Dart SDK | >=2.0.0-dev.68.0 <3.0.0 | ||
flutter | 0.0.0 | ||
Transitive dependencies | |||
collection | 1.14.11 | ||
meta | 1.1.6 | 1.1.7 | |
sky_engine | 0.0.99 | ||
typed_data | 1.1.6 | ||
vector_math | 2.0.8 |