pango-renderer.h 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  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. *
  41. * #PangoRenderPart defines different items to render for such
  42. * purposes as setting colors.
  43. *
  44. * Since: 1.8
  45. **/
  46. /* When extending, note N_RENDER_PARTS #define in pango-renderer.c */
  47. typedef enum
  48. {
  49. PANGO_RENDER_PART_FOREGROUND,
  50. PANGO_RENDER_PART_BACKGROUND,
  51. PANGO_RENDER_PART_UNDERLINE,
  52. PANGO_RENDER_PART_STRIKETHROUGH
  53. } PangoRenderPart;
  54. /**
  55. * PangoRenderer:
  56. * @matrix: (nullable): the current transformation matrix for
  57. * the Renderer; may be %NULL, which should be treated the
  58. * same as the identity matrix.
  59. *
  60. * #PangoRenderer is a base class for objects that are used to
  61. * render Pango objects such as #PangoGlyphString and
  62. * #PangoLayout.
  63. *
  64. * Since: 1.8
  65. **/
  66. struct _PangoRenderer
  67. {
  68. /*< private >*/
  69. GObject parent_instance;
  70. PangoUnderline underline;
  71. gboolean strikethrough;
  72. int active_count;
  73. /*< public >*/
  74. PangoMatrix *matrix; /* May be NULL */
  75. /*< private >*/
  76. PangoRendererPrivate *priv;
  77. };
  78. /**
  79. * PangoRendererClass:
  80. * @draw_glyphs: draws a #PangoGlyphString
  81. * @draw_rectangle: draws a rectangle
  82. * @draw_error_underline: draws a squiggly line that approximately
  83. * covers the given rectangle in the style of an underline used to
  84. * indicate a spelling error.
  85. * @draw_shape: draw content for a glyph shaped with #PangoAttrShape.
  86. * @x, @y are the coordinates of the left edge of the baseline,
  87. * in user coordinates.
  88. * @draw_trapezoid: draws a trapezoidal filled area
  89. * @draw_glyph: draws a single glyph
  90. * @part_changed: do renderer specific processing when rendering
  91. * attributes change
  92. * @begin: Do renderer-specific initialization before drawing
  93. * @end: Do renderer-specific cleanup after drawing
  94. * @prepare_run: updates the renderer for a new run
  95. * @draw_glyph_item: draws a #PangoGlyphItem
  96. *
  97. * Class structure for #PangoRenderer.
  98. *
  99. * Since: 1.8
  100. **/
  101. struct _PangoRendererClass
  102. {
  103. /*< private >*/
  104. GObjectClass parent_class;
  105. /* vtable - not signals */
  106. /*< public >*/
  107. /* All of the following have default implementations
  108. * and take as coordinates user coordinates in Pango units
  109. */
  110. void (*draw_glyphs) (PangoRenderer *renderer,
  111. PangoFont *font,
  112. PangoGlyphString *glyphs,
  113. int x,
  114. int y);
  115. void (*draw_rectangle) (PangoRenderer *renderer,
  116. PangoRenderPart part,
  117. int x,
  118. int y,
  119. int width,
  120. int height);
  121. void (*draw_error_underline) (PangoRenderer *renderer,
  122. int x,
  123. int y,
  124. int width,
  125. int height);
  126. /* Nothing is drawn for shaped glyphs unless this is implemented */
  127. void (*draw_shape) (PangoRenderer *renderer,
  128. PangoAttrShape *attr,
  129. int x,
  130. int y);
  131. /* These two must be implemented and take coordinates in
  132. * device space as doubles.
  133. */
  134. void (*draw_trapezoid) (PangoRenderer *renderer,
  135. PangoRenderPart part,
  136. double y1_,
  137. double x11,
  138. double x21,
  139. double y2,
  140. double x12,
  141. double x22);
  142. void (*draw_glyph) (PangoRenderer *renderer,
  143. PangoFont *font,
  144. PangoGlyph glyph,
  145. double x,
  146. double y);
  147. /* Notification of change in rendering attributes
  148. */
  149. void (*part_changed) (PangoRenderer *renderer,
  150. PangoRenderPart part);
  151. /* Paired around drawing operations
  152. */
  153. void (*begin) (PangoRenderer *renderer);
  154. void (*end) (PangoRenderer *renderer);
  155. /* Hooks into the details of layout rendering
  156. */
  157. void (*prepare_run) (PangoRenderer *renderer,
  158. PangoLayoutRun *run);
  159. /* All of the following have default implementations
  160. * and take as coordinates user coordinates in Pango units
  161. */
  162. void (*draw_glyph_item) (PangoRenderer *renderer,
  163. const char *text,
  164. PangoGlyphItem *glyph_item,
  165. int x,
  166. int y);
  167. /*< private >*/
  168. /* Padding for future expansion */
  169. void (*_pango_reserved2) (void);
  170. void (*_pango_reserved3) (void);
  171. void (*_pango_reserved4) (void);
  172. };
  173. GType pango_renderer_get_type (void) G_GNUC_CONST;
  174. void pango_renderer_draw_layout (PangoRenderer *renderer,
  175. PangoLayout *layout,
  176. int x,
  177. int y);
  178. void pango_renderer_draw_layout_line (PangoRenderer *renderer,
  179. PangoLayoutLine *line,
  180. int x,
  181. int y);
  182. void pango_renderer_draw_glyphs (PangoRenderer *renderer,
  183. PangoFont *font,
  184. PangoGlyphString *glyphs,
  185. int x,
  186. int y);
  187. void pango_renderer_draw_glyph_item (PangoRenderer *renderer,
  188. const char *text,
  189. PangoGlyphItem *glyph_item,
  190. int x,
  191. int y);
  192. void pango_renderer_draw_rectangle (PangoRenderer *renderer,
  193. PangoRenderPart part,
  194. int x,
  195. int y,
  196. int width,
  197. int height);
  198. void pango_renderer_draw_error_underline (PangoRenderer *renderer,
  199. int x,
  200. int y,
  201. int width,
  202. int height);
  203. void pango_renderer_draw_trapezoid (PangoRenderer *renderer,
  204. PangoRenderPart part,
  205. double y1_,
  206. double x11,
  207. double x21,
  208. double y2,
  209. double x12,
  210. double x22);
  211. void pango_renderer_draw_glyph (PangoRenderer *renderer,
  212. PangoFont *font,
  213. PangoGlyph glyph,
  214. double x,
  215. double y);
  216. void pango_renderer_activate (PangoRenderer *renderer);
  217. void pango_renderer_deactivate (PangoRenderer *renderer);
  218. void pango_renderer_part_changed (PangoRenderer *renderer,
  219. PangoRenderPart part);
  220. void pango_renderer_set_color (PangoRenderer *renderer,
  221. PangoRenderPart part,
  222. const PangoColor *color);
  223. PangoColor *pango_renderer_get_color (PangoRenderer *renderer,
  224. PangoRenderPart part);
  225. void pango_renderer_set_alpha (PangoRenderer *renderer,
  226. PangoRenderPart part,
  227. guint16 alpha);
  228. guint16 pango_renderer_get_alpha (PangoRenderer *renderer,
  229. PangoRenderPart part);
  230. void pango_renderer_set_matrix (PangoRenderer *renderer,
  231. const PangoMatrix *matrix);
  232. const PangoMatrix *pango_renderer_get_matrix (PangoRenderer *renderer);
  233. PangoLayout *pango_renderer_get_layout (PangoRenderer *renderer);
  234. PangoLayoutLine *pango_renderer_get_layout_line (PangoRenderer *renderer);
  235. G_END_DECLS
  236. #endif /* __PANGO_RENDERER_H_ */