pango-renderer.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. /* Pango
  2. * pango-renderer.h: Base class for rendering
  3. *
  4. * Copyright (C) 2004, Red Hat, Inc.
  5. *
  6. * This library is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Library General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2 of the License, or (at your option) any later version.
  10. *
  11. * This library is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Library General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Library General Public
  17. * License along with this library; if not, write to the
  18. * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
  19. * Boston, MA 02111-1307, USA.
  20. */
  21. #ifndef __PANGO_RENDERER_H_
  22. #define __PANGO_RENDERER_H_
  23. #include <pango/pango-layout.h>
  24. G_BEGIN_DECLS
  25. #define PANGO_TYPE_RENDERER (pango_renderer_get_type())
  26. #define PANGO_RENDERER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_RENDERER, PangoRenderer))
  27. #define PANGO_IS_RENDERER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_RENDERER))
  28. #define PANGO_RENDERER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_RENDERER, PangoRendererClass))
  29. #define PANGO_IS_RENDERER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_RENDERER))
  30. #define PANGO_RENDERER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_RENDERER, PangoRendererClass))
  31. typedef struct _PangoRenderer PangoRenderer;
  32. typedef struct _PangoRendererClass PangoRendererClass;
  33. typedef struct _PangoRendererPrivate PangoRendererPrivate;
  34. /**
  35. * PangoRenderPart:
  36. * @PANGO_RENDER_PART_FOREGROUND: the text itself
  37. * @PANGO_RENDER_PART_BACKGROUND: the area behind the text
  38. * @PANGO_RENDER_PART_UNDERLINE: underlines
  39. * @PANGO_RENDER_PART_STRIKETHROUGH: strikethrough lines
  40. * @PANGO_RENDER_PART_OVERLINE: overlines
  41. *
  42. * `PangoRenderPart` defines different items to render for such
  43. * purposes as setting colors.
  44. *
  45. * Since: 1.8
  46. **/
  47. /* When extending, note N_RENDER_PARTS #define in pango-renderer.c */
  48. typedef enum
  49. {
  50. PANGO_RENDER_PART_FOREGROUND,
  51. PANGO_RENDER_PART_BACKGROUND,
  52. PANGO_RENDER_PART_UNDERLINE,
  53. PANGO_RENDER_PART_STRIKETHROUGH,
  54. PANGO_RENDER_PART_OVERLINE
  55. } PangoRenderPart;
  56. /**
  57. * PangoRenderer:
  58. * @matrix: (nullable): the current transformation matrix for
  59. * the Renderer; may be %NULL, which should be treated the
  60. * same as the identity matrix.
  61. *
  62. * `PangoRenderer` is a base class for objects that can render text
  63. * provided as `PangoGlyphString` or `PangoLayout`.
  64. *
  65. * By subclassing `PangoRenderer` and overriding operations such as
  66. * @draw_glyphs and @draw_rectangle, renderers for particular font
  67. * backends and destinations can be created.
  68. *
  69. * Since: 1.8
  70. */
  71. struct _PangoRenderer
  72. {
  73. /*< private >*/
  74. GObject parent_instance;
  75. PangoUnderline underline;
  76. gboolean strikethrough;
  77. int active_count;
  78. /*< public >*/
  79. PangoMatrix *matrix; /* May be NULL */
  80. /*< private >*/
  81. PangoRendererPrivate *priv;
  82. };
  83. /**
  84. * PangoRendererClass:
  85. * @draw_glyphs: draws a `PangoGlyphString`
  86. * @draw_rectangle: draws a rectangle
  87. * @draw_error_underline: draws a squiggly line that approximately
  88. * covers the given rectangle in the style of an underline used to
  89. * indicate a spelling error.
  90. * @draw_shape: draw content for a glyph shaped with `PangoAttrShape`
  91. * @x, @y are the coordinates of the left edge of the baseline,
  92. * in user coordinates.
  93. * @draw_trapezoid: draws a trapezoidal filled area
  94. * @draw_glyph: draws a single glyph
  95. * @part_changed: do renderer specific processing when rendering
  96. * attributes change
  97. * @begin: Do renderer-specific initialization before drawing
  98. * @end: Do renderer-specific cleanup after drawing
  99. * @prepare_run: updates the renderer for a new run
  100. * @draw_glyph_item: draws a `PangoGlyphItem`
  101. *
  102. * Class structure for `PangoRenderer`.
  103. *
  104. * The following vfuncs take user space coordinates in Pango units
  105. * and have default implementations:
  106. * - draw_glyphs
  107. * - draw_rectangle
  108. * - draw_error_underline
  109. * - draw_shape
  110. * - draw_glyph_item
  111. *
  112. * The default draw_shape implementation draws nothing.
  113. *
  114. * The following vfuncs take device space coordinates as doubles
  115. * and must be implemented:
  116. * - draw_trapezoid
  117. * - draw_glyph
  118. *
  119. * Since: 1.8
  120. */
  121. struct _PangoRendererClass
  122. {
  123. /*< private >*/
  124. GObjectClass parent_class;
  125. /* vtable - not signals */
  126. /*< public >*/
  127. void (*draw_glyphs) (PangoRenderer *renderer,
  128. PangoFont *font,
  129. PangoGlyphString *glyphs,
  130. int x,
  131. int y);
  132. void (*draw_rectangle) (PangoRenderer *renderer,
  133. PangoRenderPart part,
  134. int x,
  135. int y,
  136. int width,
  137. int height);
  138. void (*draw_error_underline) (PangoRenderer *renderer,
  139. int x,
  140. int y,
  141. int width,
  142. int height);
  143. void (*draw_shape) (PangoRenderer *renderer,
  144. PangoAttrShape *attr,
  145. int x,
  146. int y);
  147. void (*draw_trapezoid) (PangoRenderer *renderer,
  148. PangoRenderPart part,
  149. double y1_,
  150. double x11,
  151. double x21,
  152. double y2,
  153. double x12,
  154. double x22);
  155. void (*draw_glyph) (PangoRenderer *renderer,
  156. PangoFont *font,
  157. PangoGlyph glyph,
  158. double x,
  159. double y);
  160. void (*part_changed) (PangoRenderer *renderer,
  161. PangoRenderPart part);
  162. void (*begin) (PangoRenderer *renderer);
  163. void (*end) (PangoRenderer *renderer);
  164. void (*prepare_run) (PangoRenderer *renderer,
  165. PangoLayoutRun *run);
  166. void (*draw_glyph_item) (PangoRenderer *renderer,
  167. const char *text,
  168. PangoGlyphItem *glyph_item,
  169. int x,
  170. int y);
  171. /*< private >*/
  172. /* Padding for future expansion */
  173. void (*_pango_reserved2) (void);
  174. void (*_pango_reserved3) (void);
  175. void (*_pango_reserved4) (void);
  176. };
  177. PANGO_AVAILABLE_IN_1_8
  178. GType pango_renderer_get_type (void) G_GNUC_CONST;
  179. PANGO_AVAILABLE_IN_1_8
  180. void pango_renderer_draw_layout (PangoRenderer *renderer,
  181. PangoLayout *layout,
  182. int x,
  183. int y);
  184. PANGO_AVAILABLE_IN_1_8
  185. void pango_renderer_draw_layout_line (PangoRenderer *renderer,
  186. PangoLayoutLine *line,
  187. int x,
  188. int y);
  189. PANGO_AVAILABLE_IN_1_8
  190. void pango_renderer_draw_glyphs (PangoRenderer *renderer,
  191. PangoFont *font,
  192. PangoGlyphString *glyphs,
  193. int x,
  194. int y);
  195. PANGO_AVAILABLE_IN_1_22
  196. void pango_renderer_draw_glyph_item (PangoRenderer *renderer,
  197. const char *text,
  198. PangoGlyphItem *glyph_item,
  199. int x,
  200. int y);
  201. PANGO_AVAILABLE_IN_1_8
  202. void pango_renderer_draw_rectangle (PangoRenderer *renderer,
  203. PangoRenderPart part,
  204. int x,
  205. int y,
  206. int width,
  207. int height);
  208. PANGO_AVAILABLE_IN_1_8
  209. void pango_renderer_draw_error_underline (PangoRenderer *renderer,
  210. int x,
  211. int y,
  212. int width,
  213. int height);
  214. PANGO_AVAILABLE_IN_1_8
  215. void pango_renderer_draw_trapezoid (PangoRenderer *renderer,
  216. PangoRenderPart part,
  217. double y1_,
  218. double x11,
  219. double x21,
  220. double y2,
  221. double x12,
  222. double x22);
  223. PANGO_AVAILABLE_IN_1_8
  224. void pango_renderer_draw_glyph (PangoRenderer *renderer,
  225. PangoFont *font,
  226. PangoGlyph glyph,
  227. double x,
  228. double y);
  229. PANGO_AVAILABLE_IN_1_8
  230. void pango_renderer_activate (PangoRenderer *renderer);
  231. PANGO_AVAILABLE_IN_1_8
  232. void pango_renderer_deactivate (PangoRenderer *renderer);
  233. PANGO_AVAILABLE_IN_1_8
  234. void pango_renderer_part_changed (PangoRenderer *renderer,
  235. PangoRenderPart part);
  236. PANGO_AVAILABLE_IN_1_8
  237. void pango_renderer_set_color (PangoRenderer *renderer,
  238. PangoRenderPart part,
  239. const PangoColor *color);
  240. PANGO_AVAILABLE_IN_1_8
  241. PangoColor *pango_renderer_get_color (PangoRenderer *renderer,
  242. PangoRenderPart part);
  243. PANGO_AVAILABLE_IN_1_38
  244. void pango_renderer_set_alpha (PangoRenderer *renderer,
  245. PangoRenderPart part,
  246. guint16 alpha);
  247. PANGO_AVAILABLE_IN_1_38
  248. guint16 pango_renderer_get_alpha (PangoRenderer *renderer,
  249. PangoRenderPart part);
  250. PANGO_AVAILABLE_IN_1_8
  251. void pango_renderer_set_matrix (PangoRenderer *renderer,
  252. const PangoMatrix *matrix);
  253. PANGO_AVAILABLE_IN_1_8
  254. const PangoMatrix *pango_renderer_get_matrix (PangoRenderer *renderer);
  255. PANGO_AVAILABLE_IN_1_20
  256. PangoLayout *pango_renderer_get_layout (PangoRenderer *renderer);
  257. PANGO_AVAILABLE_IN_1_20
  258. PangoLayoutLine *pango_renderer_get_layout_line (PangoRenderer *renderer);
  259. G_END_DECLS
  260. #endif /* __PANGO_RENDERER_H_ */