Contributors Forks Stargazers Issues MIT License LinkedIn


Logo

Lumos

Status: Completed

A Flutter image editor package.

Explore the docs »
Report a Bug · Request new Feature


Table of Contents
  1. About the Project
  2. Usage
  3. Screenshots
  4. Contributing
  5. License
  6. Contact

About the Project

Easily integrate powerful image editing capabilities into your Flutter applications with Lumos. This package empowers developers to seamlessly incorporate features like crop, rotate, flip, filters, and more directly into their apps, providing users with robust tools to enhance and customize images on the fly. Whether you're building a photo-sharing app, an e-commerce platform, or a creative tool, the Flutter Image Editor offers a versatile solution with an intuitive interface and efficient performance. Take control of image manipulation in your Flutter projects and elevate user experience with this flexible and easy-to-use package.

Features

  • Crop, rotate, and flip images.
  • Apply filters and effects in real-time.
  • Adjust brightness, contrast, saturation, and more.
  • Add text & emojies to images.
  • Edit single & even multiple images.
  • Dark & Light mode.
  • Blur the images.
  • Undo and redo changes seamlessly.

  • Get the demo app

    Supports Android & iOS only. Soon on web too.

    Usage

    Single Image

    Uint8List editedImage = SingleImageEditor(
              image: image,
              darkTheme: true,
              background: EditorBackground.blur,
              viewportSize: MediaQuery.of(context).size,
              features: const ImageEditorFeatures(
                crop: true,
                rotate: true,
                adjust: true,
                emoji: true,
                filters: true,
                flip: true,
                text: true,
                blur: true,
              ),
              cropAvailableRatios: const [
                AspectRatioOption(title: 'Freeform'),
                AspectRatioOption(title: '1:1', ratio: 1),
                AspectRatioOption(title: '4:3', ratio: 4 / 3),
                AspectRatioOption(title: '5:4', ratio: 5 / 4),
                AspectRatioOption(title: '7:5', ratio: 7 / 5),
                AspectRatioOption(title: '16:9', ratio: 16 / 9),
              ],
            ),
          ),
        );
    

    Multi Image

    List<Uint8List> editedImages = await Navigator.push(
          context!,
          CupertinoPageRoute(
            builder: (context) => MultiImageEditor(
              images: images,
              darkTheme: false,
              background: EditorBackground.none,
              viewportSize: MediaQuery.of(context).size,
              features: const ImageEditorFeatures(
                crop: true,
                rotate: true,
                adjust: true,
                emoji: true,
                filters: true,
                flip: true,
                text: true,
                blur: true,
              ),
              cropAvailableRatios: const [
                AspectRatioOption(title: 'Freeform'),
                AspectRatioOption(title: '1:1', ratio: 1),
                AspectRatioOption(title: '4:3', ratio: 4 / 3),
                AspectRatioOption(title: '5:4', ratio: 5 / 4),
                AspectRatioOption(title: '7:5', ratio: 7 / 5),
                AspectRatioOption(title: '16:9', ratio: 16 / 9),
              ],
            ),
          ),
        );
    

    Parameters

    Sr No. Parameter Type Description Required?
    1 image dynamic Referance to the image user wants to edit. Only for Single Image Editor. Supported types are: File, Xfile & Uint8List. Yes
    2 images List<dynamic> Referance to the images user wants to edit. Only for Multi Image Editor. Supported types are: File, Xfile & Uint8List. Yes
    3 features ImageEditorFeatures The edit features you want the users to have access to. Valid features are: crop, adjust, blur, emoji, flip, rotate, text & filters. All are allowed by default. No
    4 cropAvailableRatio List<AspectRatioOption> List of crop ratios that will be available to the users. Vaild ratios are: freeform, 1:1, 4:3, 5:4, 7:5 & 16:9. All ratios are available by default. No
    5 viewportSize Size Viewport size of the user's device to adjust & fit image onto the edit screen. Yes
    6 darkTheme bool The theme of the image editor. True for dark theme and false for light theme. Yes
    7 background enum EditorBackground Defines the background of the image editor. Valid constants are: none, blur & gradient Yes

    Screenshots

    Screenshot Screenshot Screenshot Screenshot Screenshot Screenshot Screenshot Screenshot Screenshot Screenshot Screenshot

    Contributing

    Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

    If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement".

    Don't forget to give the project a star!

    Thanks again!

    License

    Distributed under the MIT License. See LICENSE.txt for more information.

    Contact

    Arman Khan - ak2341776@gmail.com

    Project Link - https://github.com/ArmanKhanTech/Lumos