LoadPixels
RasterImage.LoadPixels method
加载像素。
public Color[] LoadPixels(Rectangle rectangle)
范围 | 类型 | 描述 |
---|---|---|
rectangle | Rectangle | 要从中加载像素的矩形。 |
返回值
加载的像素数组。
例子
以下示例显示了如何加载和处理光栅图像的像素。例如,考虑计算图像的完全透明像素的问题。
[C#]
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(@"c:\temp\alpha.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// 加载整个图像的像素。图像的任何矩形部分都可以指定为 Aspose.Imaging.RasterImage.LoadPixels 方法的参数。
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);
}
这个例子展示了如何在颜色类型的数组中加载像素信息,操作数组并将其设置回图像。为了执行这些操作,这个例子创建了一个新的 Image 文件(GIF 格式)uisng MemoryStream 对象。
[C#]
//创建一个MemoryStream实例
using (System.IO.MemoryStream stream = new System.IO.MemoryStream())
{
//创建一个 GifOptions 实例并设置它的各种属性,包括 Source 属性
Aspose.Imaging.ImageOptions.GifOptions gifOptions = new Aspose.Imaging.ImageOptions.GifOptions();
gifOptions.Source = new Aspose.Imaging.Sources.StreamSource(stream);
//创建一个Image实例
using (Aspose.Imaging.RasterImage image = (Aspose.Imaging.RasterImage)Aspose.Imaging.Image.Create(gifOptions, 500, 500))
{
//通过指定区域为图像边界来获取图像的像素
Aspose.Imaging.Color[] pixels = image.LoadPixels(image.Bounds);
//遍历数组并设置alrenative索引像素的颜色
for (int index = 0; index < pixels.Length; index++)
{
if (index % 2 == 0)
{
//设置索引像素颜色为黄色
pixels[index] = Aspose.Imaging.Color.Yellow;
}
else
{
//设置索引像素颜色为蓝色
pixels[index] = Aspose.Imaging.Color.Blue;
}
}
//将像素变化应用到图像
image.SavePixels(image.Bounds, pixels);
// 保存所有更改。
image.Save();
}
// 将 MemoryStream 写入文件
using (System.IO.FileStream fileStream = new System.IO.FileStream(@"C:\temp\output.gif", System.IO.FileMode.Create))
{
stream.WriteTo(fileStream);
}
}
也可以看看
- struct Color
- struct Rectangle
- class RasterImage
- 命名空间 Aspose.Imaging
- 部件 Aspose.Imaging