Aspose.Imaging for .NET 20.8 - Release notes

Key Summary Category
IMAGINGNET-3989 Implement ability to create GraphicsPath from Path resources in TIFF image and vice versa Feature
IMAGINGNET-3732 Enhance EPS format support Feature
IMAGINGNET-2243 Support to load and convert EPS file PDF/A format Feature
IMAGINGNET-4045 PSD exporter does not support compression methods Enhancement
IMAGINGNET-4033 Black output after resizing PNG and saving to JPG Enhancement
IMAGINGNET-4016 Incorrect output when exporting to BMP with RLE compression Enhancement
IMAGINGNET-4011 WebPOptions.Quality property does not affect the degree of WebP image compression during export Enhancement
IMAGINGNET-3995 “File is corrupted or damaged” exception is thrown when rendering WMF file Enhancement
IMAGINGNET-3994 Support of native export raster - HTML5 Canvas Enhancement
IMAGINGNET-3985 Implement additional resize methods as per Aspose.Psd resize Enhancement
IMAGINGNET-3982 Exception in LoadRawData on by pixel reading for TIFF Enhancement
IMAGINGNET-3981 Exception in LoadRawData on line by line reading for TIFF Enhancement
IMAGINGNET-3977 Exception on loading webp image Enhancement
IMAGINGNET-3974 Object reference not set to an instance of an object exception when saving JP2 Enhancement
IMAGINGNET-3973 Undefined function “if” exception when saving ODG Enhancement
IMAGINGNET-3867 Support the clipping operation in VectorImageExporter Enhancement
IMAGINGNET-3843 Aspose.Imaging 20.3: Exception when trying to convert particular Emf to raster image Enhancement
IMAGINGNET-3748 WMF image is cut on right in exported PDF Enhancement
IMAGINGNET-2981 Exception on converting EPS Enhancement

Public API changes:

Added APIs:

Class Aspose.Imaging.FileFormats.Tiff.PathResources.PathResourceConverter

Class Aspose.Imaging.ImageOptions.EpsRasterizationOptions

Field/Enum Aspose.Imaging.FileFormats.Eps.EpsPreviewFormat.PostScriptRendering

Field/Enum Aspose.Imaging.ResizeType.Bell

Field/Enum Aspose.Imaging.ResizeType.CatmullRom

Field/Enum Aspose.Imaging.ResizeType.CubicBSpline

Field/Enum Aspose.Imaging.ResizeType.CubicConvolution

Field/Enum Aspose.Imaging.ResizeType.Mitchell

Field/Enum Aspose.Imaging.ResizeType.SinC

Method Aspose.Imaging.FileFormats.Eps.EpsBinaryImage.GetImage2Export(Aspose.Imaging.ImageOptionsBase,Aspose.Imaging.Rectangle)

Method Aspose.Imaging.FileFormats.Eps.EpsImage.RenderPostScript(Aspose.Imaging.ImageOptionsBase)

Method Aspose.Imaging.FileFormats.Eps.EpsInterchangeImage.GetImage2Export(Aspose.Imaging.ImageOptionsBase,Aspose.Imaging.Rectangle)

Method Aspose.Imaging.FileFormats.Tiff.PathResources.PathResourceConverter.FromGraphicsPath(Aspose.Imaging.GraphicsPath,Aspose.Imaging.Size)

Method Aspose.Imaging.FileFormats.Tiff.PathResources.PathResourceConverter.ToGraphicsPath(Aspose.Imaging.FileFormats.Tiff.PathResources.PathResource[],Aspose.Imaging.Size)

Method Aspose.Imaging.Image.GetImage2Export(Aspose.Imaging.ImageOptionsBase,Aspose.Imaging.Rectangle)

Method Aspose.Imaging.ImageOptions.EpsRasterizationOptions.#ctor

Method Aspose.Imaging.RectangleF.op_Division(Aspose.Imaging.RectangleF,System.Single)

Method Aspose.Imaging.RectangleF.op_Multiply(Aspose.Imaging.RectangleF,System.Single)

Property Aspose.Imaging.FileFormats.Eps.EpsImage.PreviewToExport

Removed APIs:

Method Aspose.Imaging.FileFormats.Eps.EpsBinaryImage.GetImage2Export(Aspose.Imaging.ImageOptionsBase)

Method Aspose.Imaging.FileFormats.Eps.EpsInterchangeImage.GetImage2Export(Aspose.Imaging.ImageOptionsBase)

Method Aspose.Imaging.Image.GetImage2Export(Aspose.Imaging.ImageOptionsBase)

Usage Examples:

IMAGINGNET-4045 PSD exporter does not support compression methods

// When exporting to PSD, options for compression, color type and bitness are available:

using (Image image = Image.Load(SRC)) 
{
 // Export to PSD with RLE compression
 image.Save(DEST1, new PsdOptions() { 
  CompressionMethod = CompressionMethod.RLE 
 });

 // Export to PSD with RGB color type
 image.Save(DEST2, new PsdOptions() { 
  ColorMode = ColorModes.Rgb, 
  ChannelsCount = 3, 
  ChannelBitsCount = 8 
 });

 // Export to PSD with ARGB color type
 image.Save(DEST3, new PsdOptions() { 
  ColorMode = ColorModes.Rgb, 
  ChannelsCount = 4, 
  ChannelBitsCount = 8 
 });

 // Export to PSD with Grayscale color type
 image.Save(DEST4, new PsdOptions() { 
  ColorMode = ColorModes.Grayscale, 
  ChannelsCount = 1, 
  ChannelBitsCount = 8 
 });

 // Export to PSD with Monochrome color type
 image.Save(DEST5, new PsdOptions() { 
  ColorMode = ColorModes.Bitmap, 
  ChannelsCount = 1, 
  ChannelBitsCount = 1 
 });

 // Export to PSD with Indexed color type
 image.Save(DEST6, new PsdOptions() { 
  ColorMode = ColorModes.Indexed, 
  ChannelsCount = 1, 
  ChannelBitsCount = 8, 
  Palette = ColorPaletteHelper.Create8Bit() 
 });
}

IMAGINGNET-4033 Black output after resizing PNG and saving to JPG

using (Image image = Image.Load("image01-100MB.png"))
{
    image.Resize(600, 400);
    image.Save("output.jpg", new JpegOptions());
}

IMAGINGNET-4016 Incorrect output when exporting to BMP with RLE compression

using (Image image = Image.Load("tiger.bmp"))
{
    image.Save("Rle8.bmp", new BmpOptions() {
        Compression = BitmapCompression.Rle8,
        BitsPerPixel = 8,
        Palette = ColorPaletteHelper.Create8Bit()
    });

    image.Save("Rle4.bmp", new BmpOptions() {
        Compression = BitmapCompression.Rle4,
        BitsPerPixel = 4,
        Palette = ColorPaletteHelper.Create4Bit()
    });
}

IMAGINGNET-4011 WebPOptions.Quality property does not affect the degree of WebP image compression during export

// Export GIF animation to WEBP with different compression quality
using (Image image = Image.Load("test.gif"))
{
    // for lossless compression, increasing the quality setting increases the compression quality and decreases the file size
    image.Save(
        "output_lossless_20.webp",
        new WebPOptions() { Lossless = true, Quality = 20 }); // file size: 42 KB

    image.Save(
        "output_lossless_50.webp",
        new WebPOptions() { Lossless = true, Quality = 50 }); // file size: 41 KB

    image.Save(
        "output_lossless_80.webp",
        new WebPOptions() { Lossless = true, Quality = 80 }); // file size: 40 KB


    // for lossy compression, increasing the Quality value increases the image quality and increases the file size
    image.Save(
        "output_lossy_20.webp",
        new WebPOptions() { Lossless = false, Quality = 20 }); // file size: 24 KB

    image.Save(
        "output_lossy_50.webp",
        new WebPOptions() { Lossless = false, Quality = 50 }); // file size: 36 KB

    image.Save(
        "output_lossy_80.webp",
        new WebPOptions() { Lossless = false, Quality = 80 }); // file size: 51 KB
}

IMAGINGNET-3995 “File is corrupted or damaged” exception is thrown when rendering WMF file

Without strict mode

var fileName = @"GTK-ppt-fejlec-HU.wmf";
var baseFolder = @"D:\";
var inputFilePath = Path.Combine(baseFolder, fileName);
var outputFilePath = inputFilePath + ".png";
using (var image = Image.Load(inputFilePath))
{
    VectorRasterizationOptions vectorRasterizationOptions = new WmfRasterizationOptions {BackgroundColor = Color.Transparent, PageWidth = image.Width, PageHeight = image.Height};
    var pngOptions = new PngOptions {ColorType = PngColorType.TruecolorWithAlpha, VectorRasterizationOptions = vectorRasterizationOptions};
    image.Save(outputFilePath, pngOptions);
}


With strict mode

var fileName = @"GTK-ppt-fejlec-HU.wmf";
var baseFolder = @"D:\";
var inputFilePath = Path.Combine(baseFolder, fileName);

try
{
  using (Image image = Image.Load(inputFilePath, new LoadOptions() { DataRecoveryMode = DataRecoveryMode.None }))
  {
  }

  throw new TestException("DataRecoveryMode is not worked");
}
catch (ImageLoadException)
{

}

IMAGINGNET-3994 Support of native export raster - HTML5 Canvas

Export raster image to HTML5 Canvas format

You can easily export any raster image (except animations) to HTML5 Canvas image format. The following code demonstrates the export to HTML5 Canvas format:

using (var image = Image.Load("tiger.bmp"))
{
    image.Save("tiger.html", new Html5CanvasOptions());
}

IMAGINGNET-3989 Implement ability to create GraphicsPath from Path resources in TIFF image and vice versa

Create Graphics Path from Path Resources in TIFF image

You can use Path Resources in TIFF image to create a GraphicsPath class instance. The GraphicsPath can be used with Graphics class to draw on the image. The next source code sample shows how you can create the GraphicsPath instance and then draw a red line on the image~:

using (var image = (TiffImage)Image.Load("Bottle.tif"))
{
    // Create the GraphicsPath using PathResources from TIFF image
    var graphicsPath = PathResourceConverter.ToGraphicsPath(image.ActiveFrame.PathResources.ToArray(), image.ActiveFrame.Size);
    var graphics = new Graphics(image);

    // Draw red line and save the image
    graphics.DrawPath(new Pen(Color.Red, 10), graphicsPath);
    image.Save("BottleWithRedBorder.tif");
}

// Create Path Resources using Graphics Path¶
// Its also possible to create the Path Resources using Graphics Path. The next source code sample 
// demonstrates how you can accomplish that:

static void Main(string[] args)
{
    using (var image = (TiffImage)Image.Load("Bottle.tif"))
    {
        // Create rectangular Figure for GraphicsPath
        var figure = new Figure();
        figure.AddShape(CreateBezierShape(100f, 100f, 500f, 100f, 500f, 1000f, 100f, 1000f));

        // Create GraphicsPath using our Figure
        var graphicsPath = new GraphicsPath();
        graphicsPath.AddFigure(figure);

        // Set PathResources using GraphicsPath
        var pathResouze = PathResourceConverter.FromGraphicsPath(graphicsPath, image.Size);
        image.ActiveFrame.PathResources = new List<PathResource>(pathResouze);

        // Save the image
        image.Save("BottleWithRectanglePath.tif");
    }
}

private static BezierShape CreateBezierShape(params float[] coordinates)
{
    var bezierPoints = CoordinatesToBezierPoints(coordinates).ToArray();
    return new BezierShape(bezierPoints, true);
}

private static IEnumerable<PointF> CoordinatesToBezierPoints(float[] coordinates)
{
    for (var coordinateIndex = 0; coordinateIndex < coordinates.Length; coordinateIndex += 2)
        for (var index = 0; index < 3; index++)
            yield return new PointF(coordinates[coordinateIndex], coordinates[coordinateIndex + 1]);
}

IMAGINGNET-3985 Implement additional resize methods as per Aspose.Psd resize

New Resize Types in Aspose.Imaging library

New resize types were implemented in Aspose.Imaging library:

  • CatmullRom - The Catmull-Rom cubic interpolation method.
  • CubicConvolution - The Cubic Convolution interpolation method.
  • CubicBSpline - The CubicBSpline cubic interpolation method.
  • Mitchell - The Mitchell cubic interpolation method.
  • SinC - The Sinc (Lanczos3) cubic interpolation method.
  • Bell - The Bell interpolation method.

Resize image using specific Resize Type The next source code sample demonstrates how you can use specific Resize Type to resize the

using (var image = Image.Load("Photo.jpg"))
{
    image.Resize(640, 480, ResizeType.CatmullRom);
    image.Save("ResizedPhoto.jpg");

    image.Resize(1024, 768, ResizeType.CubicConvolution);
    image.Save("ResizedPhoto2.jpg");

    var resizeSettings = new ImageResizeSettings
    {
        Mode = ResizeType.CubicBSpline,
        FilterType = ImageFilterType.SmallRectangular
    };

    image.Resize(800, 800, resizeSettings);
    image.Save("ResizedPhoto3.jpg");
}

IMAGINGNET-3982 Exception in LoadRawData on by pixel reading for TIFF

private static void ReadOnePixel()
{
    License license = new License();
    license.SetLicense(@"Conholdate.Total.lic");
    var file = @"2by2.tif";
    using (TiffImage image = (TiffImage)Image.Load(file))
    {
        for (int i = 0; i < image.Width; i++)
        for (int j = 0; j < image.Height; j++)
        {
            image.LoadRawData(new Rectangle(i, j, 1, 1), image.RawDataSettings, new CustomRawDataLoader());
        }
    }
}

class CustomRawDataLoader : IPartialRawDataLoader
{
    public void Process(Rectangle rectangle, byte[] data, Point start, Point end)
    {
        this.Process(rectangle, data, start, end, null);
    }

    public void Process(Rectangle rectangle, byte[] data, Point start, Point end, LoadOptions loadOptions)
    {
    }
}

IMAGINGNET-3981 Exception in LoadRawData on line by line reading for TIFF

private static void ReadLineByLine()
{            
    License license = new License();
    license.SetLicense(@"Conholdate.Total.lic");
    var file = @"raster50x50.tif";
    using (TiffImage image = (TiffImage)Image.Load(file))
    {
        for (int i = 0; i < image.Height; i++)
        {
            image.LoadRawData(new Rectangle(0, i, image.Width, 1), image.RawDataSettings, new CustomRawDataLoader());
        }
    }
}

class CustomRawDataLoader : IPartialRawDataLoader
{
    public void Process(Rectangle rectangle, byte[] data, Point start, Point end)
    {
        this.Process(rectangle, data, start, end, null);
    }

    public void Process(Rectangle rectangle, byte[] data, Point start, Point end, LoadOptions loadOptions)
    {
    }
}

IMAGINGNET-3977 Exception on loading webp image

using (var image = Image.Load("failed_after_filter.wepb"))
{
    image.Save("failed_after_filter.webp.png", new PngOptions());
}

IMAGINGNET-3974 Object reference not set to an instance of an object exception when saving JP2

### Exporting JP2 image as a PNG

The  images in the Jpeg2000 format can be saved as a PNG images using following code:


using (Image image = Image.Load("sample.jp2"))
{
    PngOptions saveOptions = new PngOptions();

    image.Save("sample.jp2.png", saveOptions);
}


Using JP2 file as in attachments, the example of the result of execution of this code can be seen in the attached "sample.jp2.png" file.

IMAGINGNET-3973 Undefined function “if” exception when saving ODG

string baseFolder = @"D:\";
string inputFile = "sample.odg";
string inputFileName = Path.Combine(baseFolder, inputFile);
string outputFileName = inputFileName + ".png";
using (Image image = Image.Load(inputFileName))
{
   OdgRasterizationOptions odgRasterizationOptions = new OdgRasterizationOptions() {PageSize = image.Size};
   image.Save(outputFileName, new PngOptions() { VectorRasterizationOptions = odgRasterizationOptions });
}

IMAGINGNET-3867 Support the clipping operation in VectorImageExporter

In this task, general “Aspose.Imaging.Image.Save(System.IO.Stream,Aspose.Imaging.ImageOptionsBase,Aspose.Imaging.Rectangle)” method was implemented for all supported vector image formats. Consistency in border handling in VectorRasterizationOptions has also been maintained for all supported vector formats.

// WMF image format

using (Image image = Image.Load("castle.wmf"))
{
    // saving a rectangular part of the image to a PNG file.
    var clipRect = new Rectangle(355, 9, 130, 177);
    var exportOptions = new PngOptions() {
        VectorRasterizationOptions = new WmfRasterizationOptions() {
            PageWidth = 200,
            PageHeight = 300
        }
    }
    image.Save("castle.wmf_clip.png", exportOptions, clipRect);

    // setting the thickness of the outer borders
    exportOptions.VectorRasterizationOptions.BorderX = 50;
    exportOptions.VectorRasterizationOptions.BorderY = 25;
    image.Save("castle.wmf_clip._border.png", exportOptions, clipRect);
}

// EMF image format

using (Image image = Image.Load("Memo.emf"))
{
    // saving a rectangular part of the image to a PNG file.
    var clipRect = new Rectangle(690, 910, 300, 200);
    var exportOptions = new PngOptions() {
        VectorRasterizationOptions = new EmfRasterizationOptions() {
            PageWidth = 400,
            PageHeight = 300
        }
    }
    image.Save("Memo.emf_clip.png", exportOptions, clipRect);

    // setting the thickness of the outer borders
    exportOptions.VectorRasterizationOptions.BorderX = 50;
    exportOptions.VectorRasterizationOptions.BorderY = 25;
    image.Save("Memo.emf_clip._border.png", exportOptions, clipRect);
}

// SVG image format

using (Image image = Image.Load("sample_car.svg"))
{
    // saving a rectangular part of the image to a PNG file.
    var clipRect = new Rectangle(480, 360, 350, 420);
    var exportOptions = new PngOptions() {
        VectorRasterizationOptions = new SvgRasterizationOptions() {
            PageWidth = 300,
            PageHeight = 400
        }
    }
    image.Save("sample_car.svg_clip.png", exportOptions, clipRect);

    // setting the thickness of the outer borders
    exportOptions.VectorRasterizationOptions.BorderX = 50;
    exportOptions.VectorRasterizationOptions.BorderY = 25;
    image.Save("sample_car.svg_clip._border.png", exportOptions, clipRect);
}

// CDR image format
using (Image image = Image.Load("logo.cdr"))
{
    // saving a rectangular part of the image to a PNG file.
    var clipRect = new Rectangle(200, 700, 400, 300);
    var exportOptions = new PngOptions() {
        VectorRasterizationOptions = new CdrRasterizationOptions() {
            PageWidth = 400,
            PageHeight = 400
        }
    }
    image.Save("logo.cdr_clip.png", exportOptions, clipRect);

    // setting the thickness of the outer borders
    exportOptions.VectorRasterizationOptions.BorderX = 50;
    exportOptions.VectorRasterizationOptions.BorderY = 25;
    image.Save("logo.cdr_clip._border.png", exportOptions, clipRect);
}

// CMX image format
using (Image image = Image.Load("logo.cmx"))
{
    // saving a rectangular part of the image to a PNG file.
    var clipRect = new Rectangle(200, 700, 400, 300);
    var exportOptions = new PngOptions() {
        VectorRasterizationOptions = new CmxRasterizationOptions() {
            PageWidth = 400,
            PageHeight = 400
        }
    }
    image.Save("logo.cmx_clip.png", exportOptions, clipRect);

    // setting the thickness of the outer borders
    exportOptions.VectorRasterizationOptions.BorderX = 50;
    exportOptions.VectorRasterizationOptions.BorderY = 25;
    image.Save("logo.cmx_clip._border.png", exportOptions, clipRect);
}

// ODG image format

using (Image image = Image.Load("Example.odg"))
{
    // saving a rectangular part of the image to a PNG file.
    var clipRect = new Rectangle(350, 80, 350, 250);
    var exportOptions = new PngOptions() {
        VectorRasterizationOptions = new OdgRasterizationOptions() {
            PageWidth = 400,
            PageHeight = 170
        }
    }
    image.Save("Example.odg_clip.png", exportOptions, clipRect);

    // setting the thickness of the outer borders
    exportOptions.VectorRasterizationOptions.BorderX = 50;
    exportOptions.VectorRasterizationOptions.BorderY = 25;
    image.Save("Example.odg_clip._border.png", exportOptions, clipRect);
}


// OTG image format
using (Image image = Image.Load("connectors&fills.otg"))
{
    // saving a rectangular part of the image to a PNG file.
    var clipRect = new Rectangle(200, 700, 400, 300);
    var exportOptions = new PngOptions() {
        VectorRasterizationOptions = new OtgRasterizationOptions() {
            PageWidth = 500,
            PageHeight = 500
        }
    }
    image.Save("connectors&fills.otg_clip.png", exportOptions, clipRect);

    // setting the thickness of the outer borders
    exportOptions.VectorRasterizationOptions.BorderX = 50;
    exportOptions.VectorRasterizationOptions.BorderY = 25;
    image.Save("connectors&fills.otg_clip._border.png", exportOptions, clipRect);
}

IMAGINGNET-3843 - Aspose.Imaging 20.3: Exception when trying to convert particular Emf to raster image

using (var image = Aspose.Imaging.Image.Load("mci-flow-PA3.emf"))
{
    EmfRasterizationOptions emfRasterizationOptions = new EmfRasterizationOptions();
    emfRasterizationOptions.PageWidth = image.Width;
    emfRasterizationOptions.PageHeight = image.Height;

    PngOptions options = new PngOptions();
    options.VectorRasterizationOptions = emfRasterizationOptions;

    image.Save("result.png", options);
}

IMAGINGNET-3748 WMF image is cut on right in exported PDF

string fileName = "Test2.wmf";
string baseFolder = @"D:\";
string inputFilePath = Path.Combine(baseFolder, fileName);
string outputFilePath = inputFilePath + ".pdf";

using (Image image = Image.Load(inputFilePath))
{
    image.Save(outputFilePath, new PdfOptions()
    {
        VectorRasterizationOptions = new WmfRasterizationOptions { PageWidth = image.Width, PageHeight = image.Height }
    });
}

IMAGINGNET-3732 Enhance EPS format support

### What is EPS image format?

EPS file format is short for Encapsulated PostScript. It was created by Adobe back in 1992. It's a standard graphics file format intended for placing images or drawings within a PostScript Document. Basically it's a postscript program saved as a single file. EPS file also includes a low-resolution preview of the graphics inside which makes it accessible with programs not capable of editing the script inside. EPS file format is widely used by publishers because of its compatibility across different operating systems.

An EPS file can contain any combination of text, graphics, and images. Since it is actually a PostScript file, it is one of the most versatile file formats that are available. The files are supported by several different drawing programs and vector graphic editing applications. Many image converter programs can create EPS files containing the pixels of the image. An EPS file is a stream of generic PostScript printing commands. Thus many PostScript printer drivers have an option to save as EPS.

### The image preview

EPS files can optionally contain a bitmapped image preview so that systems that can't render PostScript directly can at least display a crude representation of what the graphic will look like. There are 4 preview formats: PICT, TIFF, Metafile and EPSI. It is also possible to have an EPS file without a preview, though. In this case, the imported file is usually displayed as a grayed out box or a box with diagonal lines running through it.

The preview image has a fixed resolution, which is usually 72 dpi. If you enlarge an EPS file in a document, the preview image is stretched and may become ‘blocky' and lacking in detail. This does not necessarily mean that the EPS-data themselves will degrade in quality. As long as the EPS-file only contains text and vector graphics, scaling it does not affect its quality. If you print a file containing an EPS-image on a non-PostScript printer, it is usually the preview image that gets printed. The preview image is ignored when you print to a PostScript device.

### Convert EPS image to PNG
The following code converts EPS image to PNG. The property **PreviewToExport** allows to select the source of the image to export from EPS file. The value **PostScriptRendering** of the enumeration **EpsPreviewFormat** cause rendering from PostScript to raster image.

using (var image = (EpsImage)Image.Load("Sample.eps"))
{
    var options = new PngOptions
    {
        VectorRasterizationOptions = new EpsRasterizationOptions
        {
            PageWidth = 500, // Image width
            PageHeight = 500 // Image height
        }
    };

    image.PreviewToExport = EpsPreviewFormat.PostScriptRendering; // Render raster image using the PostScript
    image.Save("Sample.png", options);
}

### Convert EPS to other formats
*Aspose.Imaging* library allows you to export EPS image to other formats. For that you just need to use corresponding Image options. The following code demonstrates how to export EPS image to PDF:

using (var image = (EpsImage)Image.Load("Sample.eps"))
{
    var options = new PdfOptions
    {
        PdfCoreOptions = new PdfCoreOptions
        {
            PdfCompliance = PdfComplianceVersion.PdfA1b // Set required PDF compliance
        }
    };

    image.PreviewToExport = EpsPreviewFormat.PostScriptRendering;
    image.Save("Sample.pdf", options);
}

### Determine whether the EPS image has a preview
As we already discussed, EPS image can contain an encapsulated preview image. The following code shows how can you determine if the preview exists:

using (var image = (EpsImage)Image.Load("Sample.eps"))
{
    if (image.HasRasterPreview)
    {
        Console.WriteLine("The image has a raster preview.");
    }
}

### Export EPS preview image without PostScript rendering
There are several ways how can you export EPS preview image. The following code exports TIFF preview image:

using (var image = (EpsBinaryImage)Image.Load("Sample.eps"))
{
    // Tiff image export options
    var options = new TiffOptions(TiffExpectedFormat.TiffJpegRgb)

    // The first way:
    image.TiffPreview.Save("Sample1.tiff", options);

    // The second way:
    image.PreviewToExport = EpsPreviewFormat.TIFF;
    image.Save("Sample2.tiff", options);
}

IMAGINGNET-2981 - Exception on converting EPS

using (var image = (EpsImage)Image.Load("Sample.eps"))
{
    var options = new PngOptions
    {
        VectorRasterizationOptions = new EpsRasterizationOptions
        {
            PageWidth = 500, // Image width
            PageHeight = 500 // Image height
        }
    };

    image.PreviewToExport = EpsPreviewFormat.PostScriptRendering; // Render raster image using the PostScript
    image.Save("Sample.png", options);
}

IMAGINGNET-2243 - Support to load and convert EPS file PDF/A format

The following code demonstrates how to export EPS image to PDF:

using (var image = (EpsImage)Image.Load("Sample.eps"))
{
    var options = new PdfOptions
    {
        PdfCoreOptions = new PdfCoreOptions
        {
            PdfCompliance = PdfComplianceVersion.PdfA1b // Set required PDF compliance
        }
    };

    image.PreviewToExport = EpsPreviewFormat.PostScriptRendering;
    image.Save("Sample.pdf", options);
}