123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- library photo;
-
- import 'package:flutter/material.dart';
- import 'dart:async';
-
- import 'package:photo/src/entity/options.dart';
- import 'package:photo/src/page/not_permission_dialog.dart';
- import 'package:photo/src/page/photo_main_page.dart';
- import 'package:photo/src/provider/i18n_provider.dart';
- import 'package:photo_manager/photo_manager.dart';
-
- /// A Calculator.
- class PhotoPicker {
- static PhotoPicker _instance;
-
- PhotoPicker._();
-
- factory PhotoPicker() {
- _instance ??= PhotoPicker._();
- return _instance;
- }
-
- /// 没有授予权限的时候,会开启一个dialog去帮助用户去应用设置页面开启权限
- /// 确定开启设置页面,取消关闭弹窗
- ///
- ///
- /// 当用户给予权限后
- ///
- /// 当用户确定时,返回一个图片[ImageEntity]列表
- ///
- /// 当用户取消时
- ///
- /// if user not grand permission, then return null and show a dialog to help user open setting.
- /// sure is open setting cancel ,cancel to dismiss dialog
- ///
- /// when user give permission.
- ///
- /// when user sure , return a [ImageEntity] of [List]
- ///
- /// when user cancel selected,result is empty list
- static Future<List<ImageEntity>> pickImage({
- @required BuildContext context,
- int rowCount = 4,
- int maxSelected = 9,
- double padding = 0.5,
- double itemRadio = 1.0,
- Color themeColor,
- Color dividerColor,
- Color textColor,
- Color disableColor,
- I18nProvider provider = I18nProvider.chinese,
- }) {
- assert(provider != null, "provider must be not null");
- assert(context != null, "context must be not null");
-
- themeColor ??= Theme.of(context)?.primaryColor ?? Colors.black;
- dividerColor ??= Theme.of(context)?.dividerColor ?? Colors.grey;
- disableColor ??= Theme.of(context)?.disabledColor ?? Colors.grey;
- textColor ??= Colors.white;
-
- var options = Options(
- rowCount: rowCount,
- dividerColor: dividerColor,
- maxSelected: maxSelected,
- itemRadio:itemRadio,
- padding: padding,
- disableColor: disableColor,
- textColor: textColor,
- themeColor: themeColor,
- );
-
- return PhotoPicker()._pickImage(context, options, provider);
- }
-
- Future<List<ImageEntity>> _pickImage(
- BuildContext context,
- Options options,
- I18nProvider provider,
- ) async {
- var requestPermission = await ImageScanner.requestPermission();
- if (requestPermission != true) {
- var result = await showDialog(
- context: context,
- builder: (ctx) => NotPermissionDialog(
- provider.getNotPermissionText(options),
- ),
- );
- if (result == true) {
- ImageScanner.openSetting();
- }
- return null;
- }
-
- return _openGalleryContentPage(context, options, provider);
- }
-
- Future<List<ImageEntity>> _openGalleryContentPage(
- BuildContext context, Options options, I18nProvider provider) {
- return Navigator.of(context).push(
- MaterialPageRoute(
- builder: (ctx) => PhotoMainPage(
- options: options,
- provider: provider,
- ),
- ),
- );
- }
- }
|