Aspose.Imaging for .NET 3.9.0 Release Notes
Contents
[
Hide
]
Aspose.Imaging for .Net has been updated to version 3.9.0 and we are pleased to announce it. The following is a list of changes in this version of Aspose.Imaging.
Features and Improvements
Key | Summary | Category |
---|---|---|
IMAGINGNET-1971 | Support for SAI format | New Feature |
IMAGINGNET-1970 | Support for GIMP2 format | New Feature |
IMAGINGNET-1847 | Implement ability for adding both vector graphics and bitmap components to Metafile | New Feature |
IMAGINGNET-2021 | Converting Djvu to Pdf file contains black pages only instead of image in it | Enhancement |
IMAGINGNET-2018 | Djvu extracted pages does not contain colors | Enhancement |
IMAGINGNET-2016 | Djvu converted to PDF successfully but unable to open the PDF using Adobe PDF reader | Enhancement |
IMAGINGNET-2007 | Emf image export error | Enhancement |
IMAGINGNET-2004 | Support for TEXT_AS_SHAPES while converting EMF to SVG format | Enhancement |
IMAGINGNET-2001 | Updating text in text layers of a PSD file is not generating expected output and also throwing exception | Enhancement |
IMAGINGNET-1991 | Investigate emf/emf+ renderer performance | Enhancement |
IMAGINGNET-1980 | Implement support of Icc profiles for Jpeg2000 images | Enhancement |
IMAGINGNET-1892 | PSD file has 6 layers while Aspose.Imaging shows 0 layers | Enhancement |
IMAGINGNET-1801 | Rotate operation causes color lose | Enhancement |
IMAGINGNET-1631 | Converting TIFF to JPEG shows exception: Image export failed, cannot parse file | Enhancement |
IMAGINGNET-1598 | Multiple export or saving of EmfImage throws an exception. | Enhancement |
IMAGINGNET-1597 | Transparency issue while Extracting TIFF Frame | Enhancement |
IMAGINGNET-1847 Implement ability for adding both vector graphics and bitmap components to Metafile |
namespace Tests
{
#region
using Aspose.Imaging;
using Aspose.Imaging.Brushes;
using Aspose.Imaging.FileFormats.Emf;
using Aspose.Imaging.FileFormats.Emf.Emf.Consts;
using Aspose.Imaging.FileFormats.Emf.Graphics;
using Aspose.Imaging.ImageOptions;
using Aspose.Imaging.Shapes;
#endregion
class Tests
{
const string BasePath = @"TestPath\";
public void PenTests()
{
EmfRecorderGraphics2D graphics = new EmfRecorderGraphics2D(
new Rectangle(0, 0, 1000, 1000),
new Size(1000, 1000),
new Size(100, 100));
{
Assert(graphics.BackgroundMode == EmfBackgroundMode.TRANSPARENT);
Assert(graphics.BackgroundColor == Color.Empty);
Assert(graphics.Clip == null);
Assert(graphics.ClipBounds.X == float.MinValue && graphics.ClipBounds.Y == float.MinValue);
Assert(graphics.ClipBounds.Width == float.MaxValue && graphics.ClipBounds.Height == float.MaxValue);
//
Pen pen = new Pen(Color.Bisque);
graphics.DrawLine(pen, 1, 1, 50, 50);
pen = new Pen(Color.BlueViolet, 3);
pen.EndCap = LineCap.Round;
graphics.DrawLine(pen, 15, 5, 50, 60);
pen.EndCap = LineCap.Square;
graphics.DrawLine(pen, 5, 10, 50, 10);
pen.EndCap = LineCap.Flat;
graphics.DrawLine(pen, new Point(5, 20), new Point(50, 20));
//
HatchBrush hatchBrush = new HatchBrush() { BackgroundColor = Color.AliceBlue, ForegroundColor = Color.Red, HatchStyle = HatchStyle.Cross };
pen = new Pen(hatchBrush, 7);
graphics.DrawRectangle(pen, 50, 50, 20, 30);
graphics.BackgroundMode = EmfBackgroundMode.OPAQUE;
graphics.DrawLine(pen, 80, 50, 80, 80);
//
pen = new Pen(new SolidBrush(Color.Aqua), 3);
pen.LineJoin = LineJoin.MiterClipped;
graphics.DrawPolygon(pen, new Point[] { new Point(10, 20), new Point(12, 45), new Point(22, 48), new Point(48, 36), new Point(30, 55), });
pen.LineJoin = LineJoin.Bevel;
graphics.DrawRectangle(pen, 50, 10, 10, 5);
pen.LineJoin = LineJoin.Round;
graphics.DrawRectangle(pen, 65, 10, 10, 5);
pen.LineJoin = LineJoin.Miter;
graphics.DrawRectangle(pen, 80, 10, 10, 5);
//
using (EmfImage image = graphics.EndRecording())
{
Test(image, "Pens.emf");
}
}
}
public void PenAndClockwiseArcTests()
{
EmfRecorderGraphics2D graphics = new EmfRecorderGraphics2D(
new Rectangle(0, 0, 1500, 1500),
new Size(1500, 1500),
new Size(150, 150));
{
//
Pen pen = new Pen(Color.Green, 1);
pen.DashStyle = DashStyle.Solid;
graphics.DrawArc(pen, new Rectangle(0, 5, 40, 30), 0, 360);
pen.Color = Color.Blue;
graphics.DrawArc(pen, new Rectangle(4, 7, 40, 30), 0, 90);
pen.Color = Color.Red;
graphics.DrawArc(pen, new Rectangle(8, 9, 40, 30), 0, 180);
pen.Color = Color.Yellow;
graphics.DrawArc(pen, new Rectangle(12, 11, 40, 30), 0, 270);
//
pen.DashStyle = DashStyle.Dot;
pen.Color = Color.Green;
graphics.DrawArc(pen, new Rectangle(0, 60, 40, 30), 10, 85);
pen.Color = Color.Blue;
graphics.DrawArc(pen, new Rectangle(0, 60, 40, 30), 110, 85);
pen.Color = Color.Red;
graphics.DrawArc(pen, new Rectangle(0, 60, 40, 30), 200, 85);
pen.Color = Color.Yellow;
graphics.DrawArc(pen, new Rectangle(0, 60, 40, 30), 300, 85);
//
pen.DashStyle = DashStyle.DashDotDot;
pen.Color = Color.Green;
graphics.DrawArc(pen, new Rectangle(50, 60, 40, 30), 10, -190);
pen.Color = Color.Blue;
graphics.DrawArc(pen, new Rectangle(54, 62, 40, 30), 110, -190);
pen.Color = Color.Red;
graphics.DrawArc(pen, new Rectangle(58, 64, 40, 30), 200, -190);
pen.Color = Color.Yellow;
graphics.DrawArc(pen, new Rectangle(62, 66, 40, 30), 300, -190);
//
using (EmfImage image = graphics.EndRecording())
{
Test(image, "ClockwiseArc.emf");
}
}
}
public void BrushTests1()
{
EmfRecorderGraphics2D graphics = new EmfRecorderGraphics2D(
new Rectangle(0, 0, 1000, 1000),
new Size(1000, 1000),
new Size(100, 100));
{
graphics.BackgroundMode = EmfBackgroundMode.OPAQUE;
//
Brush brush = new SolidBrush(Color.Bisque);
Pen pen = new Pen(Color.Aqua, 2);
graphics.FillPie(brush, new Rectangle(50, 00, 45, 30), 30, 15);
graphics.DrawPie(pen, new Rectangle(50, 00, 45, 30), 30, 15);
//
brush = new HatchBrush() { HatchStyle = HatchStyle.DarkHorizontal, BackgroundColor = Color.Green, ForegroundColor = Color.Black };
Figure figure = new Figure();
figure.AddShape(new RectangleShape(new RectangleF(0, 0, 40, 40)));
figure.AddShape(new RectangleShape(new RectangleF(30, 30, 60, 10)));
GraphicsPath graphicsPath = new GraphicsPath();
graphicsPath.AddFigure(figure);
graphics.FillPath(pen, brush, graphicsPath);
//
string patternFile = BasePath + "TextureBrushPattern.png";
using (Image pattern = Image.Load(patternFile))
{
brush = new TextureBrush(pattern);
graphics.FillRectangle(brush, new Rectangle(30, 50, 60, 45));
}
//
brush = new HatchBrush() { HatchStyle = HatchStyle.LightVertical, BackgroundColor = Color.Green, ForegroundColor = Color.Black };
graphics.FillRectangle(brush, new Rectangle(1, 45, 10, 70));
//
using (EmfImage image = graphics.EndRecording())
{
Test(image, "Brushes.emf");
}
}
}
public void PathFiguresTests()
{
Pen pen = new Pen(Color.Gray);
Brush brush = new HatchBrush() { BackgroundColor = Color.OrangeRed, ForegroundColor = Color.BlueViolet, HatchStyle = HatchStyle.DashedHorizontal };
GraphicsPath path = GetFiguresPath(false);
path.FillMode = FillMode.Alternate;
EmfRecorderGraphics2D graphics = new EmfRecorderGraphics2D(
new Rectangle(0, 0, 1000, 1000),
new Size(1000, 1000),
new Size(100, 100));
{
graphics.FillPath(pen, brush, path);
using (EmfImage image = graphics.EndRecording())
{
Test(image, "Path_Figures_Filled.emf");
}
}
}
public void FontsTests()
{
EmfRecorderGraphics2D graphics = new EmfRecorderGraphics2D(
new Rectangle(0, 0, 5000, 5000),
new Size(5000, 5000),
new Size(1000, 1000));
{
Font font = new Font("Arial", 10, FontStyle.Bold | FontStyle.Underline);
graphics.DrawString(font.Name + " " + font.Size + " " + font.Style.ToString(), font, Color.Brown, 10, 10);
graphics.DrawString("some text", font, Color.Brown, 10, 30);
font = new Font("Arial", 24, FontStyle.Italic | FontStyle.Strikeout);
graphics.DrawString(font.Name + " " + font.Size + " " + font.Style.ToString(), font, Color.Brown, 20, 50);
graphics.DrawString("some text", font, Color.Brown, 20, 80);
//
using (EmfImage image = graphics.EndRecording())
{
Test(image, "Fonts.emf");
}
}
}
public void TransformTests()
{
EmfRecorderGraphics2D graphics = new EmfRecorderGraphics2D(
new Rectangle(0, 0, 1000, 1000),
new Size(1000, 1000),
new Size(100, 100));
{
//
Brush brush = new SolidBrush(Color.Beige);
Pen pen = new Pen(Color.Chartreuse);
graphics.FillRectangle(brush, new Rectangle(10, 10, 50, 70));
//
graphics.DrawLine(pen, 0, 0, 60, 60);
graphics.RotateTransform(30, new PointF(20, 20), MatrixOrder.Prepend);
pen.Color = Color.Blue;
graphics.DrawLine(pen, 0, 0, 60, 60);
//
pen.Color = Color.Red;
Matrix matrix = graphics.GetTransform();
matrix.RotateAt(15, new PointF(20, 20));
graphics.SetTransform(matrix);
graphics.DrawLine(pen, 0, 0, 60, 60);
//
graphics.ScaleTransform(2, 1.5f);
pen.Color = Color.Yellow;
graphics.DrawRectangle(pen, new Rectangle(0, 0, 60, 60));
//
graphics.RotateTransform(30);
graphics.DrawEllipse(pen, new Rectangle(20, 20, 20, 10));
//
using (EmfImage image = graphics.EndRecording())
{
Test(image, "Transform.emf");
}
}
}
public void ClipTests()
{
EmfRecorderGraphics2D graphics = new EmfRecorderGraphics2D(
new Rectangle(0, 0, 1000, 1000),
new Size(1000, 1000),
new Size(100, 100));
{
//
Brush brush = new SolidBrush(Color.Beige);
graphics.IntersectClip(new Rectangle(10, 10, 20, 20));
graphics.FillRectangle(brush, new Rectangle(10, 10, 50, 70));
//
Pen pen = new Pen(Color.Red);
graphics.ResetClip();
graphics.DrawLine(pen, 0, 0, 90, 90);
graphics.IntersectClip(new Rectangle(10, 10, 50, 20));
graphics.DrawLine(pen, 10, 0, 100, 90);
//
RectangleF rect = new RectangleF(15, 50, 30, 40);
graphics.Clip = new Region(rect);
Assert(rect == graphics.ClipBounds);
Region region = graphics.Clip;
region.Union(Rectangle.FromLeftTopRightBottom(18, 52, 50, 80));
graphics.Clip = region;
Assert(graphics.ClipBounds == RectangleF.FromLeftTopRightBottom(15, 50, 50, 90));
graphics.FillPolygon(brush, new Point[] { new Point(10, 40), new Point(70, 40), new Point(70, 100), new Point(10, 100) });
//
using (EmfImage image = graphics.EndRecording())
{
Test(image, "Clip.emf");
}
}
}
#region Private Methods
private static GraphicsPath GetFiguresPath(bool closeShapes)
{
GraphicsPath graphicsPath = new GraphicsPath();
//
Figure figure = new Figure();
figure.IsClosed = true;
figure.AddShape(new RectangleShape(new RectangleF(10, 5, 20, 15)));
//
Figure figure2 = new Figure();
figure2.IsClosed = true;
figure2.AddShape(new RectangleShape(new RectangleF(-10f, -10f, 22f, 22f)));
//
Figure figure3 = new Figure();
figure3.AddShape(new CurveShape(new PointF[] {
new PointF(20, 90),
new PointF(20, 60),
new PointF(60, 20),
new PointF(90, 20), },
0.5f,
closeShapes));
figure3.AddShape(new PolygonShape(new PointF[] {
new PointF(20, 90),
new PointF(20, 60),
new PointF(60, 20),
new PointF(90, 20), }));
figure3.AddShape(new BezierShape(new PointF[] {
new PointF(90, 25),
new PointF(73, 40),
new PointF(91, 65),
new PointF(45, 70), },
closeShapes));
figure3.AddShape(new ArcShape(new RectangleF(50, 50, 30, 20), 45, 120));
figure3.IsClosed = true;
//
Figure figure4 = new Figure();
figure4.AddShape(new PieShape(new RectangleF(70, 60, 30, 20), 270, -100));
figure4.AddShape(new EllipseShape(new RectangleF(40, 40, 10, 20)));
//
graphicsPath = new GraphicsPath();
graphicsPath.AddFigures(new Figure[] { figure, figure2, figure3, figure4 });
return graphicsPath;
}
private static void Test(EmfImage image, string fileName)
{
PdfOptions options = new PdfOptions();
EmfRasterizationOptions rasterizationOptions = new EmfRasterizationOptions();
rasterizationOptions.PageSize = image.Size;
options.VectorRasterizationOptions = rasterizationOptions;
string outPath = BasePath + fileName + ".pdf";
Assert(image.Header.EmfHeader.Valid);
image.Save(outPath, options);
}
private static void Assert(bool value)
{
if (!value)
{
throw new System.Exception();
}
}
#endregion
}
}
IMAGINGNET-2021 Converting Djvu to Pdf file contains black pages only instead of image in it
string fileName = "imging_document.djvu";
string outputFile = "result.pdf";
using (DjvuImage image = (DjvuImage)Image.Load(this.GetFileInBaseFolder(filePath)))
{
int documentPageCount = image.Pages.Length;
PdfOptions exportOptions = new PdfOptions();
exportOptions.PdfDocumentInfo = new Aspose.Imaging.FileFormats.Pdf.PdfDocumentInfo();
IntRange range = new IntRange(0, documentPageCount);
exportOptions.MultiPageOptions = new DjvuMultiPageOptions(range);
image.Save(outputFile, exportOptions);
}
IMAGINGNET-2018 Djvu extracted pages does not contain colors
string filename = "superhero.djvu";
using (DjvuImage image = (DjvuImage)Image.Load(filename))
{
DjvuPage page = image.Pages[8];
page.Save("result.png", new PngOptions());
}
IMAGINGNET-2007 Emf image export error
string filePath = "Picture1.emf";
string outPath = filePath + ".png";
using (Image mf = Image.Load(filePath))
{
EmfRasterizationOptions emfRasterizationOptions = new EmfRasterizationOptions();
emfRasterizationOptions.BackgroundColor = Color.White;
emfRasterizationOptions.PageWidth = 100;
emfRasterizationOptions.PageHeight = 100;
PngOptions pngOptions = new PngOptions();
pngOptions.VectorRasterizationOptions = emfRasterizationOptions;
mf.Save(outPath, pngOptions);
}
IMAGINGNET-2004 Support for TEXT_AS_SHAPES while converting EMF to SVG format
public void ExportTextAsShapes()
{
string path = @"CaplifeDisclaimer_eng.emf";
string destPath = @"CaplifeDisclaimer_eng_Path.svg";
string destTextPath = @"CaplifeDisclaimer_eng_Text.svg";
using (Image image = Image.Load(path))
{
EmfRasterizationOptions emfRasterizationOptions = new EmfRasterizationOptions();
emfRasterizationOptions.BackgroundColor = Color.White;
emfRasterizationOptions.PageWidth = image.Width;
emfRasterizationOptions.PageHeight = image.Height;
image.Save(destPath, new SvgOptions() { VectorRasterizationOptions = emfRasterizationOptions, TextAsShapes = true });
image.Save(destTextPath, new SvgOptions() { VectorRasterizationOptions = emfRasterizationOptions, TextAsShapes = false });
}
}
IMAGINGNET-2001 Updating text in text layers of a PSD file is not generating expected output and also throwing exception
string sourceFolder = @"./sampleFiles/";
string outputFolder = @"./output/";
DirectoryInfo dinfo = new DirectoryInfo(sourceFolder);
FileInfo[] finfo = dinfo.GetFiles("*.psd");
foreach (FileInfo file in finfo)
{
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(file.FullName))
{
string outputFile = outputFolder + file.Name;
var psdImage = (Aspose.Imaging.FileFormats.Psd.PsdImage)image;
int layers = psdImage.Layers.Length;
for (int i = 0; i < layers; i++)
{
if (psdImage.Layers[i] is TextLayer)
{
TextLayer textLayer = (TextLayer)psdImage.Layers[i];
textLayer.UpdateText("IK Changed TEXT");
}
}
psdImage.Save(outputFile, new PsdOptions() { CompressionMethod = CompressionMethod.RLE });
}
}
IMAGINGNET-1892 PSD file has 6 layers while Aspose.Imaging shows 0 layers
// This sample verifies that 32 bit/channel psd is loaded and layer can be saved to another format
string inputFilePath = "Layered PSD file bug.psd";
string outputPath = "result.bmp";
using (PsdImage image = (PsdImage)Image.Load(inputFilePath))
{
// Layers count for this file is 3
Console.WriteLine(image.Layers.Length);
// Save layer number 2 to bmp
image.Layers[1].Save(outputPath, new BmpOptions(), image.Layers[1].Bounds);
}
IMAGINGNET-1597 Transparency issue while Extracting TIFF Frame [.Net]
public void SaveImageWithAlphaChannel()
{
string srcPath = @"path_to_source_folder\strike.tif";
string destPath = @"path_to_dest_folder\strikeResult.tif";
using (TiffImage multiImage = (TiffImage)Image.Load(srcPath))
{
foreach (TiffFrame tiffFrame in multiImage.Frames)
{
multiImage.ActiveFrame = tiffFrame;
Color[] pixels = multiImage.LoadPixels(tiffFrame.Bounds);
TiffOptions settings = new TiffOptions(TiffExpectedFormat.TiffDeflateRgb);
settings.Source = new FileCreateSource(destPath, false);
using (TiffImage objTiffImage = (TiffImage)Image.Create(settings, tiffFrame.Width, tiffFrame.Height))
{
objTiffImage.SavePixels(tiffFrame.Bounds, pixels);
objTiffImage.Save();
}
}
}
}