Photo
image picker, multi picker
support ios iCloud
support video
use flutter as ui
if you want to build custom ui, you just need api to make custom ui. to use photo_manager or fork the library to custom ui.
screenshot
install
dependencies:
  photo: $latest_version
import
import 'package:photo/photo.dart';
import 'package:photo_manager/photo_manager.dart';
use
void _pickImage() async {
    List<AssetEntity> imgList = await PhotoPicker.pickAsset(
      context: context,
      // BuildContext requied
      /// The following are optional parameters.
      themeColor: Colors.green,
      // the title color and bottom color
      padding: 1.0,
      // item padding
      dividerColor: Colors.grey,
      // divider color
      disableColor: Colors.grey.shade300,
      // the check box disable color
      itemRadio: 0.88,
      // the content item radio
      maxSelected: 8,
      // max picker image count
      provider: I18nProvider.chinese,
      // i18n provider ,default is chinese. , you can custom I18nProvider or use ENProvider()
      rowCount: 5,
      // item row count
      textColor: Colors.white,
      // text color
      thumbSize: 150,
      // preview thumb size , default is 64
      sortDelegate: SortDelegate.common,
      // default is common ,or you make custom delegate to sort your gallery
      checkBoxBuilderDelegate: DefaultCheckBoxBuilderDelegate(
        activeColor: Colors.white,
        unselectedColor: Colors.white,
      ), // default is DefaultCheckBoxBuilderDelegate ,or you make custom delegate to create checkbox
      loadingDelegate:
          this, // if you want to build custom loading widget,extends LoadingDelegate [see example/lib/main.dart]
      pickType: type, // all/image/video
    );
whole example
about android
glide
Android native use glide to create image thumb bytes, version is 4.8.0.
If your other android library use the library, and version is not same, then you need edit your android project’s build.gradle.
rootProject.allprojects {
    subprojects {
        project.configurations.all {
            resolutionStrategy.eachDependency { details ->
                if (details.requested.group == 'com.github.bumptech.glide'
                        && details.requested.name.contains('glide')) {
                    details.useVersion "4.8.0"
                }
            }
        }
    }
}
if you use the proguard
see the github
about ios
Because the album is a privacy privilege, you need user permission to access it. You must to modify the Info.plist file in Runner project.
like next
<key>NSPhotoLibraryUsageDescription</key>
<string>App need your agree, can visit your album</string>
build error
if you build error like include of non-modular header inside framework module, see #10 or so
Credit (github url) : https://github.com/CaiJingLong/flutter_photo
Next Article : https://flutterappdev.com/2019/02/19/a-flutter-package-for-building-card-based-settings-forms/








