ManualMaskingArgs
Содержание
[
Скрывать
]ManualMaskingArgs class
Представляет аргументы, указанные для ручного метода маскирования
public class ManualMaskingArgs : IMaskingArgs
Конструкторы
Имя | Описание |
---|---|
ManualMaskingArgs() | Конструктор по умолчанию. |
Характеристики
Имя | Описание |
---|---|
Mask { get; set; } | Получает или задает набор графических фигур, формирующих маску. |
Примеры
В этом примере показано, как разложить растровое изображение на несколько изображений с помощью маскирования изображения и ручной маски. Маскирование изображения — это метод обработки изображения, который используется для отделения фона от объектов изображения переднего плана.
[C#]
string dir = "c:\\temp\\";
// Определяем ручную маску.
Aspose.Imaging.GraphicsPath manualMask = new Aspose.Imaging.GraphicsPath();
Aspose.Imaging.Figure figure = new Aspose.Imaging.Figure();
figure.AddShape(new Aspose.Imaging.Shapes.EllipseShape(new RectangleF(50, 50, 40, 40)));
figure.AddShape(new Aspose.Imaging.Shapes.RectangleShape(new RectangleF(10, 20, 50, 30)));
manualMask.AddFigure(figure);
// Каждый кластер (сегмент) будет храниться в отдельном файле PNG.
Aspose.Imaging.ImageOptions.PngOptions exportOptions = new Aspose.Imaging.ImageOptions.PngOptions();
exportOptions.ColorType = Aspose.Imaging.FileFormats.Png.PngColorType.TruecolorWithAlpha;
exportOptions.Source = new Aspose.Imaging.Sources.StreamSource(new System.IO.MemoryStream());
// Установить маску вручную.
Aspose.Imaging.Masking.Options.ManualMaskingArgs args = new Aspose.Imaging.Masking.Options.ManualMaskingArgs();
args.Mask = manualMask;
using (RasterImage image = (RasterImage)Image.Load(dir + "Blue hills.png"))
{
Aspose.Imaging.Masking.Options.MaskingOptions maskingOptions = new Aspose.Imaging.Masking.Options.MaskingOptions();
// Использовать ручной алгоритм кластеризации.
maskingOptions.Method = Masking.Options.SegmentationMethod.Manual;
// Все фигуры, составляющие маску, будут объединены в одну.
maskingOptions.Decompose = false;
maskingOptions.Args = args;
// Цвет фона будет оранжевый.
maskingOptions.BackgroundReplacementColor = Aspose.Imaging.Color.Orange;
maskingOptions.ExportOptions = exportOptions;
// Область исходного изображения, к которой будет применяться маскирование.
maskingOptions.MaskingArea = new Rectangle(50, 50, 120, 120);
// Создаем экземпляр класса ImageMasking.
Aspose.Imaging.Masking.ImageMasking masking = new Aspose.Imaging.Masking.ImageMasking(image);
// Разделить исходное изображение на несколько кластеров (сегментов).
using (Aspose.Imaging.Masking.Result.MaskingResult maskingResult = masking.Decompose(maskingOptions))
{
// Получаем изображения из результата маскирования и сохраняем их в PNG.
for (int i = 0; i < maskingResult.Length; i++)
{
string outputFileName = string.Format("Blue hills.Segment{0}.png", maskingResult[i].ObjectNumber);
using (Aspose.Imaging.Image resultImage = maskingResult[i].GetImage())
{
resultImage.Save(dir + outputFileName);
}
}
}
}
Смотрите также
- interface IMaskingArgs
- пространство имен Aspose.Imaging.Masking.Options
- сборка Aspose.Imaging