SavePixels
RasterImage.SavePixels method
Сохраняет пиксели.
public void SavePixels(Rectangle rectangle, Color[] pixels)
Параметр | Тип | Описание |
---|---|---|
rectangle | Rectangle | Прямоугольник для сохранения пикселей. |
pixels | Color[] | Массив пикселей. |
Примеры
В следующем примере центральная область растрового изображения заполняется черными пикселями с использованием метода Aspose.Imaging.RasterImage.SavePixels.
[C#]
string dir = "c:\\temp\\";
using (Aspose.Imaging.Image image = Aspose.Imaging.Image.Load(dir + "sample.png"))
{
Aspose.Imaging.RasterImage rasterImage = (Aspose.Imaging.RasterImage)image;
// Черный квадрат
Color[] pixels = new Color[(rasterImage.Width / 2) * (rasterImage.Height / 2)];
for (int i = 0; i < pixels.Length; i++)
{
pixels[i] = Color.Black;
}
// Рисуем черный квадрат в центре изображения.
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) с использованием объекта 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);
//Создаем экземпляр изображения
using (Aspose.Imaging.RasterImage image = (Aspose.Imaging.RasterImage)Aspose.Imaging.Image.Create(gifOptions, 500, 500))
{
//Получить пиксели изображения, указав область в качестве границы изображения
Aspose.Imaging.Color[] pixels = image.LoadPixels(image.Bounds);
// Цикл по массиву и установка цвета альтернативного индексированного пикселя
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 Rectangle
- struct Color
- class RasterImage
- пространство имен Aspose.Imaging
- сборка Aspose.Imaging