| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029 |
- /*
- * 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 */
|