mirror of https://github.com/SixLabors/ImageSharp
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
43 lines
1.6 KiB
43 lines
1.6 KiB
// Copyright (c) Six Labors and contributors.
|
|
// Licensed under the Apache License, Version 2.0.
|
|
|
|
using SixLabors.ImageSharp.PixelFormats;
|
|
using SixLabors.Primitives;
|
|
|
|
namespace SixLabors.ImageSharp.Processing.Processors.Drawing
|
|
{
|
|
/// <summary>
|
|
/// Defines a processor to fill an <see cref="Image"/> with the given <see cref="IBrush"/>
|
|
/// using blending defined by the given <see cref="GraphicsOptions"/>.
|
|
/// </summary>
|
|
public class FillProcessor : IImageProcessor
|
|
{
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="FillProcessor"/> class.
|
|
/// </summary>
|
|
/// <param name="options">The <see cref="GraphicsOptions"/> defining how to blend the brush pixels over the image pixels.</param>
|
|
/// <param name="brush">The brush to use for filling.</param>
|
|
public FillProcessor(GraphicsOptions options, IBrush brush)
|
|
{
|
|
this.Brush = brush;
|
|
this.Options = options;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the <see cref="IBrush"/> used for filling the destination image.
|
|
/// </summary>
|
|
public IBrush Brush { get; }
|
|
|
|
/// <summary>
|
|
/// Gets the <see cref="GraphicsOptions"/> defining how to blend the brush pixels over the image pixels.
|
|
/// </summary>
|
|
public GraphicsOptions Options { get; }
|
|
|
|
/// <inheritdoc />
|
|
public IImageProcessor<TPixel> CreatePixelSpecificProcessor<TPixel>(Image<TPixel> source, Rectangle sourceRectangle)
|
|
where TPixel : struct, IPixel<TPixel>
|
|
{
|
|
return new FillProcessor<TPixel>(this, source, sourceRectangle);
|
|
}
|
|
}
|
|
}
|
|
|