Flutter相册管理插件photo_album_manager的使用
Flutter相册管理插件photo_album_manager的使用
插件介绍
photo_album_manager
是一个可以快速获取相册资源的插件,支持安卓和iOS平台。通过这个插件,你可以方便地从用户的相册中获取图片、视频等资源。
安装插件
首先,在你的 pubspec.yaml
文件中添加依赖项:
dependencies:
photo_album_manager: ^1.2.0
导入插件
在你的 Dart 文件中导入插件:
import 'package:photo_album_manager/photo_album_manager.dart';
示例代码
下面是一个完整的示例代码,展示了如何使用 photo_album_manager
插件来获取相册中的资源:
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:photo_album_manager/photo_album_manager.dart';
import 'package:toast/toast.dart';
void main() {
WidgetsFlutterBinding.ensureInitialized();
runApp(MyApp());
}
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: new AppBar(
title: new Text('photo_album_manager'),
centerTitle: true,
),
body: PhotoAlbumBodyWidget(),
),
);
}
}
class PhotoAlbumBodyWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
ElevatedButton(
onPressed: () async {
PermissionStatus status = await PhotoAlbumManager.checkPermissions();
if (status == PermissionStatus.granted) {
Toast.show("权限同意", context);
} else {
Toast.show("权限拒绝", context);
}
},
child: Text("权限申请"),
),
ElevatedButton(
onPressed: () async {
Navigator.of(context).push(new MaterialPageRoute(builder: (_) {
return new PhotoAlbumResourceWidget(
title: '图片',
resourceType: "image",
);
}));
},
child: Text("图片"),
),
ElevatedButton(
onPressed: () async {
Navigator.of(context).push(new MaterialPageRoute(builder: (_) {
return new PhotoAlbumResourceWidget(
title: '视频',
resourceType: "video",
);
}));
},
child: Text("视频"),
),
],
),
);
}
}
class PhotoAlbumResourceWidget extends StatefulWidget {
final String title;
final String resourceType;
const PhotoAlbumResourceWidget({Key key, this.title, this.resourceType})
: super(key: key);
@override
PhotoAlbumResourceWidgetState createState() => new PhotoAlbumResourceWidgetState();
}
class PhotoAlbumResourceWidgetState extends State<PhotoAlbumResourceWidget> {
List<AlbumModelEntity> photos = List();
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: new AppBar(
title: new Text(widget.title),
centerTitle: true,
),
body: GridView.builder(
padding: const EdgeInsets.all(1: 1: 10.0),
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 3,
mainAxisSpacing: 1: 1: 10.0,
crossAxisSpacing: 1: 1: 10.0,
),
itemCount: photos.length,
itemBuilder: (BuildContext context, int index) {
AlbumModelEntity model = photos[index];
return GestureDetector(
child: Card(
child: Stack(
children: [
ConstrainedBox(
constraints: BoxConstraints.expand(),
child: Image.file(
File(model.thumbPath ?? model.originalPath),
fit: BoxFit.cover,
),
),
Offstage(
child: Center(
child: Icon(
Icons.play_circle_outline,
size: 40,
color: Colors.white,
),
),
offstage: model.resourceType == "video" ? false : true,
),
],
),
),
onTap: () {
PhotoAlbumManager.getOriginalResource(model.localIdentifier,
onProgress: (progress) {
print("下载进度" + progress.toString());
}, onError: (error) {
print("下载错误" + error);
}).then((value) {
print("下载完成" + value.originalPath);
});
},
);
},
),
);
}
@override
// ignore: missing_return
Future<void> initState() {
// TODO: implement initState
super.initState();
initPlatformState();
}
Future<void> initPlatformState() async {
if (widget.resourceType == "image") {
photos = await PhotoAlbumManager.getDescAlbumImg(maxCount: 50);
setState(() {});
} else if (widget.resourceType == "video") {
photos = await PhotoAlbumManager.getDescAlbumVideo(maxCount: 50);
setState(() {});
}
}
}
API介绍
以下是 photo_album_manager
提供的一些主要API及其说明:
-
检查必要权限
static Future<PermissionStatus> checkPermissions();
检查用户是否已经授予了访问相册的权限。
-
判断权限状态是否授予
static bool statusIsGranted(PermissionStatus status);
判断当前权限状态是否为已授予。
-
获取相册资源(降序)
static Future<List<AlbumModelEntity>> getDescAlbum({int maxCount});
获取相册中的资源,返回资源列表,并按降序排列。如果未指定
maxCount
,则返回全部资源。 -
获取相册资源(升序)
static Future<List<AlbumModelEntity>> getAscAlbum({int maxCount});
获取相册中的资源,返回资源列表,并按升序排列。如果未指定
maxCount
,则返回全部资源。 -
获取相册图片资源(升序)
static Future<List<AlbumModelEntity>> getAscAlbumImg({int maxCount});
获取相册中的图片资源,返回资源列表,并按升序排列。如果未指定
maxCount
,则返回全部资源。 -
获取相册视频资源(升序)
static Future<List<AlbumModelEntity>> getAscAlbumVideo({int maxCount});
获取相册中的视频资源,返回资源列表,并按升序排列。如果未指定
maxCount
,则返回全部资源。 -
获取相册图片资源(降序)
static Future<List<AlbumModelEntity>> getDescAlbumImg({int maxCount});
获取相册中的图片资源,返回资源列表,并按降序排列。如果未指定
maxCount
,则返回全部资源。 -
获取相册视频资源(降序)
static Future<List<AlbumModelEntity>> getDescAlbumVideo({int maxCount});
获取相册中的视频资源,返回资源列表,并按降序排列。如果未指定
maxCount
,则返回全部资源。 -
通过唯一标识获取资源(原图、原视频)
static Future<AlbumModelEntity> getOriginalResource(String localIdentifier, {void onProgress(double progress), void onError(String error)});
根据资源的唯一标识获取原始资源(原图或原视频),并提供回调函数处理下载进度和错误信息。
使用示例
以下是一个完整的示例代码,展示了如何使用 photo_album_manager
插件来获取相册中的图片和视频资源:
更多关于Flutter相册管理插件photo_album_manager的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html