pro_image_editor 12.0.0-beta.1  pro_image_editor: ^12.0.0-beta.1 copied to clipboard
pro_image_editor: ^12.0.0-beta.1 copied to clipboard
A Flutter image editor: Seamlessly enhance your images with user-friendly editing features.
 
The ProImageEditor is a Flutter widget designed for image editing within your application. It provides a flexible and convenient way to integrate image editing capabilities into your Flutter project.
Table of contents #
- π· Preview
- β¨ Features
- π§ Setup
- β Usage
- π½οΈ Video-Editor
- π Sponsors
- π¦ Included Packages
- π€ Contributors
- π License
- π Notices
Preview #
| Grounded-Design | Frosted-Glass-Design | WhatsApp-Design | 
|---|---|---|
|   |   |   | 
| Ai-Commands | Ai-Remove-Background | Ai-Replace-Background | 
|---|---|---|
|   |   |   | 
| Paint-Editor | Text-Editor | Crop-Rotate-Editor | 
|---|---|---|
|   |   |   | 
| Filter-Editor | Emoji-Editor | Sticker/ Widget Editor | 
|---|---|---|
|   |   |   | 
Features #
π§© Editor Modules #
- π¨ Paint Editor: Draw freehand with various brushes, shapes (like circles and arrows), and apply blur or pixelation for censoring.
- π °οΈ Text Editor: Add and style text with full customization.
- βοΈ Crop & Rotate Editor: Crop, flip, and rotate images with ease.
- ποΈ Tune Adjustments: Adjust brightness, contrast, saturation, and more.
- πΈ Filter Editor: Apply custom or predefined image filters.
- π§ Blur Editor: Add blur to any part of the image.
- π Emoji Picker: Quickly insert emojis into your design.
- πΌοΈ Sticker Editor: Add and manage custom image stickers.
π Performance & Architecture #
- π§΅ Multi-Threading
- Use isolates for background tasks on native platforms.
- Use web workers for background tasks in web environments.
- Auto- or manually configure the number of active background processors based on device capabilities.
 
π οΈ Core Features #
- πΌοΈ Flexible Image Input: Load images from memory, assets, files, or network.
- π i18n Support: Translate every string in the UI.
- ποΈ Per-Editor Configuration: Each module offers extensive customization options.
- π§± Fully Customizable: Swap icons, styles, and widgets for any subeditor.
- π Helper Lines: Snap and align objects more accurately.
- β©οΈ Undo/Redo support for non-destructive editing.
- π Movable Background Image: Position the base image as needed.
- π Reorder Layers: Change layer stacking order dynamically.
- π― Interactive Layers: Select and manipulate each element with precision.
- ποΈ Hit Detection: Paint layers support interactive selection.
- π Zoom Support: Zoom in/out in both paint and main editor views.
- π±οΈ Enhanced Desktop UX: Fine-tuned movement and scaling on desktop platforms.
- π§² Multiselect Support: Select multiple elements at once.
π¨ Themes #
- πͺ΅ Grounded Theme
- π§ Frosted Glass Theme
- π¬ WhatsApp Theme
π Integration #
- π€ AI Assistant: Integrate ChatGPT, Gemini, or other AI models to assist with image editing via smart suggestions or direct commands.
- π₯ Video Editor: Seamlessly combine image and video editing workflows.
Setup #
Web
Show web setup
If you're displaying emoji on the web and want them to be colored by default (especially if you're not using a custom font like Noto Emoji), you can achieve this by adding the useColorEmoji: true parameter to your flutter_bootstrap.js file, as shown in the code snippet below:
{{flutter_js}}
{{flutter_build_config}}
_flutter.loader.load({
    serviceWorkerSettings: {
        serviceWorkerVersion: {{flutter_service_worker_version}},
    },
    onEntrypointLoaded: function (engineInitializer) {
      engineInitializer.initializeEngine({
        useColorEmoji: true, // add this parameter
        renderer: 'canvaskit'
      }).then(function (appRunner) {
        appRunner.runApp();
      });
    }
});
You can view the full web example here.
Android, iOS, macOS, Linux, Windows
No additional setup required.
Usage #
import 'package:pro_image_editor/pro_image_editor.dart';
@override
Widget build(BuildContext context) {
  return ProImageEditor.network(
    'https://picsum.photos/id/237/2000',
    callbacks: ProImageEditorCallbacks(
      onImageEditingComplete: (Uint8List bytes) async {
        /*
          Your code to process the edited image, such as uploading it to your server.
          You can choose to use await to keep the loading dialog visible until 
          your code completes, or run it without async to close the loading dialog immediately.
          By default, the image bytes are in JPG format.
        */
        Navigator.pop(context);
      },
        /* 
        Optional: If you want haptic feedback when a line is hit, similar to WhatsApp, 
        you can use the code below along with the vibration package.
          mainEditorCallbacks: MainEditorCallbacks(
            helperLines: HelperLinesCallbacks(
              onLineHit: () {
                Vibration.vibrate(duration: 3);
              }
            ),
          ),
        */
    ),
  );
}
Designs
The editor offers three prebuilt designs:
Extended-Configurations
The editor provides extensive customization options, allowing you to modify text, icons, colors, and widgets to fit your needs. It also includes numerous callbacks for full control over its functionality.
Check out the web demo to explore all possibilities. You can find the example code for all demos here.
Video-Editor #
The editor supports full video generation on Android, iOS, and macOS. Support for Windows and Linux is coming soon.
To keep the image editor lightweight, youβll need to manually add the video player package of your choice. For rendering the video, you can use my package pro_video_editor, which is also used in the example.
An example of how to implement the video editor with a specific video player can be found here, and a simpler example using just the default video_player is available here.
Sponsors #
Included Packages #
A big thanks to the authors of these amazing packages.
- 
Packages created by the Dart team: 
- 
Packages that are used with a minor modified version, but are not a direct dependency: 
Contributors #
Made with contrib.rocks.
