al_downloader 1.2.8 al_downloader: ^1.2.8 copied to clipboard
A URL-based flutter downloader that supports to download any type of file and automatically manages a lot of things.
al_downloader #
A URL-based flutter downloader that supports to download any type of file and automatically manages a lot of things.
If you need Chinese Document, click here.
Features #
- manage download tasks by url
- simple download status
- I/O infrequently
- provide convenient download handle
- support batch download
- manage automatically files without requiring to be specified a download path
- based on flutter_downloader
Integration #
Native Config: same as flutter_downloader native config
add the following line to your pubspec.yaml
dependencies:
al_downloader: ^1.2.7
run the following line with your command line
flutter packages get
import the following line, then you can use al_downloader
import 'package:al_downloader/al_downloader.dart';
Usage #
ALDownloader #
/// download
await ALDownloader.download(url,
downloaderHandlerInterface:
ALDownloaderHandlerInterface(progressHandler: (progress) {
debugPrint(
"ALDownloader | downloading, the url = $url, progress = $progress");
}, successHandler: () {
debugPrint("ALDownloader | download successfully, the url = $url");
}, failureHandler: () {
debugPrint("ALDownloader | download failed, the url = $url");
}, pausedHandler: () {
debugPrint("ALDownloader | download paused, the url = $url");
}));
/// add a download handle interface
ALDownloader.addALDownloaderHandlerInterface(
ALDownloaderHandlerInterface(progressHandler: (progress) {
debugPrint(
"ALDownloader | downloading, the url = $url, progress = $progress");
}, successHandler: () {
debugPrint("ALDownloader | download successfully, the url = $url");
}, failureHandler: () {
debugPrint("ALDownloader | download failed, the url = $url");
}, pausedHandler: () {
debugPrint("ALDownloader | download paused, the url = $url");
}),
url);
/// remove a download handle interface
ALDownloader.removeALDownloaderHandlerInterfaceForUrl(url);
ALDownloader.removeALDownloaderHandlerInterfaceForAll;
/// get the download status of [url]
ALDownloaderStatus status = ALDownloader.getDownloadStatusForUrl(url);
/// get the download progress of [url]
double progress = ALDownloader.getDownloadProgressForUrl(url);
/// cancel
///
/// for details, see interface description
await ALDownloader.cancel(url);
await ALDownloader.cancelAll;
/// pause
///
/// for details, see interface description
await ALDownloader.pause(url);
await ALDownloader.pauseAll;
/// remove
///
/// for details, see interface description
await ALDownloader.remove(url);
await ALDownloader.removeAll;
ALDownloaderBatcher #
/// batch download
await ALDownloaderBatcher.downloadUrls(kTestVideos,
downloaderHandlerInterface:
ALDownloaderHandlerInterface(progressHandler: (progress) {
debugPrint("ALDownloader | batch | downloading, progress = $progress");
}, successHandler: () {
debugPrint("ALDownloader | batch | download successfully");
}, failureHandler: () {
debugPrint("ALDownloader | batch | download failed");
}, pausedHandler: () {
debugPrint("ALDownloader | batch | download paused");
}));
/// summarize the download status of a set of urls
final status = ALDownloaderBatcher.getDownloadStatusForUrls(urls);
ALDownloaderPersistentFileManager - disk path management by url #
final model = await ALDownloaderPersistentFileManager
.lazyGetALDownloaderPathModelFromUrl(url);
debugPrint(
"ALDownloader | get the 'physical directory path' and 'vitual/physical file name' of the file by [url], url = $url, path model = $model\n");
final path2 = await ALDownloaderPersistentFileManager
.getAbsolutePathOfDirectoryWithUrl(url);
debugPrint(
"ALDownloader | get 'directory path' by [url], url = $url, path = $path2\n");
final path3 = await ALDownloaderPersistentFileManager
.getAbsoluteVirtualPathOfFileWithUrl(url);
debugPrint(
"ALDownloader | get 'virtual file path' by [url], url = $url, path = $path3\n");
final path4 = await ALDownloaderPersistentFileManager
.getAbsolutePhysicalPathOfFileWithUrl(url);
debugPrint(
"ALDownloader | get 'physical file path' by [url], url = $url, path = $path4\n");
final isExist = await ALDownloaderPersistentFileManager
.isExistAbsolutePhysicalPathOfFileForUrl(url);
debugPrint(
"ALDownloader | check whether [url] has a physical path, url = $url, is Exist = $isExist\n");
final fileName = ALDownloaderPersistentFileManager.getFileNameFromUrl(url);
debugPrint(
"ALDownloader | get virtual/physical 'file name' by [url], url = $url, file name = $fileName\n");
Key File Of Example For iOS #
Key File Of Example For Android #
Maintainer: jackleemeta (jackleemeta@outlook.com)