CompressionLevel
PngOptions.CompressionLevel property
Png-bildkomprimeringsnivån i intervallet 0-9, där 9 är maximal komprimering och 0 är lagringsläge.
public int CompressionLevel { get; set; }
Exempel
Följande exempel visar hur man komprimerar en PNG-bild med hjälp av indexerad färg med palett som passar bäst
[C#]
// Laddar png-bild
string sourceFilePath="OriginalRings.png";
string outputFilePath="OriginalRingsOutput.png";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(sourceFilePath))
{
image.Save(outputFilePath, new Aspose.Imaging.ImageOptions.PngOptions()
{
Progressive = true,
// Använd indexerad färgtyp
ColorType = Aspose.Imaging.FileFormats.Png.PngColorType.IndexedColor,
// Använd maximal komprimering
CompressionLevel = 9,
// Få den närmaste 8-bitars färgpalett som täcker så många pixlar som möjligt, så att en palettiserad bild
// är nästan visuellt omöjlig att skilja från en icke-palletiserad.
Palette = Aspose.Imaging.ColorPaletteHelper.GetCloseImagePalette((Aspose.Imaging.RasterImage)image, 256, Aspose.Imaging.PaletteMiningMethod.Histogram)
});
}
// Utdatafilens storlek bör minskas avsevärt
Det här exemplet visar hur man skapar en PNG-bild med de angivna alternativen, fyller den med en linjär övertoningsfärg och sparar den i en fil.
[C#]
string dir = "c:\\temp\\";
Aspose.Imaging.ImageOptions.PngOptions createOptions = new Aspose.Imaging.ImageOptions.PngOptions();
// Antalet bitar per färgkanal
createOptions.BitDepth = 8;
// Varje pixel är en (röd, grön, blå) trippel följt av alfakomponenten.
createOptions.ColorType = Imaging.FileFormats.Png.PngColorType.TruecolorWithAlpha;
// Den maximala kompressionsnivån.
createOptions.CompressionLevel = 9;
// Användning av filter gör det möjligt att komprimera kontinuerliga tonala bilder mer effektivt.
createOptions.FilterType = Aspose.Imaging.FileFormats.Png.PngFilterType.Sub;
// Använd progressiv laddning
createOptions.Progressive = true;
// Skapa en PNG-bild med anpassade parametrar.
using (Aspose.Imaging.FileFormats.Png.PngImage pngImage = new Aspose.Imaging.FileFormats.Png.PngImage(createOptions, 100, 100))
{
Aspose.Imaging.Brushes.LinearGradientBrush gradientBrush = new Aspose.Imaging.Brushes.LinearGradientBrush(
new Aspose.Imaging.Point(0, 0),
new Aspose.Imaging.Point(pngImage.Width, pngImage.Height),
Aspose.Imaging.Color.Blue,
Aspose.Imaging.Color.Transparent);
Aspose.Imaging.Graphics graphics = new Aspose.Imaging.Graphics(pngImage);
// Fyll bilden med en halvtransparent gradient.
graphics.FillRectangle(gradientBrush, pngImage.Bounds);
// Spara till en fil.
pngImage.Save(dir + "output.explicitoptions.png");
}
Följande exempel visar hur man sparar en bild i PNG-format med olika alternativ.
[C#]
string dir = "c:\\temp\\";
// Skapa en PNG-bild på 100x100 px.
// Du kan också ladda bilder av vilket format som helst från en fil eller en stream.
using (Aspose.Imaging.FileFormats.Png.PngImage pngImage = new Aspose.Imaging.FileFormats.Png.PngImage(100, 100))
{
Aspose.Imaging.Brushes.LinearGradientBrush gradientBrush = new Aspose.Imaging.Brushes.LinearGradientBrush(
new Aspose.Imaging.Point(0, 0),
new Aspose.Imaging.Point(pngImage.Width, pngImage.Height),
Aspose.Imaging.Color.Blue,
Aspose.Imaging.Color.Transparent);
Aspose.Imaging.Graphics graphics = new Aspose.Imaging.Graphics(pngImage);
// Fyll bilden med den blå-transparenta gradienten.
graphics.FillRectangle(gradientBrush, pngImage.Bounds);
Aspose.Imaging.ImageOptions.PngOptions saveOptions = new Aspose.Imaging.ImageOptions.PngOptions();
// Progressiv laddning.
saveOptions.Progressive = true;
// Ställ in den horisontella och vertikala upplösningen till 96 pixlar per tum.
saveOptions.ResolutionSettings = new Aspose.Imaging.ResolutionSetting(96.0, 96.0);
// Varje pixel är en (röd, grön, blå) trippel följt av alfa.
saveOptions.ColorType = Imaging.FileFormats.Png.PngColorType.TruecolorWithAlpha;
// Ställ in den maximala komprimeringsnivån.
saveOptions.CompressionLevel = 9;
// Detta är den bästa komprimeringen, men den långsammaste exekveringstiden.
// Adaptiv filtrering innebär att sparprocessen kommer att välja det lämpligaste filtret för varje datarad.
saveOptions.FilterType = Aspose.Imaging.FileFormats.Png.PngFilterType.Adaptive;
// Antalet bitar per kanal.
saveOptions.BitDepth = 8;
// Spara till en fil.
pngImage.Save(dir + "output.png", saveOptions);
}
Se även
- class PngOptions
- namnutrymme Aspose.Imaging.ImageOptions
- hopsättning Aspose.Imaging