pango-layout.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430
  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. PANGO_AVAILABLE_IN_ALL
  126. GType pango_layout_get_type (void) G_GNUC_CONST;
  127. PANGO_AVAILABLE_IN_ALL
  128. PangoLayout *pango_layout_new (PangoContext *context);
  129. PANGO_AVAILABLE_IN_ALL
  130. PangoLayout *pango_layout_copy (PangoLayout *src);
  131. PANGO_AVAILABLE_IN_ALL
  132. PangoContext *pango_layout_get_context (PangoLayout *layout);
  133. PANGO_AVAILABLE_IN_ALL
  134. void pango_layout_set_attributes (PangoLayout *layout,
  135. PangoAttrList *attrs);
  136. PANGO_AVAILABLE_IN_ALL
  137. PangoAttrList *pango_layout_get_attributes (PangoLayout *layout);
  138. PANGO_AVAILABLE_IN_ALL
  139. void pango_layout_set_text (PangoLayout *layout,
  140. const char *text,
  141. int length);
  142. PANGO_AVAILABLE_IN_ALL
  143. const char *pango_layout_get_text (PangoLayout *layout);
  144. PANGO_AVAILABLE_IN_1_30
  145. gint pango_layout_get_character_count (PangoLayout *layout);
  146. PANGO_AVAILABLE_IN_ALL
  147. void pango_layout_set_markup (PangoLayout *layout,
  148. const char *markup,
  149. int length);
  150. PANGO_AVAILABLE_IN_ALL
  151. void pango_layout_set_markup_with_accel (PangoLayout *layout,
  152. const char *markup,
  153. int length,
  154. gunichar accel_marker,
  155. gunichar *accel_char);
  156. PANGO_AVAILABLE_IN_ALL
  157. void pango_layout_set_font_description (PangoLayout *layout,
  158. const PangoFontDescription *desc);
  159. PANGO_AVAILABLE_IN_1_8
  160. const PangoFontDescription *pango_layout_get_font_description (PangoLayout *layout);
  161. PANGO_AVAILABLE_IN_ALL
  162. void pango_layout_set_width (PangoLayout *layout,
  163. int width);
  164. PANGO_AVAILABLE_IN_ALL
  165. int pango_layout_get_width (PangoLayout *layout);
  166. PANGO_AVAILABLE_IN_1_20
  167. void pango_layout_set_height (PangoLayout *layout,
  168. int height);
  169. PANGO_AVAILABLE_IN_1_20
  170. int pango_layout_get_height (PangoLayout *layout);
  171. PANGO_AVAILABLE_IN_ALL
  172. void pango_layout_set_wrap (PangoLayout *layout,
  173. PangoWrapMode wrap);
  174. PANGO_AVAILABLE_IN_ALL
  175. PangoWrapMode pango_layout_get_wrap (PangoLayout *layout);
  176. PANGO_AVAILABLE_IN_1_16
  177. gboolean pango_layout_is_wrapped (PangoLayout *layout);
  178. PANGO_AVAILABLE_IN_ALL
  179. void pango_layout_set_indent (PangoLayout *layout,
  180. int indent);
  181. PANGO_AVAILABLE_IN_ALL
  182. int pango_layout_get_indent (PangoLayout *layout);
  183. PANGO_AVAILABLE_IN_ALL
  184. void pango_layout_set_spacing (PangoLayout *layout,
  185. int spacing);
  186. PANGO_AVAILABLE_IN_ALL
  187. int pango_layout_get_spacing (PangoLayout *layout);
  188. PANGO_AVAILABLE_IN_ALL
  189. void pango_layout_set_justify (PangoLayout *layout,
  190. gboolean justify);
  191. PANGO_AVAILABLE_IN_ALL
  192. gboolean pango_layout_get_justify (PangoLayout *layout);
  193. PANGO_AVAILABLE_IN_1_4
  194. void pango_layout_set_auto_dir (PangoLayout *layout,
  195. gboolean auto_dir);
  196. PANGO_AVAILABLE_IN_1_4
  197. gboolean pango_layout_get_auto_dir (PangoLayout *layout);
  198. PANGO_AVAILABLE_IN_ALL
  199. void pango_layout_set_alignment (PangoLayout *layout,
  200. PangoAlignment alignment);
  201. PANGO_AVAILABLE_IN_ALL
  202. PangoAlignment pango_layout_get_alignment (PangoLayout *layout);
  203. PANGO_AVAILABLE_IN_ALL
  204. void pango_layout_set_tabs (PangoLayout *layout,
  205. PangoTabArray *tabs);
  206. PANGO_AVAILABLE_IN_ALL
  207. PangoTabArray* pango_layout_get_tabs (PangoLayout *layout);
  208. PANGO_AVAILABLE_IN_ALL
  209. void pango_layout_set_single_paragraph_mode (PangoLayout *layout,
  210. gboolean setting);
  211. PANGO_AVAILABLE_IN_ALL
  212. gboolean pango_layout_get_single_paragraph_mode (PangoLayout *layout);
  213. PANGO_AVAILABLE_IN_1_6
  214. void pango_layout_set_ellipsize (PangoLayout *layout,
  215. PangoEllipsizeMode ellipsize);
  216. PANGO_AVAILABLE_IN_1_6
  217. PangoEllipsizeMode pango_layout_get_ellipsize (PangoLayout *layout);
  218. PANGO_AVAILABLE_IN_1_16
  219. gboolean pango_layout_is_ellipsized (PangoLayout *layout);
  220. PANGO_AVAILABLE_IN_1_16
  221. int pango_layout_get_unknown_glyphs_count (PangoLayout *layout);
  222. PANGO_AVAILABLE_IN_ALL
  223. void pango_layout_context_changed (PangoLayout *layout);
  224. PANGO_AVAILABLE_IN_1_32
  225. guint pango_layout_get_serial (PangoLayout *layout);
  226. PANGO_AVAILABLE_IN_ALL
  227. void pango_layout_get_log_attrs (PangoLayout *layout,
  228. PangoLogAttr **attrs,
  229. gint *n_attrs);
  230. PANGO_AVAILABLE_IN_1_30
  231. const PangoLogAttr *pango_layout_get_log_attrs_readonly (PangoLayout *layout,
  232. gint *n_attrs);
  233. PANGO_AVAILABLE_IN_ALL
  234. void pango_layout_index_to_pos (PangoLayout *layout,
  235. int index_,
  236. PangoRectangle *pos);
  237. PANGO_AVAILABLE_IN_ALL
  238. void pango_layout_index_to_line_x (PangoLayout *layout,
  239. int index_,
  240. gboolean trailing,
  241. int *line,
  242. int *x_pos);
  243. PANGO_AVAILABLE_IN_ALL
  244. void pango_layout_get_cursor_pos (PangoLayout *layout,
  245. int index_,
  246. PangoRectangle *strong_pos,
  247. PangoRectangle *weak_pos);
  248. PANGO_AVAILABLE_IN_ALL
  249. void pango_layout_move_cursor_visually (PangoLayout *layout,
  250. gboolean strong,
  251. int old_index,
  252. int old_trailing,
  253. int direction,
  254. int *new_index,
  255. int *new_trailing);
  256. PANGO_AVAILABLE_IN_ALL
  257. gboolean pango_layout_xy_to_index (PangoLayout *layout,
  258. int x,
  259. int y,
  260. int *index_,
  261. int *trailing);
  262. PANGO_AVAILABLE_IN_ALL
  263. void pango_layout_get_extents (PangoLayout *layout,
  264. PangoRectangle *ink_rect,
  265. PangoRectangle *logical_rect);
  266. PANGO_AVAILABLE_IN_ALL
  267. void pango_layout_get_pixel_extents (PangoLayout *layout,
  268. PangoRectangle *ink_rect,
  269. PangoRectangle *logical_rect);
  270. PANGO_AVAILABLE_IN_ALL
  271. void pango_layout_get_size (PangoLayout *layout,
  272. int *width,
  273. int *height);
  274. PANGO_AVAILABLE_IN_ALL
  275. void pango_layout_get_pixel_size (PangoLayout *layout,
  276. int *width,
  277. int *height);
  278. PANGO_AVAILABLE_IN_1_22
  279. int pango_layout_get_baseline (PangoLayout *layout);
  280. PANGO_AVAILABLE_IN_ALL
  281. int pango_layout_get_line_count (PangoLayout *layout);
  282. PANGO_AVAILABLE_IN_ALL
  283. PangoLayoutLine *pango_layout_get_line (PangoLayout *layout,
  284. int line);
  285. PANGO_AVAILABLE_IN_1_16
  286. PangoLayoutLine *pango_layout_get_line_readonly (PangoLayout *layout,
  287. int line);
  288. PANGO_AVAILABLE_IN_ALL
  289. GSList * pango_layout_get_lines (PangoLayout *layout);
  290. PANGO_AVAILABLE_IN_1_16
  291. GSList * pango_layout_get_lines_readonly (PangoLayout *layout);
  292. #define PANGO_TYPE_LAYOUT_LINE (pango_layout_line_get_type ())
  293. PANGO_AVAILABLE_IN_ALL
  294. GType pango_layout_line_get_type (void) G_GNUC_CONST;
  295. PANGO_AVAILABLE_IN_1_10
  296. PangoLayoutLine *pango_layout_line_ref (PangoLayoutLine *line);
  297. PANGO_AVAILABLE_IN_ALL
  298. void pango_layout_line_unref (PangoLayoutLine *line);
  299. PANGO_AVAILABLE_IN_ALL
  300. gboolean pango_layout_line_x_to_index (PangoLayoutLine *line,
  301. int x_pos,
  302. int *index_,
  303. int *trailing);
  304. PANGO_AVAILABLE_IN_ALL
  305. void pango_layout_line_index_to_x (PangoLayoutLine *line,
  306. int index_,
  307. gboolean trailing,
  308. int *x_pos);
  309. PANGO_AVAILABLE_IN_ALL
  310. void pango_layout_line_get_x_ranges (PangoLayoutLine *line,
  311. int start_index,
  312. int end_index,
  313. int **ranges,
  314. int *n_ranges);
  315. PANGO_AVAILABLE_IN_ALL
  316. void pango_layout_line_get_extents (PangoLayoutLine *line,
  317. PangoRectangle *ink_rect,
  318. PangoRectangle *logical_rect);
  319. PANGO_AVAILABLE_IN_ALL
  320. void pango_layout_line_get_pixel_extents (PangoLayoutLine *layout_line,
  321. PangoRectangle *ink_rect,
  322. PangoRectangle *logical_rect);
  323. typedef struct _PangoLayoutIter PangoLayoutIter;
  324. #define PANGO_TYPE_LAYOUT_ITER (pango_layout_iter_get_type ())
  325. PANGO_AVAILABLE_IN_ALL
  326. GType pango_layout_iter_get_type (void) G_GNUC_CONST;
  327. PANGO_AVAILABLE_IN_ALL
  328. PangoLayoutIter *pango_layout_get_iter (PangoLayout *layout);
  329. PANGO_AVAILABLE_IN_1_20
  330. PangoLayoutIter *pango_layout_iter_copy (PangoLayoutIter *iter);
  331. PANGO_AVAILABLE_IN_ALL
  332. void pango_layout_iter_free (PangoLayoutIter *iter);
  333. PANGO_AVAILABLE_IN_ALL
  334. int pango_layout_iter_get_index (PangoLayoutIter *iter);
  335. PANGO_AVAILABLE_IN_ALL
  336. PangoLayoutRun *pango_layout_iter_get_run (PangoLayoutIter *iter);
  337. PANGO_AVAILABLE_IN_1_16
  338. PangoLayoutRun *pango_layout_iter_get_run_readonly (PangoLayoutIter *iter);
  339. PANGO_AVAILABLE_IN_ALL
  340. PangoLayoutLine *pango_layout_iter_get_line (PangoLayoutIter *iter);
  341. PANGO_AVAILABLE_IN_1_16
  342. PangoLayoutLine *pango_layout_iter_get_line_readonly (PangoLayoutIter *iter);
  343. PANGO_AVAILABLE_IN_ALL
  344. gboolean pango_layout_iter_at_last_line (PangoLayoutIter *iter);
  345. PANGO_AVAILABLE_IN_1_20
  346. PangoLayout *pango_layout_iter_get_layout (PangoLayoutIter *iter);
  347. PANGO_AVAILABLE_IN_ALL
  348. gboolean pango_layout_iter_next_char (PangoLayoutIter *iter);
  349. PANGO_AVAILABLE_IN_ALL
  350. gboolean pango_layout_iter_next_cluster (PangoLayoutIter *iter);
  351. PANGO_AVAILABLE_IN_ALL
  352. gboolean pango_layout_iter_next_run (PangoLayoutIter *iter);
  353. PANGO_AVAILABLE_IN_ALL
  354. gboolean pango_layout_iter_next_line (PangoLayoutIter *iter);
  355. PANGO_AVAILABLE_IN_ALL
  356. void pango_layout_iter_get_char_extents (PangoLayoutIter *iter,
  357. PangoRectangle *logical_rect);
  358. PANGO_AVAILABLE_IN_ALL
  359. void pango_layout_iter_get_cluster_extents (PangoLayoutIter *iter,
  360. PangoRectangle *ink_rect,
  361. PangoRectangle *logical_rect);
  362. PANGO_AVAILABLE_IN_ALL
  363. void pango_layout_iter_get_run_extents (PangoLayoutIter *iter,
  364. PangoRectangle *ink_rect,
  365. PangoRectangle *logical_rect);
  366. PANGO_AVAILABLE_IN_ALL
  367. void pango_layout_iter_get_line_extents (PangoLayoutIter *iter,
  368. PangoRectangle *ink_rect,
  369. PangoRectangle *logical_rect);
  370. /* All the yranges meet, unlike the logical_rect's (i.e. the yranges
  371. * assign between-line spacing to the nearest line)
  372. */
  373. PANGO_AVAILABLE_IN_ALL
  374. void pango_layout_iter_get_line_yrange (PangoLayoutIter *iter,
  375. int *y0_,
  376. int *y1_);
  377. PANGO_AVAILABLE_IN_ALL
  378. void pango_layout_iter_get_layout_extents (PangoLayoutIter *iter,
  379. PangoRectangle *ink_rect,
  380. PangoRectangle *logical_rect);
  381. PANGO_AVAILABLE_IN_ALL
  382. int pango_layout_iter_get_baseline (PangoLayoutIter *iter);
  383. G_END_DECLS
  384. #endif /* __PANGO_LAYOUT_H__ */