iText 8.0.5 API
|
Base class for linear gradient builders implementations. More...
Public Member Functions |
|
virtual AbstractLinearGradientBuilder | AddColorStop (GradientColorStop gradientColorStop) |
Adds the new color stop to the end ( more info ). More... |
|
virtual AbstractLinearGradientBuilder | SetSpreadMethod (GradientSpreadMethod gradientSpreadMethod) |
Set the spread method to use for the gradient More... |
|
virtual IList< GradientColorStop > | GetColorStops () |
Get the copy of current color stops list. More... |
|
virtual GradientSpreadMethod | GetSpreadMethod () |
Get the current spread method More... |
|
virtual Color | BuildColor (Rectangle targetBoundingBox, AffineTransform contextTransform, PdfDocument document) |
Builds the iText.Kernel.Colors.Color object representing the linear gradient with specified configuration that fills the target bounding box. More... |
|
Package Functions |
|
abstract Point[] | GetGradientVector (Rectangle targetBoundingBox, AffineTransform contextTransform) |
Returns the base gradient vector in gradient vector space. More... |
|
virtual AffineTransform | GetCurrentSpaceToGradientVectorSpaceTransformation (Rectangle targetBoundingBox, AffineTransform contextTransform) |
Returns the current space to gradient vector space transformations that should be applied to the shading color. More... |
|
Static Package Functions |
|
static double[] | EvaluateCoveringDomain (Point[] coords, Rectangle toCover) |
Evaluates the minimal domain that covers the box with vector normals. More... |
|
static Point[] | CreateCoordinatesForNewDomain (double[] newDomain, Point[] baseVector) |
Expand the base vector to cover the new domain More... |
|
Static Package Attributes |
|
const double | ZERO_EPSILON = 1E-10 |
The epsilon value used for data creation More... |
|
Base class for linear gradient builders implementations.
Base class for linear gradient builders implementations.
Color transitions for linear gradients are defined by a series of color stops along a gradient vector. A gradient normal defines how the colors in a vector are painted to the surface. For a linear gradient, a normal is a line perpendicular to the vector.
Contains the main logic that works with stop colors and creation of the resulted pdf color object.
|
inlinevirtual |
Adds the new color stop to the end ( more info ).
Adds the new color stop to the end ( more info ). Note: if the previously added color stop's offset would have grater offset than the added one, then the new offset would be normalized to be equal to the previous one. (Comparison made between relative on coordinates vector offsets. If any of them has the absolute offset, then the absolute value would converted to relative first.)
gradientColorStop | the gradient stop color to add |
|
inlinevirtual |
Builds the iText.Kernel.Colors.Color object representing the linear gradient with specified configuration that fills the target bounding box.
targetBoundingBox | the bounding box to be filled in current space |
contextTransform | the transformation from the base coordinates space into the current space. The null value is valid and can be used if there is no transformation from base coordinates to current space specified, or it is equal to identity transformation. |
document | the iText.Kernel.Pdf.PdfDocument for which the linear gradient would be built. |
null
if no color to be applied or base gradient vector has been specified
|
inlinestaticpackage |
Expand the base vector to cover the new domain
newDomain | the array of exactly two elements that specifies the domain that should be covered by the created vector |
baseVector | the array of exactly two elements that specifies the base vector which corresponds to [0, 1] domain |
|
inlinestaticpackage |
Evaluates the minimal domain that covers the box with vector normals.
Evaluates the minimal domain that covers the box with vector normals. The domain corresponding to the initial vector is [0, 1].
coords | the array of exactly two elements that describe the base vector (corresponding to [0,1] domain, that need to be adjusted to cover the box |
toCover | the box that needs to be covered |
|
inlinevirtual |
Get the copy of current color stops list.
Get the copy of current color stops list. Note that the stop colors are not copied here
|
inlinepackagevirtual |
Returns the current space to gradient vector space transformations that should be applied to the shading color.
Returns the current space to gradient vector space transformations that should be applied to the shading color. The transformation should be invertible as the current target bounding box coordinates should be transformed into the resulted shading space coordinates.
targetBoundingBox | the rectangle to be covered by constructed color in current space |
contextTransform | the current canvas transformation |
null
if no additional transformation is specified
Reimplemented in iText.Kernel.Colors.Gradients.LinearGradientBuilder.
|
packagepure virtual |
Returns the base gradient vector in gradient vector space.
Returns the base gradient vector in gradient vector space. This vector would be set as shading coordinates vector and its length would be used to translate all color stops absolute offsets into the relatives.
targetBoundingBox | the rectangle to be covered by constructed color in current space |
contextTransform | the current canvas transformation |
Implemented in iText.Kernel.Colors.Gradients.StrategyBasedLinearGradientBuilder, and iText.Kernel.Colors.Gradients.LinearGradientBuilder.
|
inlinevirtual |
Get the current spread method
|
inlinevirtual |
Set the spread method to use for the gradient
gradientSpreadMethod | the gradient spread method to set |
|
staticpackage |
The epsilon value used for data creation