pango-layout.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  1. /* Pango
  2. * pango-layout.h: High-level layout driver
  3. *
  4. * Copyright (C) 2000 Red Hat Software
  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_LAYOUT_H__
  22. #define __PANGO_LAYOUT_H__
  23. #include <pango/pango-attributes.h>
  24. #include <pango/pango-context.h>
  25. #include <pango/pango-glyph-item.h>
  26. #include <pango/pango-tabs.h>
  27. G_BEGIN_DECLS
  28. typedef struct _PangoLayout PangoLayout;
  29. typedef struct _PangoLayoutClass PangoLayoutClass;
  30. typedef struct _PangoLayoutLine PangoLayoutLine;
  31. /**
  32. * PangoLayoutRun:
  33. *
  34. * The #PangoLayoutRun structure represents a single run within
  35. * a #PangoLayoutLine; it is simply an alternate name for
  36. * #PangoGlyphItem.
  37. * See the #PangoGlyphItem docs for details on the fields.
  38. */
  39. typedef PangoGlyphItem PangoLayoutRun;
  40. /**
  41. * PangoAlignment:
  42. * @PANGO_ALIGN_LEFT: Put all available space on the right
  43. * @PANGO_ALIGN_CENTER: Center the line within the available space
  44. * @PANGO_ALIGN_RIGHT: Put all available space on the left
  45. *
  46. * A #PangoAlignment describes how to align the lines of a #PangoLayout within the
  47. * available space. If the #PangoLayout is set to justify
  48. * using pango_layout_set_justify(), this only has effect for partial lines.
  49. */
  50. typedef enum {
  51. PANGO_ALIGN_LEFT,
  52. PANGO_ALIGN_CENTER,
  53. PANGO_ALIGN_RIGHT
  54. } PangoAlignment;
  55. /**
  56. * PangoWrapMode:
  57. * @PANGO_WRAP_WORD: wrap lines at word boundaries.
  58. * @PANGO_WRAP_CHAR: wrap lines at character boundaries.
  59. * @PANGO_WRAP_WORD_CHAR: wrap lines at word boundaries, but fall back to character boundaries if there is not
  60. * enough space for a full word.
  61. *
  62. * A #PangoWrapMode describes how to wrap the lines of a #PangoLayout to the desired width.
  63. */
  64. typedef enum {
  65. PANGO_WRAP_WORD,
  66. PANGO_WRAP_CHAR,
  67. PANGO_WRAP_WORD_CHAR
  68. } PangoWrapMode;
  69. /**
  70. * PangoEllipsizeMode:
  71. * @PANGO_ELLIPSIZE_NONE: No ellipsization
  72. * @PANGO_ELLIPSIZE_START: Omit characters at the start of the text
  73. * @PANGO_ELLIPSIZE_MIDDLE: Omit characters in the middle of the text
  74. * @PANGO_ELLIPSIZE_END: Omit characters at the end of the text
  75. *
  76. * The #PangoEllipsizeMode type describes what sort of (if any)
  77. * ellipsization should be applied to a line of text. In
  78. * the ellipsization process characters are removed from the
  79. * text in order to make it fit to a given width and replaced
  80. * with an ellipsis.
  81. */
  82. typedef enum {
  83. PANGO_ELLIPSIZE_NONE,
  84. PANGO_ELLIPSIZE_START,
  85. PANGO_ELLIPSIZE_MIDDLE,
  86. PANGO_ELLIPSIZE_END
  87. } PangoEllipsizeMode;
  88. /**
  89. * PangoLayoutLine:
  90. * @layout: (allow-none): the layout this line belongs to, might be %NULL
  91. * @start_index: start of line as byte index into layout->text
  92. * @length: length of line in bytes
  93. * @runs: (allow-none) (element-type: Pango.LayoutRun): list of runs in the
  94. * line, from left to right
  95. * @is_paragraph_start: #TRUE if this is the first line of the paragraph
  96. * @resolved_dir: #Resolved PangoDirection of line
  97. *
  98. * The #PangoLayoutLine structure represents one of the lines resulting
  99. * from laying out a paragraph via #PangoLayout. #PangoLayoutLine
  100. * structures are obtained by calling pango_layout_get_line() and
  101. * are only valid until the text, attributes, or settings of the
  102. * parent #PangoLayout are modified.
  103. *
  104. * Routines for rendering PangoLayout objects are provided in
  105. * code specific to each rendering system.
  106. */
  107. struct _PangoLayoutLine
  108. {
  109. PangoLayout *layout;
  110. gint start_index; /* start of line as byte index into layout->text */
  111. gint length; /* length of line in bytes */
  112. GSList *runs;
  113. guint is_paragraph_start : 1; /* TRUE if this is the first line of the paragraph */
  114. guint resolved_dir : 3; /* Resolved PangoDirection of line */
  115. };
  116. #define PANGO_TYPE_LAYOUT (pango_layout_get_type ())
  117. #define PANGO_LAYOUT(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_LAYOUT, PangoLayout))
  118. #define PANGO_LAYOUT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_LAYOUT, PangoLayoutClass))
  119. #define PANGO_IS_LAYOUT(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_LAYOUT))
  120. #define PANGO_IS_LAYOUT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_LAYOUT))
  121. #define PANGO_LAYOUT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_LAYOUT, PangoLayoutClass))
  122. /* The PangoLayout and PangoLayoutClass structs are private; if you
  123. * need to create a subclass of these, file a bug.
  124. */
  125. GType pango_layout_get_type (void) G_GNUC_CONST;
  126. PangoLayout *pango_layout_new (PangoContext *context);
  127. PangoLayout *pango_layout_copy (PangoLayout *src);
  128. PangoContext *pango_layout_get_context (PangoLayout *layout);
  129. void pango_layout_set_attributes (PangoLayout *layout,
  130. PangoAttrList *attrs);
  131. PangoAttrList *pango_layout_get_attributes (PangoLayout *layout);
  132. void pango_layout_set_text (PangoLayout *layout,
  133. const char *text,
  134. int length);
  135. const char *pango_layout_get_text (PangoLayout *layout);
  136. gint pango_layout_get_character_count (PangoLayout *layout);
  137. void pango_layout_set_markup (PangoLayout *layout,
  138. const char *markup,
  139. int length);
  140. void pango_layout_set_markup_with_accel (PangoLayout *layout,
  141. const char *markup,
  142. int length,
  143. gunichar accel_marker,
  144. gunichar *accel_char);
  145. void pango_layout_set_font_description (PangoLayout *layout,
  146. const PangoFontDescription *desc);
  147. const PangoFontDescription *pango_layout_get_font_description (PangoLayout *layout);
  148. void pango_layout_set_width (PangoLayout *layout,
  149. int width);
  150. int pango_layout_get_width (PangoLayout *layout);
  151. void pango_layout_set_height (PangoLayout *layout,
  152. int height);
  153. int pango_layout_get_height (PangoLayout *layout);
  154. void pango_layout_set_wrap (PangoLayout *layout,
  155. PangoWrapMode wrap);
  156. PangoWrapMode pango_layout_get_wrap (PangoLayout *layout);
  157. gboolean pango_layout_is_wrapped (PangoLayout *layout);
  158. void pango_layout_set_indent (PangoLayout *layout,
  159. int indent);
  160. int pango_layout_get_indent (PangoLayout *layout);
  161. void pango_layout_set_spacing (PangoLayout *layout,
  162. int spacing);
  163. int pango_layout_get_spacing (PangoLayout *layout);
  164. void pango_layout_set_justify (PangoLayout *layout,
  165. gboolean justify);
  166. gboolean pango_layout_get_justify (PangoLayout *layout);
  167. void pango_layout_set_auto_dir (PangoLayout *layout,
  168. gboolean auto_dir);
  169. gboolean pango_layout_get_auto_dir (PangoLayout *layout);
  170. void pango_layout_set_alignment (PangoLayout *layout,
  171. PangoAlignment alignment);
  172. PangoAlignment pango_layout_get_alignment (PangoLayout *layout);
  173. void pango_layout_set_tabs (PangoLayout *layout,
  174. PangoTabArray *tabs);
  175. PangoTabArray* pango_layout_get_tabs (PangoLayout *layout);
  176. void pango_layout_set_single_paragraph_mode (PangoLayout *layout,
  177. gboolean setting);
  178. gboolean pango_layout_get_single_paragraph_mode (PangoLayout *layout);
  179. void pango_layout_set_ellipsize (PangoLayout *layout,
  180. PangoEllipsizeMode ellipsize);
  181. PangoEllipsizeMode pango_layout_get_ellipsize (PangoLayout *layout);
  182. gboolean pango_layout_is_ellipsized (PangoLayout *layout);
  183. int pango_layout_get_unknown_glyphs_count (PangoLayout *layout);
  184. void pango_layout_context_changed (PangoLayout *layout);
  185. guint pango_layout_get_serial (PangoLayout *layout);
  186. void pango_layout_get_log_attrs (PangoLayout *layout,
  187. PangoLogAttr **attrs,
  188. gint *n_attrs);
  189. const PangoLogAttr *pango_layout_get_log_attrs_readonly (PangoLayout *layout,
  190. gint *n_attrs);
  191. void pango_layout_index_to_pos (PangoLayout *layout,
  192. int index_,
  193. PangoRectangle *pos);
  194. void pango_layout_index_to_line_x (PangoLayout *layout,
  195. int index_,
  196. gboolean trailing,
  197. int *line,
  198. int *x_pos);
  199. void pango_layout_get_cursor_pos (PangoLayout *layout,
  200. int index_,
  201. PangoRectangle *strong_pos,
  202. PangoRectangle *weak_pos);
  203. void pango_layout_move_cursor_visually (PangoLayout *layout,
  204. gboolean strong,
  205. int old_index,
  206. int old_trailing,
  207. int direction,
  208. int *new_index,
  209. int *new_trailing);
  210. gboolean pango_layout_xy_to_index (PangoLayout *layout,
  211. int x,
  212. int y,
  213. int *index_,
  214. int *trailing);
  215. void pango_layout_get_extents (PangoLayout *layout,
  216. PangoRectangle *ink_rect,
  217. PangoRectangle *logical_rect);
  218. void pango_layout_get_pixel_extents (PangoLayout *layout,
  219. PangoRectangle *ink_rect,
  220. PangoRectangle *logical_rect);
  221. void pango_layout_get_size (PangoLayout *layout,
  222. int *width,
  223. int *height);
  224. void pango_layout_get_pixel_size (PangoLayout *layout,
  225. int *width,
  226. int *height);
  227. int pango_layout_get_baseline (PangoLayout *layout);
  228. int pango_layout_get_line_count (PangoLayout *layout);
  229. PangoLayoutLine *pango_layout_get_line (PangoLayout *layout,
  230. int line);
  231. PangoLayoutLine *pango_layout_get_line_readonly (PangoLayout *layout,
  232. int line);
  233. GSList * pango_layout_get_lines (PangoLayout *layout);
  234. GSList * pango_layout_get_lines_readonly (PangoLayout *layout);
  235. #define PANGO_TYPE_LAYOUT_LINE (pango_layout_line_get_type ())
  236. GType pango_layout_line_get_type (void) G_GNUC_CONST;
  237. PangoLayoutLine *pango_layout_line_ref (PangoLayoutLine *line);
  238. void pango_layout_line_unref (PangoLayoutLine *line);
  239. gboolean pango_layout_line_x_to_index (PangoLayoutLine *line,
  240. int x_pos,
  241. int *index_,
  242. int *trailing);
  243. void pango_layout_line_index_to_x (PangoLayoutLine *line,
  244. int index_,
  245. gboolean trailing,
  246. int *x_pos);
  247. void pango_layout_line_get_x_ranges (PangoLayoutLine *line,
  248. int start_index,
  249. int end_index,
  250. int **ranges,
  251. int *n_ranges);
  252. void pango_layout_line_get_extents (PangoLayoutLine *line,
  253. PangoRectangle *ink_rect,
  254. PangoRectangle *logical_rect);
  255. void pango_layout_line_get_pixel_extents (PangoLayoutLine *layout_line,
  256. PangoRectangle *ink_rect,
  257. PangoRectangle *logical_rect);
  258. typedef struct _PangoLayoutIter PangoLayoutIter;
  259. #define PANGO_TYPE_LAYOUT_ITER (pango_layout_iter_get_type ())
  260. GType pango_layout_iter_get_type (void) G_GNUC_CONST;
  261. PangoLayoutIter *pango_layout_get_iter (PangoLayout *layout);
  262. PangoLayoutIter *pango_layout_iter_copy (PangoLayoutIter *iter);
  263. void pango_layout_iter_free (PangoLayoutIter *iter);
  264. int pango_layout_iter_get_index (PangoLayoutIter *iter);
  265. PangoLayoutRun *pango_layout_iter_get_run (PangoLayoutIter *iter);
  266. PangoLayoutRun *pango_layout_iter_get_run_readonly (PangoLayoutIter *iter);
  267. PangoLayoutLine *pango_layout_iter_get_line (PangoLayoutIter *iter);
  268. PangoLayoutLine *pango_layout_iter_get_line_readonly (PangoLayoutIter *iter);
  269. gboolean pango_layout_iter_at_last_line (PangoLayoutIter *iter);
  270. PangoLayout *pango_layout_iter_get_layout (PangoLayoutIter *iter);
  271. gboolean pango_layout_iter_next_char (PangoLayoutIter *iter);
  272. gboolean pango_layout_iter_next_cluster (PangoLayoutIter *iter);
  273. gboolean pango_layout_iter_next_run (PangoLayoutIter *iter);
  274. gboolean pango_layout_iter_next_line (PangoLayoutIter *iter);
  275. void pango_layout_iter_get_char_extents (PangoLayoutIter *iter,
  276. PangoRectangle *logical_rect);
  277. void pango_layout_iter_get_cluster_extents (PangoLayoutIter *iter,
  278. PangoRectangle *ink_rect,
  279. PangoRectangle *logical_rect);
  280. void pango_layout_iter_get_run_extents (PangoLayoutIter *iter,
  281. PangoRectangle *ink_rect,
  282. PangoRectangle *logical_rect);
  283. void pango_layout_iter_get_line_extents (PangoLayoutIter *iter,
  284. PangoRectangle *ink_rect,
  285. PangoRectangle *logical_rect);
  286. /* All the yranges meet, unlike the logical_rect's (i.e. the yranges
  287. * assign between-line spacing to the nearest line)
  288. */
  289. void pango_layout_iter_get_line_yrange (PangoLayoutIter *iter,
  290. int *y0_,
  291. int *y1_);
  292. void pango_layout_iter_get_layout_extents (PangoLayoutIter *iter,
  293. PangoRectangle *ink_rect,
  294. PangoRectangle *logical_rect);
  295. int pango_layout_iter_get_baseline (PangoLayoutIter *iter);
  296. G_END_DECLS
  297. #endif /* __PANGO_LAYOUT_H__ */