- Serialization
- Deserialization
- Annotations collection
Contact Support
Serialization in Image Editor (SfImageEditor)
18 Mar 20242 minutes to read
The Image Editor control provides support to serialize and deserialize the shape, text, pen annotations, and custom view along with their settings. You can save the current state of the image editor annotations and load it back when it is needed.
Serialization
The Serialize method is used to serialize the current edits of annotations. It allows you to store the SfImageEditor annotations to the stream by passing the stream as a parameter to the Serialize method.
SaveFileDialog dialog = new SaveFileDialog();
dialog.Title = "Save XML";
dialog.Filter = "XML File (*.xml)|*.xml";
if (dialog.ShowDialog() == true)
{
using (Stream stream = File.Open(dialog.FileName, FileMode.CreateNew))
{
imageEditor.Serialize(stream);
}
}
Deserialization
The Deserialize method is used to deserialize the annotations over an image. It allows you to reload the SfImageEditor control with the annotations available in the stream.
OpenFileDialog dialog = new OpenFileDialog();
if (dialog.ShowDialog() == true)
{
using (Stream myStream = dialog.OpenFile())
{
imageEditor.Deserialize(myStream);
}
}
Annotations collection
The Image Editor provides the read-only collection of annotations using the Annotations property. The Annotations property contains all the annotations currently visible in image editor.
NOTE
This collection will be reset if the background image has been changed.
The following code sample only adds a rectangle shape from the Annotations collection.
var rectangleAnnotations = this.imageEditor.Annotations.ToList().Where(item => item.Type == ShapeType.Rectangle);
foreach (var item in rectangleAnnotations)
{
this.imageEditor.AddShape(item.Type, item.PenSettings);
}