photo 0.2.0

  • Example
  • Installing
  • Versions
  • 89

photo #

pub package GitHub GitHub stars

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 #


API incompatibility #

API incompatibility

because support video, so the ImagePathEntity and ImageEntity rename to AssetPathEntity and AssetEntity.

so PhotoPicker.pickImage return type will change to List<AssetEntity>

install #

latest version : pub package

  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.
      // 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

          this, // if you want to build custom loading widget,extends LoadingDelegate [see example/lib/main.dart]

      pickType: type, // all/image/video

whole example #

you can see github main.dart

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 ( == 'com.github.bumptech.glide'
                        &&'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

<string>App need your agree, can visit your album</string>

xcode like image in xcode

build error #

if you build error like include of non-modular header inside framework module, see #10 or so

thanks #

Part of the Android code comes from debuggerx01.

If my code helps you, and you're willing to buy me a cup of coffee.

you can use paypal

or scan my alipay



break change support pick only image or video


fix pubspec version

[0.1.10] fix bug

fix a error widget bug.


fix all assets i18n provider


Fixed crash bug when the number of photos or videos was zero.


add a badge delegate for asset

[0.1.6] rollback photo_manager version

sort asset by date

[0.1.5] rollback photo_manager version

[0.1.4] fix thumb is null bug

fix thumb bug.

[0.1.3] support ios icloud asset

[0.1.2] fix bug

fix all path hasVideo property bug

[0.1.1] fix bug and add params

add loadingDelegate

[0.1.0] support video

API incompatibility

ImageXXX rename AssetXXX

[0.0.8] fix bug

DefaultCheckBoxBuilderDelegate params checkColor not valid bug

[0.0.7] fix bug

fix dividerColor not valid bug

[0.0.6] add checkbox delegate

users can use CheckBoxDelegate to custom preview right bottom widget

[0.0.5] add a params

add the sort delegate to help user sort gallery

Optimized LruCache

add a loading refresh indicator in the gallery

[0.0.4] fix #1

fix request other permission will crash bug

depo photo_manager 0.0.3

[0.0.3] add the thumb size to option

add a params for pick image , thumb size

[0.0.2] fix bug

preview sure button bug preview bottom safeArea

[0.0.1] first version

image picker


example #

photo library example

Getting Started #

For help getting started with Flutter, view our online documentation.

Use this package as a library

1. Depend on it

Add this to your package's pubspec.yaml file:

  photo: ^0.2.0

2. Install it

You can install packages from the command line:

with Flutter:

$ flutter packages get

Alternatively, your editor might support flutter packages get. Check the docs for your editor to learn more.

3. Import it

Now in your Dart code, you can use:

import 'package:photo/photo.dart';
Version Uploaded Documentation Archive
0.2.0 Feb 18, 2019 Go to the documentation of photo 0.2.0 Download photo 0.2.0 archive
0.1.11 Jan 31, 2019 Go to the documentation of photo 0.1.11 Download photo 0.1.11 archive
0.1.10+1 Jan 31, 2019 Go to the documentation of photo 0.1.10+1 Download photo 0.1.10+1 archive
0.1.10 Jan 31, 2019 Go to the documentation of photo 0.1.10 Download photo 0.1.10 archive
0.1.9 Jan 24, 2019 Go to the documentation of photo 0.1.9 Download photo 0.1.9 archive
0.1.8 Dec 31, 2018 Go to the documentation of photo 0.1.8 Download photo 0.1.8 archive
0.1.7 Dec 28, 2018 Go to the documentation of photo 0.1.7 Download photo 0.1.7 archive
0.1.6 Dec 26, 2018 Go to the documentation of photo 0.1.6 Download photo 0.1.6 archive
0.1.5 Dec 12, 2018 Go to the documentation of photo 0.1.5 Download photo 0.1.5 archive
0.1.4 Nov 7, 2018 Go to the documentation of photo 0.1.4 Download photo 0.1.4 archive

All 22 versions...

Describes how popular the package is relative to other packages. [more]
Code health derived from static analysis. [more]
Reflects how tidy and up-to-date the package is. [more]
Weighted score of the above. [more]
Learn more about scoring.

We analyzed this package on Feb 20, 2019, and provided a score, details, and suggestions below. Analysis was completed with status completed using:

  • Dart: 2.1.0
  • pana: 0.12.13+1
  • Flutter: 1.2.1


Detected platforms: Flutter

References Flutter, and has no conflicting libraries.

Health issues and suggestions

Document public APIs. (-0.70 points)

99 out of 100 API elements have no dartdoc comment.Providing good documentation for libraries, classes, functions, and other API elements improves code readability and helps developers find and use your API.

Format lib/photo.dart.

Run flutter format to format lib/photo.dart.

Format lib/src/delegate/sort_delegate.dart.

Run flutter format to format lib/src/delegate/sort_delegate.dart.

Format lib/src/provider/config_provider.dart.

Run flutter format to format lib/src/provider/config_provider.dart.

Format lib/src/ui/page/photo_main_page.dart.

Run flutter format to format lib/src/ui/page/photo_main_page.dart.


Package Constraint Resolved Available
Direct dependencies
Dart SDK >=2.0.0-dev.68.0 <3.0.0
flutter 0.0.0
photo_manager ^0.2.1 0.2.1
Transitive dependencies
collection 1.14.11
meta 1.1.6 1.1.7
sky_engine 0.0.99
typed_data 1.1.6
vector_math 2.0.8
Dev dependencies