Class RasterImage
اسم الفضاء : Aspose.Imaging تجميع: Aspose.Imaging.dll (25.4.0)
يمثل صورة راستر تدعم عمليات الرسومات راستر.
public abstract class RasterImage : Image, IDisposable, IObjectWithBounds, IRasterImageArgb32PixelLoader, IRasterImageRawDataLoader, IHasXmpData, IHasMetadata
Inheritance
object ← DisposableObject ← DataStreamSupporter ← Image ← RasterImage
Derived
Implements
IDisposable , IObjectWithBounds , IRasterImageArgb32PixelLoader , IRasterImageRawDataLoader , IHasXmpData , IHasMetadata
الأعضاء الموروثين
Image.CanLoad(string) , Image.CanLoad(string, LoadOptions) , Image.CanLoad(Stream) , Image.CanLoad(Stream, LoadOptions) , Image.Create(ImageOptionsBase, int, int) , Image.Create(Image[]) , Image.Create(MultipageCreateOptions) , Image.Create(string[], bool) , Image.Create(string[]) , Image.Create(Image[], bool) , Image.GetFileFormat(string) , Image.GetFileFormat(Stream) , Image.GetFittingRectangle(Rectangle, int, int) , Image.GetFittingRectangle(Rectangle, int[], int, int) , Image.Load(string, LoadOptions) , Image.Load(string) , Image.Load(Stream, LoadOptions) , Image.Load(Stream) , Image.GetProportionalWidth(int, int, int) , Image.GetProportionalHeight(int, int, int) , Image.RemoveMetadata() , Image.CanSave(ImageOptionsBase) , Image.Resize(int, int) , Image.Resize(int, int, ResizeType) , Image.Resize(int, int, ImageResizeSettings) , Image.GetDefaultOptions(object[]) , Image.GetOriginalOptions() , Image.ResizeWidthProportionally(int) , Image.ResizeHeightProportionally(int) , Image.ResizeWidthProportionally(int, ResizeType) , Image.ResizeHeightProportionally(int, ResizeType) , Image.ResizeWidthProportionally(int, ImageResizeSettings) , Image.ResizeHeightProportionally(int, ImageResizeSettings) , Image.RotateFlip(RotateFlipType) , Image.Rotate(float) , Image.Crop(Rectangle) , Image.Crop(int, int, int, int) , Image.Save() , Image.Save(string) , Image.Save(string, ImageOptionsBase) , Image.Save(string, ImageOptionsBase, Rectangle) , Image.Save(Stream, ImageOptionsBase) , Image.Save(Stream, ImageOptionsBase, Rectangle) , Image.GetSerializedStream(ImageOptionsBase, Rectangle, out int) , Image.SetPalette(IColorPalette, bool) , Image.UpdateContainer(Image) , Image.GetCanNotSaveMessage(ImageOptionsBase) , Image.GetFitRectangle(Rectangle) , Image.GetImage2Export(ImageOptionsBase, Rectangle, IImageExporter) , Image.GetFitRectangle(Rectangle, int[]) , Image.OnPaletteChanged(IColorPalette, IColorPalette) , Image.OnPaletteChanging(IColorPalette, IColorPalette) , Image.ReleaseManagedResources() , Image.BitsPerPixel , Image.Bounds , Image.Container , Image.Height , Image.Palette , Image.UsePalette , Image.Size , Image.Width , Image.InterruptMonitor , Image.BufferSizeHint , Image.AutoAdjustPalette , Image.HasBackgroundColor , Image.FileFormat , Image.BackgroundColor , DataStreamSupporter.timeout , DataStreamSupporter.CacheData() , DataStreamSupporter.Save() , DataStreamSupporter.Save(Stream) , DataStreamSupporter.Save(string) , DataStreamSupporter.Save(string, bool) , DataStreamSupporter.SaveData(Stream) , DataStreamSupporter.ReleaseManagedResources() , DataStreamSupporter.OnDataStreamContainerChanging(StreamContainer) , DataStreamSupporter.DataStreamContainer , DataStreamSupporter.IsCached , DisposableObject.Dispose() , DisposableObject.ReleaseManagedResources() , DisposableObject.ReleaseUnmanagedResources() , DisposableObject.VerifyNotDisposed() , DisposableObject.Disposed , object.GetType() , object.MemberwiseClone() , object.ToString() , object.Equals(object?) , object.Equals(object?, object?) , object.ReferenceEquals(object?, object?) , object.GetHashCode()
Examples
يظهر هذا المثال كيفية تحميل معلومات بيكسيل في سلسلة من نوع اللون، وتلاعب السلسلة وإعادتها إلى الصورة.لإجراء هذه العمليات، يخلق هذا المثال ملف صورة جديد (في تنسيق GIF) uisng كائن MemoryStream.
//Create an instance of MemoryStream
using (System.IO.MemoryStream stream = new System.IO.MemoryStream())
{
//Create an instance of GifOptions and set its various properties including the Source property
Aspose.Imaging.ImageOptions.GifOptions gifOptions = new Aspose.Imaging.ImageOptions.GifOptions();
gifOptions.Source = new Aspose.Imaging.Sources.StreamSource(stream);
//Create an instance of Image
using (Aspose.Imaging.RasterImage image = (Aspose.Imaging.RasterImage)Aspose.Imaging.Image.Create(gifOptions, 500, 500))
{
//Get the pixels of image by specifying the area as image boundary
Aspose.Imaging.Color[] pixels = image.LoadPixels(image.Bounds);
//Loop over the Array and sets color of alrenative indexed pixel
for (int index = 0; index < pixels.Length; index++)
{
if (index % 2 == 0)
{
//Set the indexed pixel color to yellow
pixels[index] = Aspose.Imaging.Color.Yellow;
}
else
{
//Set the indexed pixel color to blue
pixels[index] = Aspose.Imaging.Color.Blue;
}
}
//Apply the pixel changes to the image
image.SavePixels(image.Bounds, pixels);
// save all changes.
image.Save();
}
// Write MemoryStream to File
using (System.IO.FileStream fileStream = new System.IO.FileStream(@"C:\temp\output.gif", System.IO.FileMode.Create))
{
stream.WriteTo(fileStream);
}
}
Constructors
RasterImage()
يبدأ مثالًا جديدًا من فئة Aspose.Imaging.RasterImage.
[JsonConstructor]
protected RasterImage()
RasterImage(ICOLORPALET)
يبدأ مثالًا جديدًا من فئة Aspose.Imaging.RasterImage.
protected RasterImage(IColorPalette colorPalette)
Parameters
colorPalette
IColorPalette
اللوحة الألوان .
Fields
xmpData
إحصائيات XMP
[JsonProperty]
protected XmpPacketWrapper xmpData
القيمة الميدانية
Properties
DataLoader
يحصل أو يقوم بتحميل البيانات.
[JsonProperty]
protected IRasterImageArgb32PixelLoader DataLoader { get; set; }
قيمة الممتلكات
HasAlpha
يحصل على قيمة تشير إلى ما إذا كانت هذه الحالة لديها ألفا.
public virtual bool HasAlpha { get; }
قيمة الممتلكات
Examples
يُحمل المثال التالي صورًا متسلسلة ويطبع معلومات عن تنسيق البيانات الخام وقناة ألفا.
// The image files to load.
string[] fileNames = new string[]
{
@"c:\temp\sample.bmp",
@"c:\temp\alpha.png",
};
foreach (string fileName in fileNames)
{
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(fileName))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
System.Console.WriteLine("ImageFile={0}, FileFormat={1}, HasAlpha={2}", fileName, rasterImage.RawDataFormat, rasterImage.HasAlpha);
}
}
// The output may look like this:
// ImageFile=c:\temp\sample.bmp, FileFormat=Rgb24Bpp, used channels: 8,8,8, HasAlpha=False
// ImageFile=c:\temp\alpha.png, FileFormat=RGBA32Bpp, used channels: 8,8,8,8, HasAlpha=True
يظهر المثال التالي كيفية استخراج المعلومات حول تنسيق البيانات الخام والقناة الألفا من صورة BMP.
// Create a 32-bpp BMP image of 100 x 100 px.
using (Aspose.Imaging.FileFormats.Bmp.BmpImage bmpImage = new Aspose.Imaging.FileFormats.Bmp.BmpImage(100, 100, 32, null))
{
System.Console.WriteLine("FileFormat={0}, RawDataFormat={1}, HasAlpha={2}", bmpImage.FileFormat, bmpImage.RawDataFormat, bmpImage.HasAlpha);
};
// Create a 24-bpp BMP image of 100 x 100 px.
using (Aspose.Imaging.FileFormats.Bmp.BmpImage bmpImage = new Aspose.Imaging.FileFormats.Bmp.BmpImage(100, 100, 24, null))
{
System.Console.WriteLine("FileFormat={0}, RawDataFormat={1}, HasAlpha={2}", bmpImage.FileFormat, bmpImage.RawDataFormat, bmpImage.HasAlpha);
};
// Generally, BMP doesn't support alpha channel so the output will look like this:
// FileFormat = Bmp, RawDataFormat = Rgb32Bpp, used channels: 8,8,8,8, HasAlpha = False
// FileFormat = Bmp, RawDataFormat = Rgb24Bpp, used channels: 8,8,8, HasAlpha = False
HasTransparentColor
يحصل على قيمة تشير إلى ما إذا كانت الصورة لها لون شفاف.
public virtual bool HasTransparentColor { get; set; }
قيمة الممتلكات
HorizontalResolution
يحصل أو يضع القرار الأفقي، في بكسل لكل بوصة، من هذا Aspose.Imaging.RasterImage.
public virtual double HorizontalResolution { get; set; }
قيمة الممتلكات
Examples
يظهر المثال التالي كيفية تعيين الدقة الأفقية / العمودية لصورة الرسوم المتحركة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.jpg"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Get horizontal and vertical resolution of the image
double horizontalResolution = rasterImage.HorizontalResolution;
double verticalResolution = rasterImage.VerticalResolution;
System.Console.WriteLine("The horizontal resolution, in pixels per inch: {0}", horizontalResolution);
System.Console.WriteLine("The vertical resolution, in pixels per inch: {0}", verticalResolution);
if (horizontalResolution != 96.0 || verticalResolution != 96.0)
{
// Use the SetResolution method for updating both resolution values in a single call.
System.Console.WriteLine("Set resolution values to 96 dpi");
rasterImage.SetResolution(96.0, 96.0);
System.Console.WriteLine("The horizontal resolution, in pixels per inch: {0}", rasterImage.HorizontalResolution);
System.Console.WriteLine("The vertical resolution, in pixels per inch: {0}", rasterImage.VerticalResolution);
}
// The output may look like this:
// The horizontal resolution, in pixels per inch: 300
// The vertical resolution, in pixels per inch: 300
// Set resolution values to 96 dpi
// The horizontal resolution, in pixels per inch: 96
// The vertical resolution, in pixels per inch: 96
}
Remarks
ملاحظة الافتراضية هذه القيمة هي دائما 96 لأن المنصات المختلفة لا يمكن إرجاع دقة الشاشة.يمكنك التفكير في استخدام طريقة SetResolution لتحديث كل من قيم الدقة في مكالمة واحدة.
ImageOpacity
يبدو أن هذه الصورة غير مسبوقة.
public virtual float ImageOpacity { get; }
قيمة الممتلكات
IsRawDataAvailable
يحصل على قيمة تشير إلى ما إذا كان تحميل البيانات الخام متاحًا.
public bool IsRawDataAvailable { get; }
قيمة الممتلكات
PremultiplyComponents
يحصل أو يضع قيمة تشير إلى ما إذا كانت مكونات الصورة يجب أن تكون مسبقة.
public virtual bool PremultiplyComponents { get; set; }
قيمة الممتلكات
Examples
يخلق المثال التالي صورة جديدة ، ويحفظ البكسل النصفية المحددة ، ثم يحمل تلك البكسل ويحصل على الألوان النهائية في الشكل المكرر.
int imageWidth = 3;
int imageHeight = 2;
Aspose.Imaging.Color[] colors = new Aspose.Imaging.Color[]
{
Aspose.Imaging.Color.FromArgb(127, 255, 0, 0),
Aspose.Imaging.Color.FromArgb(127, 0, 255, 0),
Aspose.Imaging.Color.FromArgb(127, 0, 0, 255),
Aspose.Imaging.Color.FromArgb(127, 255, 255, 0),
Aspose.Imaging.Color.FromArgb(127, 255, 0, 255),
Aspose.Imaging.Color.FromArgb(127, 0, 255, 255),
};
Aspose.Imaging.ImageOptions.PngOptions createOptions = new Aspose.Imaging.ImageOptions.PngOptions();
createOptions.Source = new Aspose.Imaging.Sources.StreamSource(new System.IO.MemoryStream(), true);
createOptions.ColorType = Aspose.Imaging.FileFormats.Png.PngColorType.TruecolorWithAlpha;
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Create(createOptions, imageWidth, imageHeight))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Save pixels for the whole image.
rasterImage.SavePixels(rasterImage.Bounds, colors);
// The pixels are stored in the original image in the non-premultiplied form.
// Need to specify the corresponding option explicitly to obtain premultiplied color components.
// The premultiplied color components are calculated by the formulas:
// red = original_red * alpha / 255;
// green = original_green * alpha / 255;
// blue = original_blue * alpha / 255;
rasterImage.PremultiplyComponents = true;
Aspose.Imaging.Color[] premultipliedColors = rasterImage.LoadPixels(rasterImage.Bounds);
for (int i = 0; i < colors.Length; i++)
{
System.Console.WriteLine("Original color: {0}", colors[i].ToString());
System.Console.WriteLine("Premultiplied color: {0}", premultipliedColors[i].ToString());
}
}
RawCustomColorConverter
يحصل أو يضع مبدل الألوان المخصص
public IColorConverter RawCustomColorConverter { get; set; }
قيمة الممتلكات
RawDataFormat
يحصل على تنسيق البيانات الخام.
public virtual PixelDataFormat RawDataFormat { get; }
قيمة الممتلكات
Examples
يُحمل المثال التالي صورًا متسلسلة ويطبع معلومات عن تنسيق البيانات الخام وقناة ألفا.
// The image files to load.
string[] fileNames = new string[]
{
@"c:\temp\sample.bmp",
@"c:\temp\alpha.png",
};
foreach (string fileName in fileNames)
{
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(fileName))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
System.Console.WriteLine("ImageFile={0}, FileFormat={1}, HasAlpha={2}", fileName, rasterImage.RawDataFormat, rasterImage.HasAlpha);
}
}
// The output may look like this:
// ImageFile=c:\temp\sample.bmp, FileFormat=Rgb24Bpp, used channels: 8,8,8, HasAlpha=False
// ImageFile=c:\temp\alpha.png, FileFormat=RGBA32Bpp, used channels: 8,8,8,8, HasAlpha=True
هذا المثال يظهر كيفية تحميل صورة DJVU من تدفق الملفات وطباعة المعلومات حول الصفحات.
string dir = "c:\\temp\\";
// Load a DJVU image from a file stream.
using (System.IO.Stream stream = System.IO.File.OpenRead(dir + "sample.djvu"))
{
using (Aspose.Imaging.FileFormats.Djvu.DjvuImage djvuImage = new Aspose.Imaging.FileFormats.Djvu.DjvuImage(stream))
{
System.Console.WriteLine("The total number of pages: {0}", djvuImage.Pages.Length);
System.Console.WriteLine("The active page number: {0}", djvuImage.ActivePage.PageNumber);
System.Console.WriteLine("The first page number: {0}", djvuImage.FirstPage.PageNumber);
System.Console.WriteLine("The last page number: {0}", djvuImage.LastPage.PageNumber);
foreach (Aspose.Imaging.FileFormats.Djvu.DjvuPage djvuPage in djvuImage.Pages)
{
System.Console.WriteLine("--------------------------------------------------");
System.Console.WriteLine("Page number: {0}", djvuPage.PageNumber);
System.Console.WriteLine("Page size: {0}", djvuPage.Size);
System.Console.WriteLine("Page raw format: {0}", djvuPage.RawDataFormat);
}
}
}
//The output may look like this:
//The total number of pages: 2
//The active page number: 1
//The first page number: 1
//The last page number: 2
//--------------------------------------------------
//Page number: 1
//Page size: { Width = 2481, Height = 3508}
//Page raw format: RgbIndexed1Bpp, used channels: 1
//--------------------------------------------------
//Page number: 2
//Page size: { Width = 2481, Height = 3508}
//Page raw format: RgbIndexed1Bpp, used channels: 1
RawDataSettings
احصل على إعدادات البيانات الخام الحالية.ملاحظة عند استخدام هذه الإعدادات يتم تحميل البيانات دون تحويل.
[JsonIgnore]
public RawDataSettings RawDataSettings { get; }
قيمة الممتلكات
RawFallbackIndex
يحصل أو يضع مؤشر الانخفاض للاستخدام عندما يكون مؤشر الباليه خارج الحدود
public int RawFallbackIndex { get; set; }
قيمة الممتلكات
RawIndexedColorConverter
يحصل أو يضع محول الألوان المؤشر
public IIndexedColorConverter RawIndexedColorConverter { get; set; }
قيمة الممتلكات
RawLineSize
يحصل على حجم الخط الخام في بايت.
public virtual int RawLineSize { get; }
قيمة الممتلكات
TransparentColor
يحصل الصورة على لون شفاف.
public virtual Color TransparentColor { get; set; }
قيمة الممتلكات
UpdateXmpData
يحصل أو يضع قيمة تشير إلى ما إذا كان يجب تحديث بيانات XMP.
public virtual bool UpdateXmpData { get; set; }
قيمة الممتلكات
UsePalette
يحصل على قيمة تشير إلى ما إذا كانت لوحة الصورة تستخدم.
public override bool UsePalette { get; }
قيمة الممتلكات
UseRawData
يحصل أو يضع قيمة تشير إلى ما إذا كان لاستخدام تحميل البيانات الخام عندما يكون تحميل البيانات الخام متاحًا.
public virtual bool UseRawData { get; set; }
قيمة الممتلكات
VerticalResolution
يحصل أو يضع القرار العمودي، في بكسل لكل بوصة، من هذا Aspose.Imaging.RasterImage.
public virtual double VerticalResolution { get; set; }
قيمة الممتلكات
Examples
يظهر المثال التالي كيفية تعيين الدقة الأفقية / العمودية لصورة الرسوم المتحركة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.jpg"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Get horizontal and vertical resolution of the image
double horizontalResolution = rasterImage.HorizontalResolution;
double verticalResolution = rasterImage.VerticalResolution;
System.Console.WriteLine("The horizontal resolution, in pixels per inch: {0}", horizontalResolution);
System.Console.WriteLine("The vertical resolution, in pixels per inch: {0}", verticalResolution);
if (horizontalResolution != 96.0 || verticalResolution != 96.0)
{
// Use the SetResolution method for updating both resolution values in a single call.
System.Console.WriteLine("Set resolution values to 96 dpi");
rasterImage.SetResolution(96.0, 96.0);
System.Console.WriteLine("The horizontal resolution, in pixels per inch: {0}", rasterImage.HorizontalResolution);
System.Console.WriteLine("The vertical resolution, in pixels per inch: {0}", rasterImage.VerticalResolution);
}
// The output may look like this:
// The horizontal resolution, in pixels per inch: 300
// The vertical resolution, in pixels per inch: 300
// Set resolution values to 96 dpi
// The horizontal resolution, in pixels per inch: 96
// The vertical resolution, in pixels per inch: 96
}
Remarks
ملاحظة الافتراضية هذه القيمة هي دائما 96 لأن المنصات المختلفة لا يمكن إرجاع دقة الشاشة.يمكنك التفكير في استخدام طريقة SetResolution لتحديث كل من قيم الدقة في مكالمة واحدة.
XmpData
يحصل أو يضع البيانات الميتا XMP.
public virtual XmpPacketWrapper XmpData { get; set; }
قيمة الممتلكات
Methods
AdjustBrightness(إنت)
تعديل الضوء للصورة.
public virtual void AdjustBrightness(int brightness)
Parameters
brightness
int
قيمة الضوء
Examples
في المثال التالي ، يتم إجراء تصحيح الضوء للصورة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Set the brightness value. The accepted values of brightness are in the range [-255, 255].
rasterImage.AdjustBrightness(50);
rasterImage.Save(dir + "sample.AdjustBrightness.png");
}
AdjustContrast(السفينة)
صورة تناقض
public virtual void AdjustContrast(float contrast)
Parameters
contrast
float
قيمة التباين (في نطاق [-100؛ 100])
Examples
في المثال التالي ، يتم إجراء تصحيح تناقض للصورة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Set the contrast value. The accepted values of contrast are in the range [-100f, 100f].
rasterImage.AdjustContrast(50);
rasterImage.Save(dir + "sample.AdjustContrast.png");
}
AdjustGamma(السفينة، السفينة، السفينة)
تصحيح غاما للصورة
public virtual void AdjustGamma(float gammaRed, float gammaGreen, float gammaBlue)
Parameters
gammaRed
float
القناة الحمراء معدل القناة الحمراء
gammaGreen
float
غاما لـ قناة خضراء
gammaBlue
float
القناة الزرقاء معدل القناة الزرقاء
Examples
يقدم المثال التالي تصحيح غاما للصورة التي تطبق مؤشرات مختلفة على مكونات الألوان.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Set individual gamma coefficients for red, green and blue channels.
rasterImage.AdjustGamma(1.5f, 2.5f, 3.5f);
rasterImage.Save(dir + "sample.AdjustGamma.png");
}
AdjustGamma(السفينة)
تصحيح غاما للصورة
public virtual void AdjustGamma(float gamma)
Parameters
gamma
float
غاما لعدد القنوات الحمراء والخضراء
Examples
في المثال التالي ، يتم إجراء تصحيح غاما للصورة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Set gamma coefficient for red, green and blue channels.
rasterImage.AdjustGamma(2.5f);
rasterImage.Save(dir + "sample.AdjustGamma.png");
}
BinarizeBradley(مزدوجة)
ثنائي الصورة باستخدام خوارزمية الحد الأقصى التكيفية لـ Bradley باستخدام الحد الأقصى الشامل للصورة
public virtual void BinarizeBradley(double brightnessDifference)
Parameters
brightnessDifference
double
الفرق في الضوء بين البكسل ومتوسط نافذة s x s من البكسل المركزة حول هذا البكسل.
BinarizeBradley(المزدوج، إنت)
ثنائي الصورة باستخدام خوارزمية الحد الأقصى التكيفية لـ Bradley باستخدام الحد الأقصى الشامل للصورة
public virtual void BinarizeBradley(double brightnessDifference, int windowSize)
Parameters
brightnessDifference
double
الفرق في الضوء بين البكسل ومتوسط نافذة s x s من البكسل المركزة حول هذا البكسل.
windowSize
int
حجم نافذة x s من البكسلات التي تركز حول هذا البكسل
Examples
على سبيل المثال التالي ، يتم ثنائي الصورة مع الخوارزميات التكيفية لـ Bradley مع حجم النافذة المحدد.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Binarize the image with a brightness difference of 5. The brightness is a difference between a pixel and the average of an 10 x 10 window of pixels centered around this pixel.
rasterImage.BinarizeBradley(5, 10);
rasterImage.Save(dir + "sample.BinarizeBradley5_10x10.png");
}
BinarizeFixed(بيوت)
ثنائي الصورة مع الحد الأقصى المحدد مسبقا
public virtual void BinarizeFixed(byte threshold)
Parameters
threshold
byte
إذا كانت القيمة الرمادية المقابلة للبكسل أكبر من الحد الأقصى، سيتم تخصيص قيمة 255 لها، 0 خلاف ذلك.
Examples
على سبيل المثال التالي ثنائي الصورة مع الحد المحدد مسبقا.الصور الثنائية تحتوي على 2 ألوان فقط - الأسود والأبيض.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Binarize the image with a threshold value of 127.
// If a corresponding gray value of a pixel is greater than 127, a value of 255 will be assigned to it, 0 otherwise.
rasterImage.BinarizeFixed(127);
rasterImage.Save(dir + "sample.BinarizeFixed.png");
}
BinarizeOtsu()
ثنائي الصورة مع حافة أوتسو
public virtual void BinarizeOtsu()
Examples
على سبيل المثال التالي ثنائي الصورة مع الحدود Otsu. الصور الثنائية تحتوي على 2 ألوان فقط - الأسود والأبيض.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Binarize the image with Otsu thresholding.
rasterImage.BinarizeOtsu();
rasterImage.Save(dir + "sample.BinarizeOtsu.png");
}
Blend(نقطة، RasterImage، Rectangle، بايت)
خلط هذه المثال الصورة مع الصورة overlay".
public virtual void Blend(Point origin, RasterImage overlay, Rectangle overlayArea, byte overlayAlpha = 255)
Parameters
origin
Point
صورة الخلفية المختلطة الأصل.
overlay
RasterImage
الصورة الكبيرة .
overlayArea
Rectangle
منطقة التعبئة.
overlayAlpha
byte
ألفا الفائض .
Blend(نقطة, RasterImage, byte)
خلط هذه المثال الصورة مع الصورة overlay".
public void Blend(Point origin, RasterImage overlay, byte overlayAlpha = 255)
Parameters
origin
Point
صورة الخلفية المختلطة الأصل.
overlay
RasterImage
الصورة الكبيرة .
overlayAlpha
byte
ألفا الفائض .
Dither(الطريقة، إنت)
أداء على الصورة الحالية.
public void Dither(DitheringMethod ditheringMethod, int bitsCount)
Parameters
ditheringMethod
DitheringMethod
الطريقة المضغوطة .
bitsCount
int
النقاط النهائية تحسب لالتقاط.
Examples
ويحمل المثال التالي صورة راستر ويقوم بتحريك الحد الأقصى والتدفق باستخدام عمق مختلف في اللوحة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Perform threshold dithering using 4-bit color palette which contains 16 colors.
// The more bits specified the higher quality and the bigger size of the output image.
// Note that only 1-bit, 4-bit and 8-bit palettes are supported at the moment.
rasterImage.Dither(Aspose.Imaging.DitheringMethod.ThresholdDithering, 4);
rasterImage.Save(dir + "sample.ThresholdDithering4.png");
}
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Perform floyd dithering using 1-bit color palette which contains only 2 colors - black and white.
// The more bits specified the higher quality and the bigger size of the output image.
// Note that only 1-bit, 4-bit and 8-bit palettes are supported at the moment.
rasterImage.Dither(Aspose.Imaging.DitheringMethod.FloydSteinbergDithering, 1);
rasterImage.Save(dir + "sample.FloydSteinbergDithering1.png");
}
Dither(DitheringMethod، int، IColorPalette)
أداء على الصورة الحالية.
public abstract void Dither(DitheringMethod ditheringMethod, int bitsCount, IColorPalette customPalette)
Parameters
ditheringMethod
DitheringMethod
الطريقة المضغوطة .
bitsCount
int
النقاط النهائية تحسب لالتقاط.
customPalette
IColorPalette
أضف تعليق لـ DITERING.
Filter(الخيارات الثنائية، FilterOptionsBase)
تصفية المستطيل المحدد.
public virtual void Filter(Rectangle rectangle, FilterOptionsBase options)
Parameters
rectangle
Rectangle
من المستطيل .
options
FilterOptionsBase
الخيارات .
Examples
على سبيل المثال التالي تنطبق أنواع مختلفة من الفلاتر على صورة راستر.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Apply a median filter with a rectangle size of 5 to the entire image.
rasterImage.Filter(rasterImage.Bounds, new Aspose.Imaging.ImageFilters.FilterOptions.MedianFilterOptions(5));
rasterImage.Save(dir + "sample.MedianFilter.png");
}
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Apply a bilateral smoothing filter with a kernel size of 5 to the entire image.
rasterImage.Filter(rasterImage.Bounds, new Aspose.Imaging.ImageFilters.FilterOptions.BilateralSmoothingFilterOptions(5));
rasterImage.Save(dir + "sample.BilateralSmoothingFilter.png");
}
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Apply a Gaussian blur filter with a radius of 5 and a sigma value of 4.0 to the entire image.
rasterImage.Filter(rasterImage.Bounds, new Aspose.Imaging.ImageFilters.FilterOptions.GaussianBlurFilterOptions(5, 4.0));
rasterImage.Save(dir + "sample.GaussianBlurFilter.png");
}
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Apply a Gauss-Wiener filter with a radius of 5 and a smooth value of 4.0 to the entire image.
rasterImage.Filter(rasterImage.Bounds, new Aspose.Imaging.ImageFilters.FilterOptions.GaussWienerFilterOptions(5, 4.0));
rasterImage.Save(dir + "sample.GaussWienerFilter.png");
}
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Apply a motion wiener filter with a length of 5, a smooth value of 4.0 and an angle of 90.0 degrees to the entire image.
rasterImage.Filter(rasterImage.Bounds, new Aspose.Imaging.ImageFilters.FilterOptions.MotionWienerFilterOptions(10, 1.0, 90.0));
rasterImage.Save(dir + "sample.MotionWienerFilter.png");
}
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Apply a sharpen filter with a kernel size of 5 and a sigma value of 4.0 to the entire image.
rasterImage.Filter(rasterImage.Bounds, new Aspose.Imaging.ImageFilters.FilterOptions.SharpenFilterOptions(5, 4.0));
rasterImage.Save(dir + "sample.SharpenFilter.png");
}
GetArgb32Pixel(إنت، إنت)
يحصل على صورة 32 بت ARGB بكسل.
public int GetArgb32Pixel(int x, int y)
Parameters
x
int
موقع بكسل X.
y
int
الـ Pixel Y الموقع
Returns
بكسل ARGB 32 بت للموقع المحدد.
Examples
يحصل المثال التالي على صورة راستر ويحصل على لون بكسل عشوائي تمثل كقيمة كاملة 32 بت.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Get an integer representation of the color of the top-left pixel of the image.
int color = rasterImage.GetArgb32Pixel(0, 0);
// To obtain the values of the individual color components, shift the color value by a corresponding number of bits
int alpha = (color >> 24) & 0xff;
int red = (color >> 16) & 0xff;
int green = (color >> 8) & 0xff;
int blue = (color >> 0) & 0xff;
System.Console.WriteLine("The color of the pixel(0,0) is A={0},R={1},G={2},B={3}", alpha, red, green, blue);
}
يظهر المثال التالي كيف يؤثر تسجيل الصور على الأداء.في الحالة العامة، يتم قراءة البيانات المسجلة بشكل أسرع من قراءة البيانات غير المسجلة.
string dir = "c:\\temp\\";
// Load an image from a PNG file.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
// Cache all pixel data so that no additional data loading will be performed from the underlying data stream
image.CacheData();
System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
stopwatch.Start();
// Reading all pixels is pretty fast.
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
for (int y = 0; y < image.Height; y++)
{
for (int x = 0; x < image.Width; x++)
{
int color = rasterImage.GetArgb32Pixel(x, y);
}
}
stopwatch.Stop();
System.Console.WriteLine("Reading all cached pixels took {0} ms.", stopwatch.ElapsedMilliseconds);
}
// Load an image from a PNG file
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
stopwatch.Start();
// Reading all pixels is not as fast as when caching
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
for (int y = 0; y < image.Height; y++)
{
for (int x = 0; x < image.Width; x++)
{
int color = rasterImage.GetArgb32Pixel(x, y);
}
}
stopwatch.Stop();
System.Console.WriteLine("Reading all pixels without preliminary caching took {0} ms.", stopwatch.ElapsedMilliseconds);
}
// The output may look like this:
// Reading all cached pixels took 1500 ms.
// Reading all pixels without preliminary caching took 150000 ms.
GetDefaultArgb32Pixels(Rectangle)
يحصل على ترتيب البكسل 32 بت ARGB الافتراضي.
public int[] GetDefaultArgb32Pixels(Rectangle rectangle)
Parameters
rectangle
Rectangle
من المستطيل أن تحصل على بكسل.
Returns
int [ ]
أضف تعليق حول Pixel Array.
GetDefaultPixels(الكمبيوتر: IPartialArgb32PixelLoader)
يتم ترتيب البكسلات الافتراضية باستخدام شاحن البكسل الجزئي.
public void GetDefaultPixels(Rectangle rectangle, IPartialArgb32PixelLoader partialPixelLoader)
Parameters
rectangle
Rectangle
من المستطيل أن تحصل على بكسل.
partialPixelLoader
IPartialArgb32PixelLoader
شحن البكسل الجزئي.
GetDefaultRawData(Rectangle، IPartialRawDataLoader، RawDataSettings)
يحصل على مجموعة البيانات الخام الافتراضية باستخدام شاحن بكسل جزئي.
public void GetDefaultRawData(Rectangle rectangle, IPartialRawDataLoader partialRawDataLoader, RawDataSettings rawDataSettings)
Parameters
rectangle
Rectangle
من المستطيل أن تحصل على بكسل.
partialRawDataLoader
IPartialRawDataLoader
محمول البيانات الخام الجزئي.
rawDataSettings
RawDataSettings
إعدادات البيانات الخام.
GetDefaultRawData(أرشيف الوسم : RawDataSettings)
يحصل على مجموعة البيانات الخام الافتراضية.
public byte[] GetDefaultRawData(Rectangle rectangle, RawDataSettings rawDataSettings)
Parameters
rectangle
Rectangle
المستقيم للحصول على البيانات الخام.
rawDataSettings
RawDataSettings
إعدادات البيانات الخام.
Returns
byte [ ]
إعداد البيانات الخام الافتراضية.
GetModifyDate(بول)
يحصل على تاريخ ووقت تم تعديل صورة المصدر مؤخراً.
public virtual DateTime GetModifyDate(bool useDefault)
Parameters
useDefault
bool
إذا قمت بتعيين “الحقيقة” تستخدم المعلومات من FileInfo كقيمة افتراضية.
Returns
تاريخ ووقت تم آخر تعديل لصورة المصدر.
GetPixel(إنت، إنت)
يحصل على صورة بكسل.
public Color GetPixel(int x, int y)
Parameters
x
int
موقع بكسل X.
y
int
الـ Pixel Y الموقع
Returns
لون بكسل للموقع المحدد.
Examples
ويحمل المثال التالي صورة راستر ويحصل على لون بكسل عشوائي.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Get the color of the top-left pixel of the image.
Color color = rasterImage.GetPixel(0, 0);
// Obtain the values of the individual color components
byte alpha = color.A;
byte red = color.R;
int green = color.G;
int blue = color.B;
System.Console.WriteLine("The color of the pixel(0,0) is A={0},R={1},G={2},B={3}", alpha, red, green, blue);
}
GetSkewAngle()
احصل على زاوية الضيق.هذه الطريقة تنطبق على مستندات النص المسح الضوئي، لتحديد زاوية التفريغ عند المسح.
public float GetSkewAngle()
Returns
زاوية الصلب، في درجات.
Grayscale()
تحويل الصورة إلى تمثيلها الرمادي
public virtual void Grayscale()
Examples
في المثال التالي ، تحول صورة الرستير الملونة إلى تمثيلها الرمادي.تتكون صور الرستير حصريًا من الظلال الرمادية وتحمل فقط معلومات الكثافة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
rasterImage.Grayscale();
rasterImage.Save(dir + "sample.Grayscale.png");
}
LoadArgb32Pixels(Rectangle)
تحميل 32 بت بكسل ARGB.
public int[] LoadArgb32Pixels(Rectangle rectangle)
Parameters
rectangle
Rectangle
من المستطيل لتحميل البكسل من.
Returns
int [ ]
يتم تحميل 32 بت ARGB بكسل.
Examples
يظهر المثال التالي كيفية تحميل ومعالجة البكسلات من الصورة الرافعة.يتم تمثيل البكسلات كقيم كاملة 32 بت.على سبيل المثال، فكر في مشكلة حساب البكسلات الشفافة بالكامل من الصورة.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\alpha.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Load pixels for the whole image. Any rectangular part of the image can be specified as a parameter of the Aspose.Imaging.RasterImage.LoadArgb32Pixels method.
int[] pixels = rasterImage.LoadArgb32Pixels(rasterImage.Bounds);
int count = 0;
foreach (int pixel in pixels)
{
int alpha = (pixel >> 24) & 0xff;
if (alpha == 0)
{
count++;
}
}
System.Console.WriteLine("The number of fully transparent pixels is {0}", count);
System.Console.WriteLine("The total number of pixels is {0}", image.Width * image.Height);
}
LoadArgb64Pixels(Rectangle)
تحميل 64 بت بكسل ARGB.
public long[] LoadArgb64Pixels(Rectangle rectangle)
Parameters
rectangle
Rectangle
من المستطيل لتحميل البكسل من.
Returns
long [ ]
يتم تحميل 64 بت ARGB بكسل.
Examples
يظهر المثال التالي كيفية تحميل ومعالجة البكسل من صورة راستر.يتم تمثيل البكسل كقيم كاملة 64 بت.على سبيل المثال، فكر في مشكلة حساب البكسل شفافة تماما من الصورة.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\16rgba.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Load pixels for the whole image. Any rectangular part of the image can be specified as a parameter of the Aspose.Imaging.RasterImage.LoadArgb64Pixels method.
// Note that the image itself must have 16 bits per sample, because Aspose.Imaging.RasterImage.LoadArgb64Pixels doesn't work with 8 bit per sample.
// In order to work with 8 bits per sample please use the good old Aspose.Imaging.RasterImage.LoadArgb32Pixels method.
long[] pixels = rasterImage.LoadArgb64Pixels(rasterImage.Bounds);
int count = 0;
foreach (int pixel in pixels)
{
// Note that all color components including alpha are represented by 16-bit values, so their allowed values are in the range [0, 63535].
int alpha = (pixel >> 48) & 0xffff;
if (alpha == 0)
{
count++;
}
}
System.Console.WriteLine("The number of fully transparent pixels is {0}", count);
System.Console.WriteLine("The total number of pixels is {0}", image.Width * image.Height);
}
LoadCmyk32Pixels(Rectangle)
تحميل بكسل في تنسيق CMYK
public int[] LoadCmyk32Pixels(Rectangle rectangle)
Parameters
rectangle
Rectangle
من المستطيل لتحميل البكسل من.
Returns
int [ ]
تتوفر بكسل CMYK المحمولة كقيم 32 بت.
LoadCmykPixels(Rectangle)
تحميل بكسل في تنسيق CMYKيرجى استخدام طريقة Aspose.Imaging.RasterImage.LoadCmyk32Pixels(Aspose.Imaging.Rectangle) أكثر فعالية.
[Obsolete("Method is obsolete")]
public CmykColor[] LoadCmykPixels(Rectangle rectangle)
Parameters
rectangle
Rectangle
من المستطيل لتحميل البكسل من.
Returns
CmykColor [ ]
كلمات متعلقة CMYK pixels array.
LoadPartialArgb32Pixels(الكمبيوتر: IPartialArgb32PixelLoader)
يحمل 32 بت ARGB بكسل جزئيا بواسطة حزم.
public void LoadPartialArgb32Pixels(Rectangle rectangle, IPartialArgb32PixelLoader partialPixelLoader)
Parameters
rectangle
Rectangle
المستطيل المطلوب
partialPixelLoader
IPartialArgb32PixelLoader
الكمبيوتر المحمول 32 بت ARGB.
Examples
يظهر المثال التالي كيفية تحميل ومعالجة بكسل الصورة عن طريق المعالج الجزئي الخاص بك. على سبيل المثال، فكر في مشكلة حساب بكسل شفافة تماما من الصورة. من أجل حساب بكسل شفافة باستخدام آلية الشحن الجزئي، يتم إدخال فئة منفصلة TransparentArgb32PixelCounter تنفيذ Aspose.Imaging.IPartialArgb32PixelLoader.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\alpha.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Create an instance of the Aspose.Imaging.IPartialArgb32PixelLoader and pass it to the Aspose.Imaging.RasterImage.LoadPartialArgb32Pixels
TransparentArgb32PixelCounter counter = new TransparentArgb32PixelCounter();
// Load pixels for the whole image. Any rectangular part of the image can be specified as the first parameter of the Aspose.Imaging.RasterImage.LoadPartialArgb32Pixels method.
rasterImage.LoadPartialArgb32Pixels(rasterImage.Bounds, counter);
System.Console.WriteLine("The number of fully transparent pixels is {0}", counter.Count);
System.Console.WriteLine("The total number of pixels is {0}", image.Width * image.Height);
}
// The counter may look like this:
/// <summary>
/// Counts the number of fully transparent pixels with alpha channel value of 0.
/// </summary>
private class TransparentArgb32PixelCounter : IPartialArgb32PixelLoader
{
/// <summary>
/// The number of fully transparent pixels.
/// </summary>
private int count;
/// <summary>
/// Gets the number of fully transparent pixels.
/// </summary>
public int Count
{
get { return this.count; }
}
/// <summary>
/// Processes the loaded pixels. This method is called back every time when a new portion of pixels is loaded.
/// </summary>
/// <param name="pixelsRectangle"/>The pixels rectangle.
/// <param name="pixels"/>The 32-bit ARGB pixels.
/// <param name="start"/>The start pixels point.
/// <param name="end"/>The end pixels point.
public void Process(Aspose.Imaging.Rectangle pixelsRectangle, int[] pixels, Aspose.Imaging.Point start, Aspose.Imaging.Point end)
{
foreach (int pixel in pixels)
{
int alpha = (pixel >> 24) & 0xff;
if (alpha == 0)
{
this.count++;
}
}
}
}
LoadPartialArgb64Pixels(الكمبيوتر: IPartialArgb64PixelLoader)
يحمل 64 بت ARGB بكسل جزئيا عن طريق الحزم.
public void LoadPartialArgb64Pixels(Rectangle rectangle, IPartialArgb64PixelLoader partialPixelLoader)
Parameters
rectangle
Rectangle
المستطيل المطلوب
partialPixelLoader
IPartialArgb64PixelLoader
شاحن 64 بت ARGB بكسل
LoadPartialPixels(كلمات متعلقة IPartialPixelLoader)
تحميل البكسل جزئيا بواسطة الحزم.
public void LoadPartialPixels(Rectangle desiredRectangle, IPartialPixelLoader pixelLoader)
Parameters
desiredRectangle
Rectangle
المستطيل المطلوب
pixelLoader
IPartialPixelLoader
الـ Pixel Loader
Examples
يظهر المثال التالي كيفية تحميل ومعالجة البكسل من صورة راستر باستخدام المعالج الجزئي الخاص بك. على سبيل المثال، فكر في مشكلة حساب البكسل شفافة تماما من الصورة. من أجل حساب شفافة باستخدام آلية الشحن الجزئي، يتم إدخال فئة منفصلة TransparentPixelCounter تنفيذ Aspose.Imaging.IPartialPixelLoader.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\alpha.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Create an instance of the Aspose.Imaging.IPartialPixelLoader and pass it to the Aspose.Imaging.RasterImage.LoadPartialPixels
TransparentPixelCounter counter = new TransparentPixelCounter();
// Load pixels for the whole image. Any rectangular part of the image can be specified as the first parameter of the Aspose.Imaging.RasterImage.LoadPartialPixels method.
rasterImage.LoadPartialPixels(rasterImage.Bounds, counter);
System.Console.WriteLine("The number of fully transparent pixels is {0}", counter.Count);
System.Console.WriteLine("The total number of pixels is {0}", image.Width * image.Height);
}
// The counter may look like this:
/// <summary>
/// Counts the number of fully transparent pixels with alpha channel value of 0.
/// </summary>
private class TransparentPixelCounter : IPartialPixelLoader
{
/// <summary>
/// The number of fully transparent pixels.
/// </summary>
private int count;
/// <summary>
/// Gets the number of fully transparent pixels.
/// </summary>
public int Count
{
get { return this.count; }
}
/// <summary>
/// Processes the loaded pixels. This method is called back every time when a new portion of pixels is loaded.
/// </summary>
/// <param name="pixelsRectangle"/>The pixels rectangle.
/// <param name="pixels"/>The 32-bit ARGB pixels.
/// <param name="start"/>The start pixels point.
/// <param name="end"/>The end pixels point.
public void Process(Aspose.Imaging.Rectangle pixelsRectangle, Aspose.Imaging.Color[] pixels, Aspose.Imaging.Point start, Aspose.Imaging.Point end)
{
foreach (Color pixel in pixels)
{
if (pixel.A == 0)
{
this.count++;
}
}
}
}
LoadPixels(Rectangle)
تحميل البكسل
public Color[] LoadPixels(Rectangle rectangle)
Parameters
rectangle
Rectangle
من المستطيل لتحميل البكسل من.
Returns
Color [ ]
أضف تعليق حول Pixel Array
Examples
يظهر المثال التالي كيفية تحميل ومعالجة البكسل من صورة راستر.على سبيل المثال، فكر في مشكلة حساب البكسل شفافة تماما من الصورة.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\alpha.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Load pixels for the whole image. Any rectangular part of the image can be specified as a parameter of the Aspose.Imaging.RasterImage.LoadPixels method.
Color[] pixels = rasterImage.LoadPixels(rasterImage.Bounds);
int count = 0;
foreach (Color pixel in pixels)
{
if (pixel.A == 0)
{
count++;
}
}
System.Console.WriteLine("The number of fully transparent pixels is {0}", count);
System.Console.WriteLine("The total number of pixels is {0}", image.Width * image.Height);
}
يظهر هذا المثال كيفية تحميل معلومات بيكسيل في سلسلة من نوع اللون، وتلاعب السلسلة وإعادتها إلى الصورة.لإجراء هذه العمليات، يخلق هذا المثال ملف صورة جديد (في تنسيق GIF) uisng كائن MemoryStream.
//Create an instance of MemoryStream
using (System.IO.MemoryStream stream = new System.IO.MemoryStream())
{
//Create an instance of GifOptions and set its various properties including the Source property
Aspose.Imaging.ImageOptions.GifOptions gifOptions = new Aspose.Imaging.ImageOptions.GifOptions();
gifOptions.Source = new Aspose.Imaging.Sources.StreamSource(stream);
//Create an instance of Image
using (Aspose.Imaging.RasterImage image = (Aspose.Imaging.RasterImage)Aspose.Imaging.Image.Create(gifOptions, 500, 500))
{
//Get the pixels of image by specifying the area as image boundary
Aspose.Imaging.Color[] pixels = image.LoadPixels(image.Bounds);
//Loop over the Array and sets color of alrenative indexed pixel
for (int index = 0; index < pixels.Length; index++)
{
if (index % 2 == 0)
{
//Set the indexed pixel color to yellow
pixels[index] = Aspose.Imaging.Color.Yellow;
}
else
{
//Set the indexed pixel color to blue
pixels[index] = Aspose.Imaging.Color.Blue;
}
}
//Apply the pixel changes to the image
image.SavePixels(image.Bounds, pixels);
// save all changes.
image.Save();
}
// Write MemoryStream to File
using (System.IO.FileStream fileStream = new System.IO.FileStream(@"C:\temp\output.gif", System.IO.FileMode.Create))
{
stream.WriteTo(fileStream);
}
}
LoadRawData(Rectangle، RawDataSettings، IPartialRawDataLoader)
تحميل البيانات الخام
public void LoadRawData(Rectangle rectangle, RawDataSettings rawDataSettings, IPartialRawDataLoader rawDataLoader)
Parameters
rectangle
Rectangle
المستطيل لتحميل البيانات الخام من.
rawDataSettings
RawDataSettings
إعدادات البيانات الخام لاستخدامها للبيانات المحمولة.ملاحظة إذا لم تكن البيانات في النموذج المحدد ثم سيتم إجراء تحويل البيانات.
rawDataLoader
IPartialRawDataLoader
محمول البيانات الخام.
Examples
يظهر المثال التالي كيفية استخراج البكسل من بيانات الصورة الخام باستخدام RawDataSettings.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\GrayscaleWithAlpha.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
Aspose.Imaging.RawDataSettings settings = rasterImage.RawDataSettings;
TransparentPixelRawDataCounter rawDataLoader = new TransparentPixelRawDataCounter(settings);
// Load pixels for the whole image. Any rectangular part of the image can be specified as a parameter of the Aspose.Imaging.RasterImage.LoadRawData method.
rasterImage.LoadRawData(rasterImage.Bounds, settings, rawDataLoader);
System.Console.WriteLine("The number of fully transparent pixels is {0}", rawDataLoader.Count);
System.Console.WriteLine("The total number of pixels is {0}", image.Width * image.Height);
}
// In case of raw data, the counter may look like this:
/// <summary>
/// Counts the number of fully transparent pixels with alpha channel value of 0.
/// </summary>
private class TransparentPixelRawDataCounter : IPartialRawDataLoader
{
/// <summary>
/// The number of fully transparent pixels.
/// </summary>
private int count;
/// <summary>
/// The raw data settings of the loaded image.
/// </summary>
private Aspose.Imaging.RawDataSettings rawDataSettings;
/// <summary>
/// Gets the number of fully transparent pixels.
/// </summary>
public int Count
{
get { return this.count; }
}
/// <summary>
/// Initializes a new instance of the <see transparentpixelrawdatacounter=""></see> class.
/// </summary>
/// <param name="settings"/>The raw data settings allow to extract color components from raw data.
public TransparentPixelRawDataCounter(Aspose.Imaging.RawDataSettings settings)
{
this.rawDataSettings = settings;
this.count = 0;
}
/// <summary>
/// Processes the loaded raw data. This method is called back every time when a new portion of raw data is loaded.
/// </summary>
/// <param name="dataRectangle"/>The raw data rectangle.
/// <param name="data"/>The raw data.
/// <param name="start"/>The start data point.
/// <param name="end"/>The end data point.
public void Process(Aspose.Imaging.Rectangle dataRectangle, byte[] data, Aspose.Imaging.Point start, Aspose.Imaging.Point end)
{
int[] channelBits = this.rawDataSettings.PixelDataFormat.ChannelBits;
// Only simple formats are consdired here to simplify the code.
// Let's consider only images with 8 bits per sample.
for (int i = 0; i < channelBits.Length; i++)
{
if (channelBits[i] != 8)
{
throw new System.NotSupportedException();
}
}
switch (this.rawDataSettings.PixelDataFormat.PixelFormat)
{
case PixelFormat.Rgb:
case PixelFormat.Bgr:
{
if (channelBits.Length == 4)
{
// ARGB
for (int i = 0; i < data.Length; i += 4)
{
// The alpha channel is stored last, after the color components.
if (data[i + 3] == 0)
{
this.count++;
}
}
}
}
break;
case PixelFormat.Grayscale:
{
if (channelBits.Length == 2)
{
// Grayscale Alpha
for (int i = 0; i < data.Length; i += 2)
{
// The alpha channel is stored last, after the color components.
if (data[i + 1] == 0)
{
this.count++;
}
}
}
}
break;
default:
throw new System.ArgumentOutOfRangeException("PixelFormat");
}
}
/// <summary>
/// Processes the loaded raw data. This method is called back every time when a new portion of raw data is loaded.
/// </summary>
/// <param name="dataRectangle"/>The raw data rectangle.
/// <param name="data"/>The raw data.
/// <param name="start"/>The start data point.
/// <param name="end"/>The end data point.
/// <param name="loadOptions"/>The load options.
public void Process(Aspose.Imaging.Rectangle dataRectangle, byte[] data, Aspose.Imaging.Point start, Aspose.Imaging.Point end, Aspose.Imaging.LoadOptions loadOptions)
{
this.Process(dataRectangle, data, start, end);
}
}
LoadRawData(Rectangle، Rectangle، RawDataSettings، IPartialRawDataLoader)
تحميل البيانات الخام
public void LoadRawData(Rectangle rectangle, Rectangle destImageBounds, RawDataSettings rawDataSettings, IPartialRawDataLoader rawDataLoader)
Parameters
rectangle
Rectangle
المستطيل لتحميل البيانات الخام من.
destImageBounds
Rectangle
الضوء يحد من الصورة
rawDataSettings
RawDataSettings
إعدادات البيانات الخام لاستخدامها للبيانات المحمولة.ملاحظة إذا لم تكن البيانات في النموذج المحدد ثم سيتم إجراء تحويل البيانات.
rawDataLoader
IPartialRawDataLoader
محمول البيانات الخام.
NormalizeAngle()
تطبيع الزاوية.هذه الطريقة تنطبق على وثائق النص المسح الضوئي للتخلص من المسح الضوئي.هذه الطريقة تستخدم أساليب Aspose.Imaging.RasterImage.GetSkewAngle و Aspose.Imaging.RasterImage.Rotate(System.Single).
public void NormalizeAngle()
NormalizeAngle(البول، اللون)
تطبيع الزاوية.هذه الطريقة تنطبق على وثائق النص المسح الضوئي للتخلص من المسح الضوئي.هذه الطريقة تستخدم أساليب Aspose.Imaging.RasterImage.GetSkewAngle و Aspose.Imaging.RasterImage.Rotate(System.Single،System.Boolean،Aspose.Imaging.Color).
public virtual void NormalizeAngle(bool resizeProportionally, Color backgroundColor)
Parameters
resizeProportionally
bool
إذا قمت بتعيين “الحقيقي” ستكون حجم الصورة الخاص بك قد تغيرت وفقًا للتوقعات المستطيلة (نقاط الزاوية) في حالة أخرى تترك الأبعاد غير ملموسة ويتم توجيه محتوى الصورة الداخلي فقط.
backgroundColor
Color
لون الخلفية
Examples
Skew هو عمل يمكن أن تظهر أثناء عملية فحص المستندات عندما يتم تحويل النص / الصور من المستند إلى زاوية خفيفة. يمكن أن يكون لها أسباب مختلفة ولكن الأكثر شيوعا هو أن الورق يتم وضعها بشكل خاطئ أثناء الفحص. وبالتالي، Deskew هو عملية اكتشاف وتصحيح هذه المشكلة على الملفات الماسح الضوئي (أي خريطة بيت) بحيث يكون المستندات الماسح الضوئي النص / الصور بشكل صحيح والأفقية.
string dir = "c:\\aspose.imaging\\issues\\net\\3567\\";
string inputFilePath = dir + "skewed.png";
string outputFilePath = dir + "skewed.out.png";
// Get rid of the skewed scan with default parameters
using (Aspose.Imaging.RasterImage image = (Aspose.Imaging.RasterImage)Aspose.Imaging.Image.Load(inputFilePath))
{
// Deskew
image.NormalizeAngle(false /*do not resize*/, Aspose.Imaging.Color.LightGray /*background color*/);
image.Save(outputFilePath);
}
NormalizeHistogram()
تطبيع هيستوغرام الصورة - تعديل قيم البكسل لاستخدام جميع المساحة المتاحة.
public virtual void NormalizeHistogram()
ReadArgb32ScanLine(إنت)
يقرأ خط الفحص بأكمله بواسطة مؤشر خط الفحص المحدد.
public int[] ReadArgb32ScanLine(int scanLineIndex)
Parameters
scanLineIndex
int
صفر قاعدة مؤشر خط الفحص.
Returns
int [ ]
خط الفحص 32 بت ARGB قيم الألوان المرتبة.
ReadScanLine(إنت)
يقرأ خط الفحص بأكمله بواسطة مؤشر خط الفحص المحدد.
public Color[] ReadScanLine(int scanLineIndex)
Parameters
scanLineIndex
int
صفر قاعدة مؤشر خط الفحص.
Returns
Color [ ]
خط الفحص بكسل الألوان قيم الترتيب.
ReleaseManagedResources()
تأكد من عدم إطلاق الموارد غير المعالجة هنا، لأنها قد تكون قد تم إطلاقها بالفعل.
protected override void ReleaseManagedResources()
RemoveMetadata()
إزالة هذه البيانات الميتا من حالة الصورة عن طريق إعداد هذا Aspose.Imaging.Xmp.IHasXMPData. صفر.
public override void RemoveMetadata()
ReplaceColor(اللون، بايت، اللون)
يحل محل لون واحد لآخر مع الفرق المسموح به ويحافظ على قيمة ألفا الأصلية لتوفير الحواف الناعمة.
public void ReplaceColor(Color oldColor, byte oldColorDiff, Color newColor)
Parameters
oldColor
Color
الألوان القديمة يجب استبدالها
oldColorDiff
byte
يسمح الفرق في اللون القديم لتكون قادرة على توسيع نغمة الألوان المستبدة.
newColor
Color
لون جديد يستبدل باللون القديم
ReplaceColor(إنت، بايت، إنت)
يحل محل لون واحد لآخر مع الفرق المسموح به ويحافظ على قيمة ألفا الأصلية لتوفير الحواف الناعمة.
public virtual void ReplaceColor(int oldColorArgb, byte oldColorDiff, int newColorArgb)
Parameters
oldColorArgb
int
سيتم استبدال قيمة الألوان القديمة ARGB.
oldColorDiff
byte
يسمح الفرق في اللون القديم لتكون قادرة على توسيع نغمة الألوان المستبدة.
newColorArgb
int
قيمة الألوان الجديدة ARGB لتحل محل الألوان القديمة مع.
ReplaceNonTransparentColors(Color)
يستبدل جميع الألوان غير النظيفة بألوان جديدة ويحافظ على قيمة ألفا الأصلية لتوفير الحواف الناعمة.ملاحظة: إذا كنت تستخدمها على الصور دون شفافية، سيتم استبدال جميع الألوان مع واحد واحد.
public void ReplaceNonTransparentColors(Color newColor)
Parameters
newColor
Color
الألوان الجديدة لتحل محل الألوان غير الشفافة.
ReplaceNonTransparentColors(إنت)
يستبدل جميع الألوان غير النظيفة بألوان جديدة ويحافظ على قيمة ألفا الأصلية لتوفير الحواف الناعمة.ملاحظة: إذا كنت تستخدمها على الصور دون شفافية، سيتم استبدال جميع الألوان مع واحد واحد.
public virtual void ReplaceNonTransparentColors(int newColorArgb)
Parameters
newColorArgb
int
قيمة الألوان الجديدة ARGB لاستبدال الألوان غير الشفافة مع.
Resize(إنت، إنت، ImageResizeSettings)
إعادة تدوير الصورة باستخدام الخيارات الموسعة.
public override void Resize(int newWidth, int newHeight, ImageResizeSettings settings)
Parameters
newWidth
int
العرض الجديد .
newHeight
int
الارتفاع الجديد
settings
ImageResizeSettings
إعدادات إعادة التدوير
Examples
هذا المثال يحمل صورة راستر ويعيدها باستخدام إعدادات إعادة التدوير المختلفة.
string dir = "c:\\temp\\";
Aspose.Imaging.ImageResizeSettings resizeSettings = new Aspose.Imaging.ImageResizeSettings();
// The adaptive algorithm based on weighted and blended rational function and lanczos3 interpolation.
resizeSettings.Mode = Aspose.Imaging.ResizeType.AdaptiveResample;
// The small rectangular filter
resizeSettings.FilterType = Aspose.Imaging.ImageFilterType.SmallRectangular;
// The number of colors in the palette.
resizeSettings.EntriesCount = 256;
// The color quantization is not used
resizeSettings.ColorQuantizationMethod = ColorQuantizationMethod.None;
// The euclidian method
resizeSettings.ColorCompareMethod = ColorCompareMethod.Euclidian;
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.gif"))
{
// Scale down by 2 times using adaptive resampling.
image.Resize(image.Width / 2, image.Height / 2, resizeSettings);
image.Save(dir + "downsample.adaptive.gif");
}
Rotate(البول، البول، اللون)
تحويل الصورة حول المركز.
public virtual void Rotate(float angle, bool resizeProportionally, Color backgroundColor)
Parameters
angle
float
زاوية الدوران في درجات.القيم الإيجابية سوف تدور في اتجاه الساعة.
resizeProportionally
bool
إذا قمت بتعيين “الحقيقي” ستكون حجم الصورة الخاص بك قد تغيرت وفقًا للتوقعات المستطيلة (نقاط الزاوية) في حالة أخرى تترك الأبعاد غير ملموسة ويتم توجيه محتوى الصورة الداخلي فقط.
backgroundColor
Color
لون الخلفية
Exceptions
الاستثناء غير المعمول به
Rotate(السفينة)
تحويل الصورة حول المركز.
public override void Rotate(float angle)
Parameters
angle
float
زاوية الدوران في درجات.القيم الإيجابية سوف تدور في اتجاه الساعة.
Save(البث, ImageOptionsBase, Rectangle)
تخزين بيانات الصورة إلى التيار المحدد في تنسيق الملف المحدد حسب خيارات التخزين.
public override void Save(Stream stream, ImageOptionsBase optionsBase, Rectangle boundsRectangle)
Parameters
stream
Stream
تدفق لتخزين بيانات الصورة إلى.
optionsBase
ImageOptionsBase
خيارات الادخار .
boundsRectangle
Rectangle
يحدد صورة الوجهة المستطيل.إعداد المستطيل الفارغ لاستخدام حدود المصدر.
SaveArgb32Pixels(اليمين، إنت[])
تخزين البكسل 32 بت ARGB.
public void SaveArgb32Pixels(Rectangle rectangle, int[] pixels)
Parameters
rectangle
Rectangle
اليمين المستقيم لتخزين البكسل.
pixels
int
[ ]
32 بت ARGB بكسل التردد.
Examples
يملأ المثال التالي المنطقة المركزية للصورة الخرسانية بكسل سوداء باستخدام طريقة Aspose.Imaging.RasterImage.SaveArgb32Pixels.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// The black square
int[] pixels = new int[(rasterImage.Width / 2) * (rasterImage.Height / 2)];
for (int i = 0; i < pixels.Length; i++)
{
pixels[i] = Color.Black.ToArgb();
}
// Draw the black square at the center of the image.
Aspose.Imaging.Rectangle area = new Aspose.Imaging.Rectangle(rasterImage.Width / 4, rasterImage.Height / 4, rasterImage.Width / 2, rasterImage.Height / 2);
rasterImage.SaveArgb32Pixels(area, pixels);
rasterImage.Save(dir + "sample.SaveArgb32Pixels.png");
}
SaveCmyk32Pixels(اليمين، إنت[])
احرص على توفير البكسل
public void SaveCmyk32Pixels(Rectangle rectangle, int[] pixels)
Parameters
rectangle
Rectangle
اليمين المستقيم لتخزين البكسل.
pixels
int
[ ]
تم تقديم بكسل CMYK كقيم كاملة 32 بت.
Examples
يملأ المثال التالي المنطقة المركزية للصورة الخرسانية بكسل سوداء باستخدام طريقة Aspose.Imaging.RasterImage.SaveCmyk32Pixels.
string dir = @"c:\temp\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Get an integer representation of black in the CMYK color space.
int blackCmyk = Aspose.Imaging.CmykColorHelper.ToCmyk(Color.Black);
// The black square.
int[] pixels = new int[(rasterImage.Width / 2) * (rasterImage.Height / 2)];
for (int i = 0; i < pixels.Length; i++)
{
pixels[i] = blackCmyk;
}
// Draw the black square at the center of the image.
Aspose.Imaging.Rectangle area = new Aspose.Imaging.Rectangle(rasterImage.Width / 4, rasterImage.Height / 4, rasterImage.Width / 2, rasterImage.Height / 2);
rasterImage.SaveCmyk32Pixels(area, pixels);
rasterImage.Save(dir + "sample.SaveCmyk32Pixels.png");
}
SaveCmykPixels(الرماد، CmykColor[])
احرص على توفير البكسليرجى استخدام طريقة Aspose.Imaging.RasterImage.SaveCmyk32Pixels(Aspose.Imaging.Rectangle,System.Int32[]) أكثر فعالية.
[Obsolete("Method is obsolete")]
public void SaveCmykPixels(Rectangle rectangle, CmykColor[] pixels)
Parameters
rectangle
Rectangle
اليمين المستقيم لتخزين البكسل.
pixels
CmykColor
[ ]
كميات كبيرة من بكسل CMYK.
SavePixels(اللون، اللون[])
احرص على توفير البكسل
public void SavePixels(Rectangle rectangle, Color[] pixels)
Parameters
rectangle
Rectangle
اليمين المستقيم لتخزين البكسل.
pixels
Color
[ ]
البيكسيلات تتحرك.
Examples
يملأ المثال التالي المنطقة المركزية للصورة الخرسانية بكسل سوداء باستخدام طريقة Aspose.Imaging.RasterImage.SavePixels.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// The black square
Color[] pixels = new Color[(rasterImage.Width / 2) * (rasterImage.Height / 2)];
for (int i = 0; i < pixels.Length; i++)
{
pixels[i] = Color.Black;
}
// Draw the black square at the center of the image.
Aspose.Imaging.Rectangle area = new Aspose.Imaging.Rectangle(rasterImage.Width / 4, rasterImage.Height / 4, rasterImage.Width / 2, rasterImage.Height / 2);
rasterImage.SavePixels(area, pixels);
rasterImage.Save(dir + "sample.SavePixels.png");
}
يظهر هذا المثال كيفية تحميل معلومات بيكسيل في سلسلة من نوع اللون، وتلاعب السلسلة وإعادتها إلى الصورة.لإجراء هذه العمليات، يخلق هذا المثال ملف صورة جديد (في تنسيق GIF) uisng كائن MemoryStream.
//Create an instance of MemoryStream
using (System.IO.MemoryStream stream = new System.IO.MemoryStream())
{
//Create an instance of GifOptions and set its various properties including the Source property
Aspose.Imaging.ImageOptions.GifOptions gifOptions = new Aspose.Imaging.ImageOptions.GifOptions();
gifOptions.Source = new Aspose.Imaging.Sources.StreamSource(stream);
//Create an instance of Image
using (Aspose.Imaging.RasterImage image = (Aspose.Imaging.RasterImage)Aspose.Imaging.Image.Create(gifOptions, 500, 500))
{
//Get the pixels of image by specifying the area as image boundary
Aspose.Imaging.Color[] pixels = image.LoadPixels(image.Bounds);
//Loop over the Array and sets color of alrenative indexed pixel
for (int index = 0; index < pixels.Length; index++)
{
if (index % 2 == 0)
{
//Set the indexed pixel color to yellow
pixels[index] = Aspose.Imaging.Color.Yellow;
}
else
{
//Set the indexed pixel color to blue
pixels[index] = Aspose.Imaging.Color.Blue;
}
}
//Apply the pixel changes to the image
image.SavePixels(image.Bounds, pixels);
// save all changes.
image.Save();
}
// Write MemoryStream to File
using (System.IO.FileStream fileStream = new System.IO.FileStream(@"C:\temp\output.gif", System.IO.FileMode.Create))
{
stream.WriteTo(fileStream);
}
}
SaveRawData(بيوت[ ]، int ، Rectangle ، RawDataSettings)
تخزين البيانات الخام
public void SaveRawData(byte[] data, int dataOffset, Rectangle rectangle, RawDataSettings rawDataSettings)
Parameters
data
byte
[ ]
البيانات الخام .
dataOffset
int
بدء البيانات الخام تعويض.
rectangle
Rectangle
دقة البيانات الخام.
rawDataSettings
RawDataSettings
إعدادات البيانات الخام التي يتم إدخالها.
SetArgb32Pixel(إنت، إنت، إنت)
إعداد صورة 32 بت ARGB بكسل للموقف المحدد.
public void SetArgb32Pixel(int x, int y, int argb32Color)
Parameters
x
int
موقع بكسل X.
y
int
الـ Pixel Y الموقع
argb32Color
int
البكسل 32 بت ARGB للموقع المحدد.
Examples
ويحمل المثال التالي صورة خفيفة، ويحدد لون بكسل عشوائي.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Sets the color of the top-left pixel.
rasterImage.SetArgb32Pixel(0, 0, Aspose.Imaging.Color.Aqua.ToArgb());
// Another way is to pass an instance of the Aspose.Imaging.Color directly
rasterImage.SetPixel(0, 0, Aspose.Imaging.Color.Aqua);
}
SetPalette(اللوحة، بول)
إعداد لوحة الصورة.
public override void SetPalette(IColorPalette palette, bool updateColors)
Parameters
palette
IColorPalette
اللوحة التي يجب وضعها.
updateColors
bool
إذا قمت بتعيين الألوان “الحقيقية” سيتم تحديثها وفقًا للجدول الجديد ؛ وإلا فإن مؤشرات الألوان لا تزال غير متغيرة.
SetPixel(إنت، إنت، اللون)
إعداد صورة بكسل للموقف المحدد.
public void SetPixel(int x, int y, Color color)
Parameters
x
int
موقع بكسل X.
y
int
الـ Pixel Y الموقع
color
Color
لون البكسل للموقف المحدد.
Examples
ويحمل المثال التالي صورة خفيفة، ويحدد لون بكسل عشوائي.
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Sets the color of the top-left pixel.
rasterImage.SetArgb32Pixel(0, 0, Aspose.Imaging.Color.Aqua.ToArgb());
// Another way is to pass an instance of the Aspose.Imaging.Color directly
rasterImage.SetPixel(0, 0, Aspose.Imaging.Color.Aqua);
}
SetResolution(المزدوج، المزدوج)
إعداد القرار لهذا Aspose.Imaging.RasterImage.
public virtual void SetResolution(double dpiX, double dpiY)
Parameters
dpiX
double
القرار الأفقي، في نقاط لكل بوصة، من Aspose.Imaging.RasterImage.
dpiY
double
القرار الرأسي، في نقاط لكل بوصة، من Aspose.Imaging.RasterImage.
Examples
يظهر المثال التالي كيفية تعيين الدقة الأفقية / العمودية لصورة الرسوم المتحركة.
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.jpg"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Get horizontal and vertical resolution of the image
double horizontalResolution = rasterImage.HorizontalResolution;
double verticalResolution = rasterImage.VerticalResolution;
System.Console.WriteLine("The horizontal resolution, in pixels per inch: {0}", horizontalResolution);
System.Console.WriteLine("The vertical resolution, in pixels per inch: {0}", verticalResolution);
if (horizontalResolution != 96.0 || verticalResolution != 96.0)
{
// Use the SetResolution method for updating both resolution values in a single call.
System.Console.WriteLine("Set resolution values to 96 dpi");
rasterImage.SetResolution(96.0, 96.0);
System.Console.WriteLine("The horizontal resolution, in pixels per inch: {0}", rasterImage.HorizontalResolution);
System.Console.WriteLine("The vertical resolution, in pixels per inch: {0}", rasterImage.VerticalResolution);
}
// The output may look like this:
// The horizontal resolution, in pixels per inch: 300
// The vertical resolution, in pixels per inch: 300
// Set resolution values to 96 dpi
// The horizontal resolution, in pixels per inch: 96
// The vertical resolution, in pixels per inch: 96
}
ToBitmap()
تحويل صورة راستر إلى خريطة بيت.هذه الطريقة غير مدعومة في الإصدارات من .Net7.0 أو أعلى
public virtual Bitmap ToBitmap()
Returns
الخريطة bitmap
UpdateDimensions(إنت، إنت)
تحديث أبعاد الصورة.
protected abstract void UpdateDimensions(int newWidth, int newHeight)
Parameters
newWidth
int
عرض الصورة الجديد.
newHeight
int
ارتفاع الصورة الجديدة.
UpdateMetadata()
تحديث بيانات الصورة.
protected virtual void UpdateMetadata()
WriteArgb32ScanLine(إنت، إنت[])
اكتب خط الفحص بأكمله إلى مؤشر خط الفحص المحدد.
public void WriteArgb32ScanLine(int scanLineIndex, int[] argb32Pixels)
Parameters
scanLineIndex
int
صفر قاعدة مؤشر خط الفحص.
argb32Pixels
int
[ ]
الألوان 32 بت ARGB تصل إلى الكتابة.
WriteScanLine(إنت، اللون[])
اكتب خط الفحص بأكمله إلى مؤشر خط الفحص المحدد.
public void WriteScanLine(int scanLineIndex, Color[] pixels)
Parameters
scanLineIndex
int
صفر قاعدة مؤشر خط الفحص.
pixels
Color
[ ]
الألوان البكسلية تستعد للكتابة.