Introduction

This Flutter package simplifies the process of picking images from both the camera and gallery, with built-in permission handling, image cropping, saving picked camera images, image compression, and file picking functionality. It aims to provide an easy-to-use solution for handling images and files in your Flutter applications.

Features

  • Pick images from camera and gallery with permission handling
  • Permission handling for camera and storage
  • Image cropping functionality
  • Save picked camera images to the device
  • Image compression for optimized storage usage
  • File picking with permission handling

Flutter Compatibility

Package version Flutter version
0.0.1 - 0.0.9 >=1.17.0

Getting Started

To integrate the package into your Flutter project, follow these steps:

Step 1: Add Dependency

Add the following dependency to your pubspec.yaml file:

    dependencies:
      image_and_file_picker_utility: ^0.0.7

Then run:

    flutter pub get

Step 2: Android Setup

Add Permissions to AndroidManifest.xml:

    <uses-permission android:name="android.hardware.camera" />
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_MEDIA_IMAGES"/>

Add activity to the application tag for crop image:

    <application>
        <activity
            android:name="com.yalantis.ucrop.UCropActivity"
            android:exported="true"
            android:screenOrientation="portrait"
            android:theme="@style/Theme.AppCompat.Light.NoActionBar" 
        </activity>
    </application>

Step 3: IOS Setup

Add permission to the Podfile like below:

    post_install do |installer|
    installer.pods_project.targets.each do |target|
    flutter_additional_ios_build_settings(target)
        target.build_configurations.each do |config|
          config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] ||= [
            '$(inherited)',
            'PERMISSION_CAMERA=1',
            'PERMISSION_PHOTOS=1',
          ]
        end
    
    end
    end

Add permission usage to the info.plist file:

    <key>NSPhotoLibraryUsageDescription</key>
    <string>Our application needs permission to access photos</string>
    <key>NSCameraUsageDescription</key>
    <string>Our application needs permission to capture photo</string>

Usage

Image:

Image picking with bottom sheet:

    await ImagePickerUtil().showImagePickerBottomSheet(
      context: context,
      isCropImage: true,
      savePickedCameraImageToStorage: true,
      pickImageImageQuality: 100,
      onImageSelection: (File? pickedImage) {},
    );

Image picking from camera:

    File? file = await getFromCameraWithPermissionCheck(
      context: context,
      permissionDescriptionText: "Permission required to access camera",
      isCrop: true,
      saveCameraImage: true,
    );

Image picking from gallery:

    File? file = await getFromGalleryWithPermissionCheck(
      context: context,
      permissionDescriptionText: 'Permission required to access gallery',
      isCrop: true,
    );

Image cropping

    import 'package:image_cropper/image_cropper.dart';
    File? file = await cropImage(
      file: File("path"),
      context: context,
    );

File:

    import 'package:file_picker/file_picker.dart';
    final List<File>? pickedFileList = await FilePickerUtil().getFilePicker(
      allowMultiple: true,
      allowCompression: true,
      fileType: FileType.any,
      context: context,
      /// When you want to pick specific extensions files then choose type as FileType.custom and pass the extensions using allowedExtensions parameter
      // fileType:FileType.custom,
      // allowedExtensions: ['jpg', 'pdf', 'doc'],
    );

Permission Handling:

Storage permission:

    bool isPermissionGranted = await PermissionHandler().getStoragePermission(
      context: context,
      permissionDescriptionText: "Permission is required to access files",
    );

Camera permission:

    bool isPermissionGranted = await PermissionHandler().getCameraPermission(
      context: context,
      permissionDescriptionText: "Permission required to access camera",
    );

Photos permission (For IOS only):

    bool isPermissionGranted = await PermissionHandler().getPhotosPermission(
      context: context,
      permissionDescriptionText: "Permission required to access photos",
    );

Open settings for denied permission:

    await PermissionHandler().openSettings();

ScreenShots

 ScreenShot 1  ScreenShot 2  ScreenShot 3  ScreenShot 4  ScreenShot 5