2018-05-01 17:16:46 +02:00
|
|
|
/*
|
|
|
|
* Copyright © 2016 Google, Inc.
|
2018-10-21 07:18:07 +02:00
|
|
|
* Copyright © 2018 Khaled Hosny
|
|
|
|
* Copyright © 2018 Ebrahim Byagowi
|
2018-05-01 17:16:46 +02:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2018-10-22 22:02:04 +02:00
|
|
|
* Google Author(s): Sascha Brawer, Behdad Esfahbod
|
2018-05-01 17:16:46 +02:00
|
|
|
*/
|
|
|
|
|
2021-02-10 22:37:43 +01:00
|
|
|
#if !defined(HB_OT_H_IN) && !defined(HB_NO_SINGLE_HEADER_ERROR)
|
2018-05-01 17:16:46 +02:00
|
|
|
#error "Include <hb-ot.h> instead."
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef HB_OT_COLOR_H
|
|
|
|
#define HB_OT_COLOR_H
|
|
|
|
|
|
|
|
#include "hb.h"
|
2018-10-21 06:56:40 +02:00
|
|
|
#include "hb-ot-name.h"
|
2018-05-01 17:16:46 +02:00
|
|
|
|
|
|
|
HB_BEGIN_DECLS
|
|
|
|
|
2018-10-22 04:23:11 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Color palettes.
|
|
|
|
*/
|
2018-05-01 17:16:46 +02:00
|
|
|
|
|
|
|
HB_EXTERN hb_bool_t
|
2018-10-22 04:23:11 +02:00
|
|
|
hb_ot_color_has_palettes (hb_face_t *face);
|
2018-05-01 17:16:46 +02:00
|
|
|
|
|
|
|
HB_EXTERN unsigned int
|
2018-10-22 22:02:04 +02:00
|
|
|
hb_ot_color_palette_get_count (hb_face_t *face);
|
2018-05-01 17:16:46 +02:00
|
|
|
|
2018-10-30 22:04:09 +01:00
|
|
|
HB_EXTERN hb_ot_name_id_t
|
2018-10-22 22:02:04 +02:00
|
|
|
hb_ot_color_palette_get_name_id (hb_face_t *face,
|
|
|
|
unsigned int palette_index);
|
2018-05-01 17:16:46 +02:00
|
|
|
|
2018-10-30 22:04:09 +01:00
|
|
|
HB_EXTERN hb_ot_name_id_t
|
2018-10-22 22:02:04 +02:00
|
|
|
hb_ot_color_palette_color_get_name_id (hb_face_t *face,
|
|
|
|
unsigned int color_index);
|
2018-05-01 17:16:46 +02:00
|
|
|
|
2018-10-21 08:14:16 +02:00
|
|
|
/**
|
|
|
|
* hb_ot_color_palette_flags_t:
|
2019-04-14 16:20:56 +02:00
|
|
|
* @HB_OT_COLOR_PALETTE_FLAG_DEFAULT: Default indicating that there is nothing special
|
2018-10-22 04:08:25 +02:00
|
|
|
* to note about a color palette.
|
2019-04-14 16:20:56 +02:00
|
|
|
* @HB_OT_COLOR_PALETTE_FLAG_USABLE_WITH_LIGHT_BACKGROUND: Flag indicating that the color
|
2018-10-22 04:08:25 +02:00
|
|
|
* palette is appropriate to use when displaying the font on a light background such as white.
|
2019-04-14 16:20:56 +02:00
|
|
|
* @HB_OT_COLOR_PALETTE_FLAG_USABLE_WITH_DARK_BACKGROUND: Flag indicating that the color
|
2018-10-22 04:08:25 +02:00
|
|
|
* palette is appropriate to use when displaying the font on a dark background such as black.
|
2018-10-21 08:14:16 +02:00
|
|
|
*
|
2020-12-28 04:23:26 +01:00
|
|
|
* Flags that describe the properties of color palette.
|
|
|
|
*
|
2018-10-30 23:52:26 +01:00
|
|
|
* Since: 2.1.0
|
2018-10-21 08:14:16 +02:00
|
|
|
*/
|
|
|
|
typedef enum { /*< flags >*/
|
2018-10-22 04:08:25 +02:00
|
|
|
HB_OT_COLOR_PALETTE_FLAG_DEFAULT = 0x00000000u,
|
|
|
|
HB_OT_COLOR_PALETTE_FLAG_USABLE_WITH_LIGHT_BACKGROUND = 0x00000001u,
|
2018-12-17 23:18:47 +01:00
|
|
|
HB_OT_COLOR_PALETTE_FLAG_USABLE_WITH_DARK_BACKGROUND = 0x00000002u
|
2018-10-21 08:14:16 +02:00
|
|
|
} hb_ot_color_palette_flags_t;
|
|
|
|
|
|
|
|
HB_EXTERN hb_ot_color_palette_flags_t
|
2018-10-22 22:02:04 +02:00
|
|
|
hb_ot_color_palette_get_flags (hb_face_t *face,
|
|
|
|
unsigned int palette_index);
|
2018-10-21 08:14:16 +02:00
|
|
|
|
2018-10-22 22:02:04 +02:00
|
|
|
HB_EXTERN unsigned int
|
2018-10-23 01:55:12 +02:00
|
|
|
hb_ot_color_palette_get_colors (hb_face_t *face,
|
|
|
|
unsigned int palette_index,
|
|
|
|
unsigned int start_offset,
|
|
|
|
unsigned int *color_count, /* IN/OUT. May be NULL. */
|
|
|
|
hb_color_t *colors /* OUT. May be NULL. */);
|
2018-10-22 04:08:25 +02:00
|
|
|
|
2018-10-22 04:23:11 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Color layers.
|
|
|
|
*/
|
|
|
|
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_ot_color_has_layers (hb_face_t *face);
|
|
|
|
|
2018-10-22 19:29:01 +02:00
|
|
|
/**
|
2018-10-29 19:01:25 +01:00
|
|
|
* hb_ot_color_layer_t:
|
2020-12-28 04:23:26 +01:00
|
|
|
* @glyph: the glyph ID of the layer
|
|
|
|
* @color_index: the palette color index of the layer
|
2018-10-29 19:01:25 +01:00
|
|
|
*
|
|
|
|
* Pairs of glyph and color index.
|
2018-10-22 19:29:01 +02:00
|
|
|
*
|
2022-07-10 03:57:25 +02:00
|
|
|
* A color index of 0xFFFF does not refer to a palette
|
|
|
|
* color, but indicates that the foreground color should
|
|
|
|
* be used.
|
|
|
|
*
|
2018-10-30 23:52:26 +01:00
|
|
|
* Since: 2.1.0
|
2018-10-22 19:29:01 +02:00
|
|
|
**/
|
2020-12-22 23:22:56 +01:00
|
|
|
typedef struct hb_ot_color_layer_t {
|
2018-10-22 19:29:01 +02:00
|
|
|
hb_codepoint_t glyph;
|
|
|
|
unsigned int color_index;
|
|
|
|
} hb_ot_color_layer_t;
|
|
|
|
|
2018-10-22 04:23:11 +02:00
|
|
|
HB_EXTERN unsigned int
|
2018-10-22 19:29:01 +02:00
|
|
|
hb_ot_color_glyph_get_layers (hb_face_t *face,
|
|
|
|
hb_codepoint_t glyph,
|
|
|
|
unsigned int start_offset,
|
2019-05-11 09:53:52 +02:00
|
|
|
unsigned int *layer_count, /* IN/OUT. May be NULL. */
|
2018-10-22 19:29:01 +02:00
|
|
|
hb_ot_color_layer_t *layers /* OUT. May be NULL. */);
|
2018-10-22 04:23:11 +02:00
|
|
|
|
2022-12-18 06:12:32 +01:00
|
|
|
/* COLRv1 */
|
|
|
|
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_ot_color_has_paint (hb_face_t *face);
|
|
|
|
|
2022-12-26 13:59:01 +01:00
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_ot_color_glyph_has_paint (hb_face_t *face,
|
|
|
|
hb_codepoint_t glyph);
|
|
|
|
|
2018-10-27 13:45:24 +02:00
|
|
|
/*
|
|
|
|
* SVG
|
|
|
|
*/
|
|
|
|
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_ot_color_has_svg (hb_face_t *face);
|
|
|
|
|
|
|
|
HB_EXTERN hb_blob_t *
|
2018-10-28 19:08:56 +01:00
|
|
|
hb_ot_color_glyph_reference_svg (hb_face_t *face, hb_codepoint_t glyph);
|
2018-10-27 13:45:24 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* PNG: CBDT or sbix
|
|
|
|
*/
|
|
|
|
|
|
|
|
HB_EXTERN hb_bool_t
|
|
|
|
hb_ot_color_has_png (hb_face_t *face);
|
|
|
|
|
|
|
|
HB_EXTERN hb_blob_t *
|
2018-10-28 19:08:56 +01:00
|
|
|
hb_ot_color_glyph_reference_png (hb_font_t *font, hb_codepoint_t glyph);
|
2018-10-27 13:45:24 +02:00
|
|
|
|
|
|
|
|
2018-05-01 17:16:46 +02:00
|
|
|
HB_END_DECLS
|
|
|
|
|
|
|
|
#endif /* HB_OT_COLOR_H */
|