Aspose.Imaging for Java 20.8 - Release notes
Key | Summary | Category |
---|---|---|
IMAGINGJAVA-1786 | Enhance EPS format support | Feature |
IMAGINGJAVA-1749 | Support to load and convert EPS file PDF/A format | Feature |
IMAGINGJAVA-1747 | Implement ability to create GraphicsPath from Path resources in TIFF image and vice versa | Feature |
IMAGINGJAVA-1795 | Implement additional resize methods as per Aspose.Psd resize | Enhancement |
IMAGINGJAVA-1793 | “File is corrupted or damaged” exception is thrown when rendering WMF file | Enhancement |
IMAGINGJAVA-1792 | PSD exporter does not support compression methods | Enhancement |
IMAGINGJAVA-1791 | Incorrect output when exporting to BMP with RLE compression | Enhancement |
IMAGINGJAVA-1790 | Support of native export raster - HTML5 Canvas | Enhancement |
IMAGINGJAVA-1789 | Black output after resizing PNG and saving to JPG | Enhancement |
IMAGINGJAVA-1788 | WMF image is cut on right in exported PDF | Enhancement |
IMAGINGJAVA-1751 | Exception on converting EPS | Enhancement |
IMAGINGJAVA-1748 | Object reference not set to an instance of an object exception when saving JP2 | Enhancement |
IMAGINGJAVA-1744 | Undefined function “if” exception when saving ODG | Enhancement |
IMAGINGJAVA-1742 | WebPOptions.Quality property does not affect the degree of WebP image compression during export | Enhancement |
IMAGINGJAVA-1741 | Exception on loading webp image | Enhancement |
IMAGINGJAVA-1740 | Exception in LoadRawData on by pixel reading for TIFF | Enhancement |
IMAGINGJAVA-1739 | Exception in LoadRawData on line by line reading for TIFF | Enhancement |
IMAGINGJAVA-1737 | Support the clipping operation in VectorImageExporter | Enhancement |
IMAGINGJAVA-1736 | Aspose.Imaging 20.3: Exception when trying to convert particular Emf to raster image | Enhancement |
Public API changes:
Added APIs:
Please see corresponding cumulative API changes for Aspose.Imaging for .NET 20.8 version
Removed APIs:
Please see corresponding cumulative API changes for Aspose.Imaging for .NET 20.8 version
Usage Examples:
IMAGINGJAVA-1795 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 image:
try (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");
ImageResizeSettings resizeSettings = new ImageResizeSettings();
resizeSettings.setMode(ResizeType.CubicBSpline);
resizeSettings.setFilterType(ImageFilterType.SmallRectangular)
image.resize(800, 800, resizeSettings);
image.save("ResizedPhoto3.jpg");
}
IMAGINGJAVA-1793 “File is corrupted or damaged” exception is thrown when rendering WMF file
Without strict mode
String fileName = "GTK-ppt-fejlec-HU.wmf";
String baseFolder = "D:\\";
String inputFilePath = baseFolder + fileName;
String outputFilePath = inputFilePath + ".png";
try (Image image = Image.load(inputFilePath))
{
VectorRasterizationOptions vectorRasterizationOptions = new WmfRasterizationOptions();
vectorRasterizationOptions.setBackgroundColor(Color.getTransparent());
vectorRasterizationOptions.setPageWidth(image.getWidth());
vectorRasterizationOptions.setPageHeight(image.getHeight());
PngOptions pngOptions = new PngOptions();
pngOptions.setColorType(PngColorType.TruecolorWithAlpha);
pngOptions.setVectorRasterizationOptions(vectorRasterizationOptions);
image.save(outputFilePath, pngOptions);
}
With strict mode
String fileName = "GTK-ppt-fejlec-HU.wmf";
String baseFolder = "D:\\";
String inputFilePath = baseFolder + fileName;
try
{
final LoadOptions loadOptions = new LoadOptions();
loadOptions.setDataRecoveryMode(DataRecoveryMode.None);
try (Image image = Image.load(inputFilePath, loadOptions))
{
}
throw new TestException("DataRecoveryMode is not worked");
}
catch (ImageLoadException exception)
{
// Just skip it
}
IMAGINGJAVA-1792 PSD exporter does not support compression methods
// When exporting to PSD, options for compression, color type and bitness are available:
String SRC = "SRC";
try (Image image = Image.load(SRC))
{
// Export to PSD with RLE compression
final PsdOptions psdOptions = new PsdOptions();
psdOptions.setCompressionMethod(CompressionMethod.RLE);
image.save("DEST1", psdOptions);
// Export to PSD with RGB color type
psdOptions.setColorMode(ColorModes.Rgb);
psdOptions.setChannelsCount((short) 3);
psdOptions.setChannelBitsCount((short) 8);
image.save("DEST2", psdOptions);
// Export to PSD with ARGB color type
psdOptions.setColorMode(ColorModes.Rgb);
psdOptions.setChannelsCount((short) 4);
psdOptions.setChannelBitsCount((short) 8);
image.save("DEST3", psdOptions);
// Export to PSD with Grayscale color type
psdOptions.setColorMode(ColorModes.Grayscale);
psdOptions.setChannelsCount((short) 1);
psdOptions.setChannelBitsCount((short) 8);
image.save("DEST4", psdOptions);
// Export to PSD with Monochrome color type
psdOptions.setColorMode(ColorModes.Bitmap);
psdOptions.setChannelsCount((short) 1);
psdOptions.setChannelBitsCount((short) 1);
image.save("DEST5", psdOptions);
// Export to PSD with Indexed color type
psdOptions.setColorMode(ColorModes.Indexed);
psdOptions.setChannelsCount((short) 1);
psdOptions.setChannelBitsCount((short) 8);
psdOptions.setPalette(ColorPaletteHelper.create8Bit());
image.save("DEST6", psdOptions);
}
IMAGINGJAVA-1791 Incorrect output when exporting to BMP with RLE compression
try (Image image = Image.load("tiger.bmp"))
{
final BmpOptions bmpOptions = new BmpOptions();
bmpOptions.setCompression(BitmapCompression.Rle8);
bmpOptions.setBitsPerPixel(8);
bmpOptions.setPalette(ColorPaletteHelper.create8Bit());
image.save("Rle8.bmp", bmpOptions);
bmpOptions.setCompression(BitmapCompression.Rle4);
bmpOptions.setBitsPerPixel(4);
bmpOptions.setPalette(ColorPaletteHelper.create4Bit());
image.save("Rle4.bmp", bmpOptions);
}
IMAGINGJAVA-1790 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:
try (Image image = Image.load("tiger.bmp"))
{
image.save("tiger.html", new Html5CanvasOptions());
}
IMAGINGJAVA-1789 Black output after resizing PNG and saving to JPG
try (Image image = Image.load("image01-100MB.png"))
{
image.resize(600, 400);
image.save("output.jpg", new JpegOptions());
}
IMAGINGJAVA-1788 WMF image is cut on right in exported PDF
String fileName = "Test2.wmf";
String baseFolder = "D:\\";
String inputFilePath = baseFolder + fileName;
String outputFilePath = inputFilePath + ".pdf";
try (Image image = Image.load(inputFilePath))
{
final PdfOptions pdfOptions = new PdfOptions();
final WmfRasterizationOptions wmfOptions = new WmfRasterizationOptions();
wmfOptions.setPageWidth(image.getWidth());
wmfOptions.setPageHeight(image.getHeight());
pdfOptions.setVectorRasterizationOptions(wmfOptions);
image.save(outputFilePath, pdfOptions);
}
IMAGINGJAVA-1786 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.
try (EpsImage image = (EpsImage)Image.load("Sample.eps"))
{
PngOptions options = new PngOptions();
EpsRasterizationOptions epsRasterizationOptions = new EpsRasterizationOptions();
epsRasterizationOptions.setPageWidth(500); // Image width
epsRasterizationOptions.setPageHeight(500);// Image height
options.setVectorRasterizationOptions(epsRasterizationOptions);
image.setPreviewToExport(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:
try (EpsImage image = (EpsImage)Image.load("Sample.eps"))
{
PdfOptions options = new PdfOptions();
final PdfCoreOptions pdfCoreOptions = new PdfCoreOptions();
pdfCoreOptions.setPdfCompliance(PdfComplianceVersion.PdfA1b); // Set required PDF compliance
options.setPdfCoreOptions(pdfCoreOptions);
image.setPreviewToExport(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:
try (EpsImage image = (EpsImage)Image.load("Sample.eps"))
{
if (image.hasRasterPreview())
{
System.out.println("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:
try (EpsBinaryImage image = (EpsBinaryImage)Image.load("Sample.eps"))
{
// Tiff image export options
TiffOptions options = new TiffOptions(TiffExpectedFormat.TiffJpegRgb);
// The first way:
image.getTiffPreview().save("Sample1.tiff", options);
// The second way:
image.setPreviewToExport(EpsPreviewFormat.TIFF);
image.save("Sample2.tiff", options);
}
IMAGINGJAVA-1751 Exception on converting EPS
### 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.
try (EpsImage image = (EpsImage)Image.load("Sample.eps"))
{
PngOptions options = new PngOptions();
final EpsRasterizationOptions epsOptions = new EpsRasterizationOptions();
epsOptions.setPageWidth(500); // Image width
epsOptions.setPageHeight(500); // Image height
options.setVectorRasterizationOptions(epsOptions);
image.setPreviewToExport(EpsPreviewFormat.PostScriptRendering); // Render raster image using the PostScript
image.save("Sample.png", options);
}
IMAGINGJAVA-1749 Support to load and convert EPS file PDF/A format
### Convert EPS image to PDF
The following code demonstrates how to export EPS image to PDF:
try (EpsImage image = (EpsImage)Image.load("Sample.eps"))
{
PdfOptions options = new PdfOptions();
final PdfCoreOptions coreOptions = new PdfCoreOptions();
coreOptions.setPdfCompliance(PdfComplianceVersion.PdfA1b); // Set required PDF compliance
options.setPdfCoreOptions(coreOptions);
image.setPreviewToExport(EpsPreviewFormat.PostScriptRendering); // Render raster image using the PostScript
image.save("Sample.pdf", options);
}
IMAGINGJAVA-1748 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:
try (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.
IMAGINGJAVA-1747 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:
try (TiffImage image = (TiffImage)Image.load("Bottle.tif"))
{
// Create the GraphicsPath using PathResources from TIFF image
GraphicsPath graphicsPath = PathResourceConverter.toGraphicsPath(image.getActiveFrame().getPathResources().toArray(new PathResource[0]),
image.getActiveFrame().getSize());
Graphics graphics = new Graphics(image);
// Draw red line and save the image
graphics.drawPath(new Pen(Color.getRed(), 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)
{
try (TiffImage image = (TiffImage)Image.load("Bottle.tif"))
{
// Create rectangular Figure for GraphicsPath
Figure figure = new Figure();
figure.addShape(createBezierShape(100f, 100f, 500f, 100f, 500f, 1000f, 100f, 1000f));
// Create GraphicsPath using our Figure
GraphicsPath graphicsPath = new GraphicsPath();
graphicsPath.addFigure(figure);
// Set PathResources using GraphicsPath
PathResource[] pathResource = PathResourceConverter.fromGraphicsPath(graphicsPath, image.getSize());
image.getActiveFrame().setPathResources(Arrays.asList(pathResource));
// Save the image
image.save("BottleWithRectanglePath.tif");
}
}
private static BezierShape createBezierShape(float ... coordinates)
{
PointF[] bezierPoints = coordinatesToBezierPoints(coordinates);
return new BezierShape(bezierPoints, true);
}
private static PointF[] coordinatesToBezierPoints(float[] coordinates)
{
PointF[] result = new PointF[coordinates.length / 2 * 3];
int j = 0;
for (int i = 0; i < coordinates.length - 1; i += 2)
{
result[j++] = new PointF(coordinates[i], coordinates[i+1]);
result[j++] = new PointF(coordinates[i], coordinates[i+1]);
result[j++] = new PointF(coordinates[i], coordinates[i+1]);
}
return result;
}
IMAGINGJAVA-1744 Undefined function “if” exception when saving ODG
String baseFolder = "D:\\";
String inputFile = "sample.odg";
String inputFileName = baseFolder + inputFile;
String outputFileName = inputFileName + ".png";
try (Image image = Image.load(inputFileName))
{
OdgRasterizationOptions odgRasterizationOptions = new OdgRasterizationOptions();
odgRasterizationOptions.setPageSize(Size.toSizeF(image.getSize()));
PngOptions options = new PngOptions();
options.setVectorRasterizationOptions(odgRasterizationOptions);
image.save(outputFileName, options);
}
IMAGINGJAVA-1742 WebPOptions.Quality property does not affect the degree of WebP image compression during export
// Export GIF animation to WEBP with different compression quality
try (Image image = Image.load("test.gif"))
{
// for lossless compression, increasing the quality setting increases the compression quality and decreases the file size
WebPOptions webPOptions = new WebPOptions();
webPOptions.setLossless(true);
webPOptions.setQuality(20);
image.save(
"output_lossless_20.webp",
webPOptions); // file size: 42 KB
webPOptions.setLossless(true);
webPOptions.setQuality(50);
image.save(
"output_lossless_50.webp",
webPOptions); // file size: 41 KB
webPOptions.setLossless(true);
webPOptions.setQuality(80);
image.save(
"output_lossless_80.webp",
webPOptions); // file size: 40 KB
// for lossy compression, increasing the Quality value increases the image quality and increases the file size
webPOptions.setLossless(false);
webPOptions.setQuality(20);
image.save(
"output_lossy_20.webp",
webPOptions); // file size: 24 KB
webPOptions.setLossless(false);
webPOptions.setQuality(50);
image.save(
"output_lossy_50.webp",
webPOptions); // file size: 36 KB
webPOptions.setLossless(false);
webPOptions.setQuality(80);
image.save(
"output_lossy_80.webp",
webPOptions); // file size: 51 KB
}
IMAGINGJAVA-1741 Exception on loading webp image
try (Image image = Image.load("failed_after_filter.wepb"))
{
image.save("failed_after_filter.webp.png", new PngOptions());
}
IMAGINGJAVA-1740 Exception in LoadRawData on by pixel reading for TIFF
private static void readOnePixel()
{
License license = new License();
license.setLicense("Conholdate.Total.lic");
String file = "2by2.tif";
try (TiffImage image = (TiffImage)Image.load(file))
{
for (int y = 0; i < image.getHeight(); y++)
{
for (int x = 0; i < image.getWidth(); x++)
image.loadRawData(new Rectangle(x, y, 1, 1), image.getRawDataSettings(), new CustomRawDataLoader());
}
}
}
class CustomRawDataLoader implements 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)
{
// Do everything you need
}
}
IMAGINGJAVA-1739 Exception in LoadRawData on line by line reading for TIFF
private static void readLineByLine()
{
License license = new License();
license.setLicense("Conholdate.Total.lic");
String file = "raster50x50.tif";
try (TiffImage image = (TiffImage)Image.load(file))
{
for (int i = 0; i < image.getHeight(); i++)
{
image.loadRawData(new Rectangle(0, i, image.getWidth(), 1), image.getRawDataSettings(), new CustomRawDataLoader());
}
}
}
class CustomRawDataLoader implements 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)
{
// Here do everything you need with pixel's data
}
}
IMAGINGJAVA-1737 Support the clipping operation in VectorImageExporter
WMF image format
try (Image image = Image.load("castle.wmf"))
{
// saving a rectangular part of the image to a PNG file.
Rectangle clipRect = new Rectangle(355, 9, 130, 177);
PngOptions exportOptions = new PngOptions();
final WmfRasterizationOptions wmfOptions = new WmfRasterizationOptions();
wmfOptions.setPageWidth(200);
wmfOptions.setPageHeight(200);
exportOptions.setVectorRasterizationOptions(wmfOptions);
image.save("castle.wmf_clip.png", exportOptions, clipRect);
// setting the thickness of the outer borders
wmfOptions.setBorderX(50);
wmfOptions.setBorderY(25);
image.save("castle.wmf_clip._border.png", exportOptions, clipRect);
}
IMAGINGJAVA-1736 Aspose.Imaging 20.3: Exception when trying to convert particular Emf to raster image
try (com.aspose.imaging.Image image = com.aspose.imaging.Image.load("mci-flow-PA3.emf"))
{
EmfRasterizationOptions emfRasterizationOptions = new EmfRasterizationOptions();
emfRasterizationOptions.setPageWidth(image.getWidth());
emfRasterizationOptions.setPageHeight(image.getHeight());
PngOptions options = new PngOptions();
options.setVectorRasterizationOptions(emfRasterizationOptions);
image.save("result.png", options);
}