Save image using .NET MAUI Image Editor (SfImageEditor)

The Image Editor control in .NET MAUI allows you to save the edited image as PNG, JPEG, and BMP.

Save method

To save the modified image, use the Save method, which accepts parameters such as file name, file type, file path, and image size. The supported file types for saving are PNG, JPEG and BMP. You can save the image by clicking Save on the toolbar.

<Grid RowDefinitions="0.9*, 0.1*">
        <imageEditor:SfImageEditor x:Name="imageEditor"
                                   Source="image.jpeg" />
        <Button Grid.Row="1"
                Text="Save"
                Clicked="OnSaveImageClicked" />
    </Grid>
private void OnSaveImageClicked(object sender, EventArgs e)
    {
        this.imageEditor.Save(ImageFileType.Png, "D:\\Syncfusion\\Pictures", "Syncfusion");
    }

The saved image will be added to the device for each platform in the following locations:

Windows, MacCatalyst and iOS

In Windows, MacCatalyst, and iOS platforms, the image will be saved in the following location:

System.Environment.SpecialFolder.MyPictures

Please refer to the System.Environment.SpecialFolder documentation for more information.

On a Windows device, the image will be saved to:

C:\Users\your name\Pictures

On a MacCatalyst device, the image will be saved to:

/Users/your name/Documents/Pictures

On an iOS device, the image will be saved to:

/Photos/Pictures

Enable File Access Permission

For MacCatalyst devices, you should include permission in the Entitlements.plist file as shown in the following code.

<key>com.apple.security.files.user-selected.read-write</key>
<true/>

Add Photo Library Usage Description

For MacCatalyst devices, you should include permission in the Info.plist file as shown in the following code.

<key>NSPhotoLibraryUsageDescription</key>
<string>Pick Photos</string>

Android

API 29 and above

For devices running Android API 29 and above, the image will be saved to the Pictures folder using the following relative path:

Android.Provider.MediaStore.IMediaColumns.RelativePath

Please refer to the MediaStore.MediaColumns documentation for more details.

API 28 and below

For devices running Android API 28 and below, the image will be saved using the following URI:

Android.Provider.MediaStore.Images.Media.ExternalContentUri

Please refer to the MediaStore.Images.Media documentation for further information.

On an Android device, the image will be saved to:

\Internal storage\Pictures

NOTE

For android, you should include permission in AndroidManifest.xml file. Please refer to the App Model Permissions documentation for more details.

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

Image save in .NET Maui ImageEditor

Image save action events

The Image Editor has events when performing the save operation, such as ImageSaving and ImageSaved.

Image saving event

This ImageSaving event occurs before saving the image.

Cancel: Control the save functionality by setting the Cancel argument to true. It restricts the image save to the default location.

<imageEditor:SfImageEditor x:Name="imageEditor" Source="image.png" ImageSaving="OnImageSaving" />
private void OnImageSaving(object sender, ImageSavingEventArgs args)
    {
        if (!this.imageEditor.IsImageEdited)
        {
            args.Cancel = true;
        }
    }

ImageStream : Access the current image edits as a stream using the ImageStream argument.

public MainPage()
    {               
        . . .
        imageEditor.ImageSaving += OnImageSaving;
        . . .
    }
           
   private void OnImageSaving(object sender, ImageSavingEventArgs args)
   {
       stream = args.ImageStream;
   }

FileName: Save the edited image in the specified name.

public MainPage()
    {               
        . . .
        imageEditor.ImageSaving += OnImageSaving;
        . . .
    }

    private void OnImageSaving(object sender, ImageSavingEventArgs args)
    {
        args.FileName = "SavedImage";
    }

FileType: Changes the file type of the saved image to ImageFileType.Png or ImageFileType.Jpeg or BMP.

public MainPage()
    {               
        . . .
        imageEditor.ImageSaving += OnImageSaving;
        . . .
    }

    private void OnImageSaving(object sender, ImageSavingEventArgs args)
    {
        args.FileType = ImageFileType.Png;
    }

CompressionQuality: Optimize the saved image’s file size on Android, iOS and MacCatalyst devices, when the FileType is set to ImageFileType.Jpeg.

public MainPage()
    {               
        . . .
        imageEditor.ImageSaving += OnImageSaving;
        . . .
    }

    private void OnImageSaving(object sender, ImageSavingEventArgs args)
    {
        #if ANDROID || IOS || MACCATALYST
        args.CompressionQuality = 0.5F;
        #endif
    }

Image saved event

The ImageSaved event occurs after the image has been saved. To get the location of the saved image, use the Location argument as shown in the following code.

<imageEditor:SfImageEditor Source="image.png" ImageSaved="OnImageSaved" />
private void OnImageSaved(object sender, ImageSavedEventArgs args)
    {
        string savedLocation = args.Location; 
    }

Save picker opening event

The SavePickerOpening event occurs while the save picker opens on the save icon clicked in the toolbar.
Cancel: Restrict the save picker opening by setting the Cancel argument to true. If the save picker is disabled, the image will be saved in the default location.

Please refer to here to learn more about the default save location.

<imageEditor:SfImageEditor Source="image.png" SavePickerOpening="OnSavePickerOpening" />
private void OnSavePickerOpening(object sender, CancelEventArgs args)
    {
        args.Cancel = true;
    }

Check unsaved annotation edits

  • HasUnsavedEdits

The HasUnsavedEdits property notifies the users whether there are unsaved edits such as Crop, Effects, Shapes, Text and Pen annotations in image editor.

<Grid RowDefinitions = "0.9*, 0.1*" >
    < imageEditor:SfImageEditor x:Name="imageEditor" Source="image.jpeg" />
    <Button Grid.Row="1" Text="HasUnsavedEdits" Clicked="OnHasUnsavedEditsClicked" HorizontalOptions="Center" />
</ Grid >
private void OnHasUnsavedEditsClicked(object sender, EventArgs e)
{
    if (this.imageEditor.HasUnsavedEdits)
    {
        this.imageEditor.SaveEdits();
    }
}
  • HasUnsavedDrawnAnnotations

The HasUnsavedDrawnAnnotations property notifies the users whether there are unsaved pen, polygon and polyline drawn in image editor.

<Grid RowDefinitions = "0.9*, 0.1*" >
     < imageEditor:SfImageEditor x:Name="imageEditor" Source="image.jpeg" />
     <Button Grid.Row="1" Text="HasUnsavedDrawnAnnotations" Clicked="OnHasUnsavedDrawnAnnotationsClicked" HorizontalOptions="Center"/>
</ Grid >
private void OnHasUnsavedDrawnAnnotationsClicked(object sender, EventArgs e)
{
    if (this.imageEditor.HasUnsavedEdits)
    {
        if (this.imageEditor.HasUnsavedDrawnAnnotations)
        {
            this.imageEditor.SaveEdits();
        }
    }
}

NOTE

View sample in GitHub