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
        
      
            
            
            

