/*
* Copyright © 2022 Matthias Clasen
*
* This is part of HarfBuzz , a text shaping library .
*
* Permission is hereby granted , without written agreement and without
* license or royalty fees , to use , copy , modify , and distribute this
* software and its documentation for any purpose , provided that the
* above copyright notice and the following two paragraphs appear in
* all copies of this software .
*
* IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
* DIRECT , INDIRECT , SPECIAL , INCIDENTAL , OR CONSEQUENTIAL DAMAGES
* ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION , EVEN
* IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE .
*
* THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES , INCLUDING ,
* BUT NOT LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE . THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN " AS IS " BASIS , AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
* PROVIDE MAINTENANCE , SUPPORT , UPDATES , ENHANCEMENTS , OR MODIFICATIONS .
*/
#if !defined (HB_H_IN) && !defined (HB_NO_SINGLE_HEADER_ERROR)
#error "Include <hb.h> instead."
#endif
#ifndef HB_PAINT_H
#define HB_PAINT_H
#include "hb-common.h"
HB_BEGIN_DECLS
/**
* hb_paint_funcs_t :
*
* Glyph paint callbacks .
*
* The callbacks assume that the caller maintains a stack
* of current transforms , clips and intermediate surfaces ,
* as evidenced by the pairs of push / pop callbacks . The
* push / pop calls will be properly nested , so it is fine
* to store the different kinds of object on a single stack .
*
* Not all callbacks are required for all kinds of glyphs .
* For rendering COLRv0 or non - color outline glyphs , the
* gradient callbacks are not needed , and the composite
* callback only needs to handle simple alpha compositing
* ( # HB_PAINT_COMPOSITE_MODE_SRC_OVER ) .
*
* The paint - image callback is only needed for glyphs
* with image blobs in the CBDT , sbix or SVG tables .
*
* The custom - palette - color callback is only necessary if
* you want to override colors from the font palette with
* custom colors .
*
* Since : 7 . 0 . 0
**/
typedef struct hb_paint_funcs_t hb_paint_funcs_t;
HB_EXTERN hb_paint_funcs_t *
hb_paint_funcs_create (void );
HB_EXTERN hb_paint_funcs_t *
hb_paint_funcs_get_empty (void );
HB_EXTERN hb_paint_funcs_t *
hb_paint_funcs_reference (hb_paint_funcs_t *funcs);
HB_EXTERN void
hb_paint_funcs_destroy (hb_paint_funcs_t *funcs);
HB_EXTERN hb_bool_t
hb_paint_funcs_set_user_data (hb_paint_funcs_t *funcs,
hb_user_data_key_t *key,
void * data,
hb_destroy_func_t destroy,
hb_bool_t replace);
HB_EXTERN void *
hb_paint_funcs_get_user_data (const hb_paint_funcs_t *funcs,
hb_user_data_key_t *key);
HB_EXTERN void
hb_paint_funcs_make_immutable (hb_paint_funcs_t *funcs);
HB_EXTERN hb_bool_t
hb_paint_funcs_is_immutable (hb_paint_funcs_t *funcs);
/**
* hb_paint_push_transform_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ xx : xx component of the transform matrix
* @ yx : yx component of the transform matrix
* @ xy : xy component of the transform matrix
* @ yy : yy component of the transform matrix
* @ dx : dx component of the transform matrix
* @ dy : dy component of the transform matrix
* @ user_data : User data pointer passed to hb_paint_funcs_set_push_transform_func ( )
*
* A virtual method for the # hb_paint_funcs_t to apply
* a transform to subsequent paint calls .
*
* This transform is applied after the current transform ,
* and remains in effect until a matching call to
* the # hb_paint_funcs_pop_transform_func_t vfunc .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_push_transform_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
float xx, float yx,
float xy, float yy,
float dx, float dy,
void *user_data);
/**
* hb_paint_pop_transform_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ user_data : User data pointer passed to hb_paint_funcs_set_pop_transform_func ( )
*
* A virtual method for the # hb_paint_funcs_t to undo
* the effect of a prior call to the # hb_paint_funcs_push_transform_func_t
* vfunc .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_pop_transform_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
void *user_data);
/**
* hb_paint_color_glyph_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ glyph : the glyph ID
* @ font : the font
* @ user_data : User data pointer passed to hb_paint_funcs_set_color_glyph_func ( )
*
* A virtual method for the # hb_paint_funcs_t to render a color glyph by glyph index .
*
* Return value : ` true ` if the glyph was painted , ` false ` otherwise .
*
* Since : 8 . 2 . 0
*/
typedef hb_bool_t (*hb_paint_color_glyph_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_codepoint_t glyph,
hb_font_t *font,
void *user_data);
/**
* hb_paint_push_clip_glyph_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ glyph : the glyph ID
* @ font : the font
* @ user_data : User data pointer passed to hb_paint_funcs_set_push_clip_glyph_func ( )
*
* A virtual method for the # hb_paint_funcs_t to clip
* subsequent paint calls to the outline of a glyph .
*
* The coordinates of the glyph outline are interpreted according
* to the current transform .
*
* This clip is applied in addition to the current clip ,
* and remains in effect until a matching call to
* the # hb_paint_funcs_pop_clip_func_t vfunc .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_push_clip_glyph_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_codepoint_t glyph,
hb_font_t *font,
void *user_data);
/**
* hb_paint_push_clip_rectangle_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ xmin : min X for the rectangle
* @ ymin : min Y for the rectangle
* @ xmax : max X for the rectangle
* @ ymax : max Y for the rectangle
* @ user_data : User data pointer passed to hb_paint_funcs_set_push_clip_rectangle_func ( )
*
* A virtual method for the # hb_paint_funcs_t to clip
* subsequent paint calls to a rectangle .
*
* The coordinates of the rectangle are interpreted according
* to the current transform .
*
* This clip is applied in addition to the current clip ,
* and remains in effect until a matching call to
* the # hb_paint_funcs_pop_clip_func_t vfunc .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_push_clip_rectangle_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
float xmin, float ymin,
float xmax, float ymax,
void *user_data);
/**
* hb_paint_pop_clip_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ user_data : User data pointer passed to hb_paint_funcs_set_pop_clip_func ( )
*
* A virtual method for the # hb_paint_funcs_t to undo
* the effect of a prior call to the # hb_paint_funcs_push_clip_glyph_func_t
* or # hb_paint_funcs_push_clip_rectangle_func_t vfuncs .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_pop_clip_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
void *user_data);
/**
* hb_paint_color_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ is_foreground : whether the color is the foreground
* @ color : The color to use , unpremultiplied
* @ user_data : User data pointer passed to hb_paint_funcs_set_color_func ( )
*
* A virtual method for the # hb_paint_funcs_t to paint a
* color everywhere within the current clip .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_color_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_bool_t is_foreground,
hb_color_t color,
void *user_data);
/**
* HB_PAINT_IMAGE_FORMAT_PNG :
*
* Tag identifying PNG images in # hb_paint_image_func_t callbacks .
*
* Since : 7 . 0 . 0
*/
#define HB_PAINT_IMAGE_FORMAT_PNG HB_TAG('p' ,'n' ,'g' ,' ' )
/**
* HB_PAINT_IMAGE_FORMAT_SVG :
*
* Tag identifying SVG images in # hb_paint_image_func_t callbacks .
*
* Since : 7 . 0 . 0
*/
#define HB_PAINT_IMAGE_FORMAT_SVG HB_TAG('s' ,'v' ,'g' ,' ' )
/**
* HB_PAINT_IMAGE_FORMAT_BGRA :
*
* Tag identifying raw pixel - data images in # hb_paint_image_func_t callbacks .
* The data is in BGRA pre - multiplied sRGBA color - space format .
*
* Since : 7 . 0 . 0
*/
#define HB_PAINT_IMAGE_FORMAT_BGRA HB_TAG('B' ,'G' ,'R' ,'A' )
/**
* hb_paint_image_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ image : the image data
* @ width : width of the raster image in pixels , or 0
* @ height : height of the raster image in pixels , or 0
* @ format : the image format as a tag
* @ slant : the synthetic slant ratio to be applied to the image during rendering
* @ extents : ( nullable ) : glyph extents for desired rendering
* @ user_data : User data pointer passed to hb_paint_funcs_set_image_func ( )
*
* A virtual method for the # hb_paint_funcs_t to paint a glyph image .
*
* This method is called for glyphs with image blobs in the CBDT ,
* sbix or SVG tables . The @ format identifies the kind of data that
* is contained in @ image . Possible values include # HB_PAINT_IMAGE_FORMAT_PNG ,
* # HB_PAINT_IMAGE_FORMAT_SVG and # HB_PAINT_IMAGE_FORMAT_BGRA .
*
* The image dimensions and glyph extents are provided if available ,
* and should be used to size and position the image .
*
* Return value : Whether the operation was successful .
*
* Since : 7 . 0 . 0
*/
typedef hb_bool_t (*hb_paint_image_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_blob_t *image,
unsigned int width,
unsigned int height,
hb_tag_t format,
float slant,
hb_glyph_extents_t *extents,
void *user_data);
/**
* hb_color_stop_t :
* @ offset : the offset of the color stop
* @ is_foreground : whether the color is the foreground
* @ color : the color , unpremultiplied
*
* Information about a color stop on a color line .
*
* Color lines typically have offsets ranging between 0 and 1 ,
* but that is not required .
*
* Note : despite @ color being unpremultiplied here , interpolation in
* gradients shall happen in premultiplied space . See the OpenType spec
* [ COLR ] ( https : //learn.microsoft.com/en-us/typography/opentype/spec/colr)
* section for details .
*
* Since : 7 . 0 . 0
*/
typedef struct {
float offset;
hb_bool_t is_foreground;
hb_color_t color;
} hb_color_stop_t;
/**
* hb_paint_extend_t :
* @ HB_PAINT_EXTEND_PAD : Outside the defined interval ,
* the color of the closest color stop is used .
* @ HB_PAINT_EXTEND_REPEAT : The color line is repeated over
* repeated multiples of the defined interval
* @ HB_PAINT_EXTEND_REFLECT : The color line is repeated over
* repeated intervals , as for the repeat mode .
* However , in each repeated interval , the ordering of
* color stops is the reverse of the adjacent interval .
*
* The values of this enumeration determine how color values
* outside the minimum and maximum defined offset on a # hb_color_line_t
* are determined .
*
* See the OpenType spec [ COLR ] ( https : //learn.microsoft.com/en-us/typography/opentype/spec/colr)
* section for details .
*
* Since : 7 . 0 . 0
*/
typedef enum {
HB_PAINT_EXTEND_PAD,
HB_PAINT_EXTEND_REPEAT,
HB_PAINT_EXTEND_REFLECT
} hb_paint_extend_t;
typedef struct hb_color_line_t hb_color_line_t;
/**
* hb_color_line_get_color_stops_func_t :
* @ color_line : a # hb_color_line_t object
* @ color_line_data : the data accompanying @ color_line
* @ start : the index of the first color stop to return
* @ count : ( inout ) ( optional ) : Input = the maximum number of feature tags to return ;
* Output = the actual number of feature tags returned ( may be zero )
* @ color_stops : ( out ) ( array length = count ) ( optional ) : Array of # hb_color_stop_t to populate
* @ user_data : the data accompanying this method
*
* A virtual method for the # hb_color_line_t to fetch color stops .
*
* Return value : the total number of color stops in @ color_line
*
* Since : 7 . 0 . 0
*/
typedef unsigned int (*hb_color_line_get_color_stops_func_t) (hb_color_line_t *color_line,
void *color_line_data,
unsigned int start,
unsigned int *count,
hb_color_stop_t *color_stops,
void *user_data);
/**
* hb_color_line_get_extend_func_t :
* @ color_line : a # hb_color_line_t object
* @ color_line_data : the data accompanying @ color_line
* @ user_data : the data accompanying this method
*
* A virtual method for the @ hb_color_line_t to fetches the extend mode .
*
* Return value : the extend mode of @ color_line
*
* Since : 7 . 0 . 0
*/
typedef hb_paint_extend_t (*hb_color_line_get_extend_func_t) (hb_color_line_t *color_line,
void *color_line_data,
void *user_data);
/**
* hb_color_line_t :
*
* A struct containing color information for a gradient .
*
* Since : 7 . 0 . 0
*/
struct hb_color_line_t {
void *data;
hb_color_line_get_color_stops_func_t get_color_stops;
void *get_color_stops_user_data;
hb_color_line_get_extend_func_t get_extend;
void *get_extend_user_data;
void *reserved0;
void *reserved1;
void *reserved2;
void *reserved3;
void *reserved5;
void *reserved6;
void *reserved7;
void *reserved8;
};
HB_EXTERN unsigned int
hb_color_line_get_color_stops (hb_color_line_t *color_line,
unsigned int start,
unsigned int *count,
hb_color_stop_t *color_stops);
HB_EXTERN hb_paint_extend_t
hb_color_line_get_extend (hb_color_line_t *color_line);
/**
* hb_paint_linear_gradient_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ color_line : Color information for the gradient
* @ x0 : X coordinate of the first point
* @ y0 : Y coordinate of the first point
* @ x1 : X coordinate of the second point
* @ y1 : Y coordinate of the second point
* @ x2 : X coordinate of the third point
* @ y2 : Y coordinate of the third point
* @ user_data : User data pointer passed to hb_paint_funcs_set_linear_gradient_func ( )
*
* A virtual method for the # hb_paint_funcs_t to paint a linear
* gradient everywhere within the current clip .
*
* The @ color_line object contains information about the colors of the gradients .
* It is only valid for the duration of the callback , you cannot keep it around .
*
* The coordinates of the points are interpreted according
* to the current transform .
*
* See the OpenType spec [ COLR ] ( https : //learn.microsoft.com/en-us/typography/opentype/spec/colr)
* section for details on how the points define the direction
* of the gradient , and how to interpret the @ color_line .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_linear_gradient_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_color_line_t *color_line,
float x0, float y0,
float x1, float y1,
float x2, float y2,
void *user_data);
/**
* hb_paint_radial_gradient_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ color_line : Color information for the gradient
* @ x0 : X coordinate of the first circle ' s center
* @ y0 : Y coordinate of the first circle ' s center
* @ r0 : radius of the first circle
* @ x1 : X coordinate of the second circle ' s center
* @ y1 : Y coordinate of the second circle ' s center
* @ r1 : radius of the second circle
* @ user_data : User data pointer passed to hb_paint_funcs_set_radial_gradient_func ( )
*
* A virtual method for the # hb_paint_funcs_t to paint a radial
* gradient everywhere within the current clip .
*
* The @ color_line object contains information about the colors of the gradients .
* It is only valid for the duration of the callback , you cannot keep it around .
*
* The coordinates of the points are interpreted according
* to the current transform .
*
* See the OpenType spec [ COLR ] ( https : //learn.microsoft.com/en-us/typography/opentype/spec/colr)
* section for details on how the points define the direction
* of the gradient , and how to interpret the @ color_line .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_radial_gradient_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_color_line_t *color_line,
float x0, float y0, float r0,
float x1, float y1, float r1,
void *user_data);
/**
* hb_paint_sweep_gradient_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ color_line : Color information for the gradient
* @ x0 : X coordinate of the circle ' s center
* @ y0 : Y coordinate of the circle ' s center
* @ start_angle : the start angle , in radians
* @ end_angle : the end angle , in radians
* @ user_data : User data pointer passed to hb_paint_funcs_set_sweep_gradient_func ( )
*
* A virtual method for the # hb_paint_funcs_t to paint a sweep
* gradient everywhere within the current clip .
*
* The @ color_line object contains information about the colors of the gradients .
* It is only valid for the duration of the callback , you cannot keep it around .
*
* The coordinates of the points are interpreted according
* to the current transform .
*
* See the OpenType spec [ COLR ] ( https : //learn.microsoft.com/en-us/typography/opentype/spec/colr)
* section for details on how the points define the direction
* of the gradient , and how to interpret the @ color_line .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_sweep_gradient_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_color_line_t *color_line,
float x0, float y0,
float start_angle,
float end_angle,
void *user_data);
/**
* hb_paint_composite_mode_t :
* @ HB_PAINT_COMPOSITE_MODE_CLEAR : clear destination layer ( bounded )
* @ HB_PAINT_COMPOSITE_MODE_SRC : replace destination layer ( bounded )
* @ HB_PAINT_COMPOSITE_MODE_SRC_OVER : draw source layer on top of destination layer
* ( bounded )
* @ HB_PAINT_COMPOSITE_MODE_SRC_IN : draw source where there was destination content
* ( unbounded )
* @ HB_PAINT_COMPOSITE_MODE_SRC_OUT : draw source where there was no destination
* content ( unbounded )
* @ HB_PAINT_COMPOSITE_MODE_SRC_ATOP : draw source on top of destination content and
* only there
* @ HB_PAINT_COMPOSITE_MODE_DEST : ignore the source
* @ HB_PAINT_COMPOSITE_MODE_DEST_OVER : draw destination on top of source
* @ HB_PAINT_COMPOSITE_MODE_DEST_IN : leave destination only where there was
* source content ( unbounded )
* @ HB_PAINT_COMPOSITE_MODE_DEST_OUT : leave destination only where there was no
* source content
* @ HB_PAINT_COMPOSITE_MODE_DEST_ATOP : leave destination on top of source content
* and only there ( unbounded )
* @ HB_PAINT_COMPOSITE_MODE_XOR : source and destination are shown where there is only
* one of them
* @ HB_PAINT_COMPOSITE_MODE_PLUS : source and destination layers are accumulated
* @ HB_PAINT_COMPOSITE_MODE_MULTIPLY : source and destination layers are multiplied .
* This causes the result to be at least as dark as the darker inputs .
* @ HB_PAINT_COMPOSITE_MODE_SCREEN : source and destination are complemented and
* multiplied . This causes the result to be at least as light as the lighter
* inputs .
* @ HB_PAINT_COMPOSITE_MODE_OVERLAY : multiplies or screens , depending on the
* lightness of the destination color .
* @ HB_PAINT_COMPOSITE_MODE_DARKEN : replaces the destination with the source if it
* is darker , otherwise keeps the source .
* @ HB_PAINT_COMPOSITE_MODE_LIGHTEN : replaces the destination with the source if it
* is lighter , otherwise keeps the source .
* @ HB_PAINT_COMPOSITE_MODE_COLOR_DODGE : brightens the destination color to reflect
* the source color .
* @ HB_PAINT_COMPOSITE_MODE_COLOR_BURN : darkens the destination color to reflect
* the source color .
* @ HB_PAINT_COMPOSITE_MODE_HARD_LIGHT : Multiplies or screens , dependent on source
* color .
* @ HB_PAINT_COMPOSITE_MODE_SOFT_LIGHT : Darkens or lightens , dependent on source
* color .
* @ HB_PAINT_COMPOSITE_MODE_DIFFERENCE : Takes the difference of the source and
* destination color .
* @ HB_PAINT_COMPOSITE_MODE_EXCLUSION : Produces an effect similar to difference , but
* with lower contrast .
* @ HB_PAINT_COMPOSITE_MODE_HSL_HUE : Creates a color with the hue of the source
* and the saturation and luminosity of the target .
* @ HB_PAINT_COMPOSITE_MODE_HSL_SATURATION : Creates a color with the saturation
* of the source and the hue and luminosity of the target . Painting with
* this mode onto a gray area produces no change .
* @ HB_PAINT_COMPOSITE_MODE_HSL_COLOR : Creates a color with the hue and saturation
* of the source and the luminosity of the target . This preserves the gray
* levels of the target and is useful for coloring monochrome images or
* tinting color images .
* @ HB_PAINT_COMPOSITE_MODE_HSL_LUMINOSITY : Creates a color with the luminosity of
* the source and the hue and saturation of the target . This produces an
* inverse effect to @ HB_PAINT_COMPOSITE_MODE_HSL_COLOR .
*
* The values of this enumeration describe the compositing modes
* that can be used when combining temporary redirected drawing
* with the backdrop .
*
* See the OpenType spec [ COLR ] ( https : //learn.microsoft.com/en-us/typography/opentype/spec/colr)
* section for details .
*
* Since : 7 . 0 . 0
*/
typedef enum {
HB_PAINT_COMPOSITE_MODE_CLEAR,
HB_PAINT_COMPOSITE_MODE_SRC,
HB_PAINT_COMPOSITE_MODE_DEST,
HB_PAINT_COMPOSITE_MODE_SRC_OVER,
HB_PAINT_COMPOSITE_MODE_DEST_OVER,
HB_PAINT_COMPOSITE_MODE_SRC_IN,
HB_PAINT_COMPOSITE_MODE_DEST_IN,
HB_PAINT_COMPOSITE_MODE_SRC_OUT,
HB_PAINT_COMPOSITE_MODE_DEST_OUT,
HB_PAINT_COMPOSITE_MODE_SRC_ATOP,
HB_PAINT_COMPOSITE_MODE_DEST_ATOP,
HB_PAINT_COMPOSITE_MODE_XOR,
HB_PAINT_COMPOSITE_MODE_PLUS,
HB_PAINT_COMPOSITE_MODE_SCREEN,
HB_PAINT_COMPOSITE_MODE_OVERLAY,
HB_PAINT_COMPOSITE_MODE_DARKEN,
HB_PAINT_COMPOSITE_MODE_LIGHTEN,
HB_PAINT_COMPOSITE_MODE_COLOR_DODGE,
HB_PAINT_COMPOSITE_MODE_COLOR_BURN,
HB_PAINT_COMPOSITE_MODE_HARD_LIGHT,
HB_PAINT_COMPOSITE_MODE_SOFT_LIGHT,
HB_PAINT_COMPOSITE_MODE_DIFFERENCE,
HB_PAINT_COMPOSITE_MODE_EXCLUSION,
HB_PAINT_COMPOSITE_MODE_MULTIPLY,
HB_PAINT_COMPOSITE_MODE_HSL_HUE,
HB_PAINT_COMPOSITE_MODE_HSL_SATURATION,
HB_PAINT_COMPOSITE_MODE_HSL_COLOR,
HB_PAINT_COMPOSITE_MODE_HSL_LUMINOSITY
} hb_paint_composite_mode_t;
/**
* hb_paint_push_group_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ user_data : User data pointer passed to hb_paint_funcs_set_push_group_func ( )
*
* A virtual method for the # hb_paint_funcs_t to use
* an intermediate surface for subsequent paint calls .
*
* The drawing will be redirected to an intermediate surface
* until a matching call to the # hb_paint_funcs_pop_group_func_t
* vfunc .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_push_group_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
void *user_data);
/**
* hb_paint_pop_group_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ mode : the compositing mode to use
* @ user_data : User data pointer passed to hb_paint_funcs_set_pop_group_func ( )
*
* A virtual method for the # hb_paint_funcs_t to undo
* the effect of a prior call to the # hb_paint_funcs_push_group_func_t
* vfunc .
*
* This call stops the redirection to the intermediate surface ,
* and then composites it on the previous surface , using the
* compositing mode passed to this call .
*
* Since : 7 . 0 . 0
*/
typedef void (*hb_paint_pop_group_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
hb_paint_composite_mode_t mode,
void *user_data);
/**
* hb_paint_custom_palette_color_func_t :
* @ funcs : paint functions object
* @ paint_data : The data accompanying the paint functions in hb_font_paint_glyph ( )
* @ color_index : the color index
* @ color : ( out ) : fetched color
* @ user_data : User data pointer passed to hb_paint_funcs_set_pop_group_func ( )
*
* A virtual method for the # hb_paint_funcs_t to fetch a color from the custom
* color palette .
*
* Custom palette colors override the colors from the fonts selected color
* palette . It is not necessary to override all palette entries ; for entries
* that should be taken from the font palette , return ` false ` .
*
* This function might get called multiple times , but the custom palette is
* expected to remain unchanged for duration of a hb_font_paint_glyph ( ) call .
*
* Return value : ` true ` if found , ` false ` otherwise
*
* Since : 7 . 0 . 0
*/
typedef hb_bool_t (*hb_paint_custom_palette_color_func_t) (hb_paint_funcs_t *funcs,
void *paint_data,
unsigned int color_index,
hb_color_t *color,
void *user_data);
/**
* hb_paint_funcs_set_push_transform_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The push - transform callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the push - transform callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_push_transform_func (hb_paint_funcs_t *funcs,
hb_paint_push_transform_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_pop_transform_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The pop - transform callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the pop - transform callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_pop_transform_func (hb_paint_funcs_t *funcs,
hb_paint_pop_transform_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_color_glyph_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The color - glyph callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the color - glyph callback on the paint functions struct .
*
* Since : 8 . 2 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_color_glyph_func (hb_paint_funcs_t *funcs,
hb_paint_color_glyph_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_push_clip_glyph_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The push - clip - glyph callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the push - clip - glyph callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_push_clip_glyph_func (hb_paint_funcs_t *funcs,
hb_paint_push_clip_glyph_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_push_clip_rectangle_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The push - clip - rectangle callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the push - clip - rect callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_push_clip_rectangle_func (hb_paint_funcs_t *funcs,
hb_paint_push_clip_rectangle_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_pop_clip_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The pop - clip callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the pop - clip callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_pop_clip_func (hb_paint_funcs_t *funcs,
hb_paint_pop_clip_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_color_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The paint - color callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the paint - color callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_color_func (hb_paint_funcs_t *funcs,
hb_paint_color_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_image_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The paint - image callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the paint - image callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_image_func (hb_paint_funcs_t *funcs,
hb_paint_image_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_linear_gradient_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The linear - gradient callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the linear - gradient callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_linear_gradient_func (hb_paint_funcs_t *funcs,
hb_paint_linear_gradient_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_radial_gradient_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The radial - gradient callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the radial - gradient callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_radial_gradient_func (hb_paint_funcs_t *funcs,
hb_paint_radial_gradient_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_sweep_gradient_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The sweep - gradient callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the sweep - gradient callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_sweep_gradient_func (hb_paint_funcs_t *funcs,
hb_paint_sweep_gradient_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_push_group_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The push - group callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the push - group callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_push_group_func (hb_paint_funcs_t *funcs,
hb_paint_push_group_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_pop_group_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The pop - group callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the pop - group callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_pop_group_func (hb_paint_funcs_t *funcs,
hb_paint_pop_group_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/**
* hb_paint_funcs_set_custom_palette_color_func :
* @ funcs : A paint functions struct
* @ func : ( closure user_data ) ( destroy destroy ) ( scope notified ) : The custom - palette - color callback
* @ user_data : Data to pass to @ func
* @ destroy : ( nullable ) : Function to call when @ user_data is no longer needed
*
* Sets the custom - palette - color callback on the paint functions struct .
*
* Since : 7 . 0 . 0
*/
HB_EXTERN void
hb_paint_funcs_set_custom_palette_color_func (hb_paint_funcs_t *funcs,
hb_paint_custom_palette_color_func_t func,
void *user_data,
hb_destroy_func_t destroy);
/*
* Manual API
*/
HB_EXTERN void
hb_paint_push_transform (hb_paint_funcs_t *funcs, void *paint_data,
float xx, float yx,
float xy, float yy,
float dx, float dy);
HB_EXTERN void
hb_paint_pop_transform (hb_paint_funcs_t *funcs, void *paint_data);
HB_EXTERN hb_bool_t
hb_paint_color_glyph (hb_paint_funcs_t *funcs, void *paint_data,
hb_codepoint_t glyph,
hb_font_t *font);
HB_EXTERN void
hb_paint_push_clip_glyph (hb_paint_funcs_t *funcs, void *paint_data,
hb_codepoint_t glyph,
hb_font_t *font);
HB_EXTERN void
hb_paint_push_clip_rectangle (hb_paint_funcs_t *funcs, void *paint_data,
float xmin, float ymin,
float xmax, float ymax);
HB_EXTERN void
hb_paint_pop_clip (hb_paint_funcs_t *funcs, void *paint_data);
HB_EXTERN void
hb_paint_color (hb_paint_funcs_t *funcs, void *paint_data,
hb_bool_t is_foreground,
hb_color_t color);
HB_EXTERN void
hb_paint_image (hb_paint_funcs_t *funcs, void *paint_data,
hb_blob_t *image,
unsigned int width,
unsigned int height,
hb_tag_t format,
float slant,
hb_glyph_extents_t *extents);
HB_EXTERN void
hb_paint_linear_gradient (hb_paint_funcs_t *funcs, void *paint_data,
hb_color_line_t *color_line,
float x0, float y0,
float x1, float y1,
float x2, float y2);
HB_EXTERN void
hb_paint_radial_gradient (hb_paint_funcs_t *funcs, void *paint_data,
hb_color_line_t *color_line,
float x0, float y0,
float r0,
float x1, float y1,
float r1);
HB_EXTERN void
hb_paint_sweep_gradient (hb_paint_funcs_t *funcs, void *paint_data,
hb_color_line_t *color_line,
float x0, float y0,
float start_angle, float end_angle);
HB_EXTERN void
hb_paint_push_group (hb_paint_funcs_t *funcs, void *paint_data);
HB_EXTERN void
hb_paint_pop_group (hb_paint_funcs_t *funcs, void *paint_data,
hb_paint_composite_mode_t mode);
HB_EXTERN hb_bool_t
hb_paint_custom_palette_color (hb_paint_funcs_t *funcs, void *paint_data,
unsigned int color_index,
hb_color_t *color);
HB_END_DECLS
#endif /* HB_PAINT_H */
Messung V0.5 in Prozent C=96 H=97 G=96
¤ Dauer der Verarbeitung: 0.32 Sekunden
(vorverarbeitet am 2026-06-10)
¤
*© Formatika GbR, Deutschland