Mercurial > MadButterfly
diff include/mb_shapes.h @ 293:a171b94582ae
Add document for TextField API.
author | wycc |
---|---|
date | Sun, 01 Feb 2009 02:34:24 +0800 |
parents | 7270e368ee98 |
children | 6a1b36738d3d |
line wrap: on
line diff
--- a/include/mb_shapes.h Sun Feb 01 02:14:45 2009 +0800 +++ b/include/mb_shapes.h Sun Feb 01 02:34:24 2009 +0800 @@ -63,7 +63,17 @@ const char *txt, co_aix x, co_aix y, co_aix font_size, cairo_font_face_t *face,PangoAttrList *attrs); +/*! \brief Change the content of the text element. + * In the SVG, the content of a text tag can be composed of several tspan inside it. The Madbutterfly parser will collect all content of a + * text segement as a single string. The attribute of these characters are saved in a seperate data structure. In the program level, we will + * not keep the SVG text tree. Instead, all attributes will be expanded into a list. + * + * When you change the content of a text element, please remember that the attributes will not be removed by the way. You need to change + * them seperately. + * + */ extern void sh_text_set_text(shape_t *shape, const char *txt); + extern void sh_text_transform(shape_t *shape); extern void sh_text_draw(shape_t *shape, cairo_t *cr); /* @} */ @@ -108,12 +118,45 @@ cairo_surface_t *surface; } mb_text_t; +/*! \brief Change the style of the text. + * + * This function can add a couple of attributes to a segment of text or the whole text field. If the @end is -1, the attributes + * will be applied to the whole text field. The @style should be initialized by using the mb_textstyle_xxx functions. All attributes + * which is not initialized will not be changed. It means that the @style will be added into all existing style instead of reaplcing + * it. + */ extern void sh_text_set_style(shape_t *shape,int begin,int end,mb_textstyle_t *format); +/*! \brief Change the color of the text field + * Change the color of the whole text field. This will removed all existing color attribute. If you want to change part of the text + * field only, please use the sh_text_set_style instead. + */ extern void sh_text_set_color(shape_t *shape, unsigned color); +/*! \brief Turn on/off the bold attribute. + * Turn on/off the font weight of the whole text field. This will removed all existing bold setting. If you want to change part of the text + * field only, please use the sh_text_set_style instead. + */ extern void sh_text_set_bold(shape_t *shape, int bold); +/*! \brief Turn on/off the italic attribute. + * Turn on/off the italic of the whole text field. This will removed all existing italic setting. If you want to change part of the text + * field only, please use the sh_text_set_style instead. + */ extern void sh_text_set_italic(shape_t *shape, int italic); +/*! \brief Turn on/off the underline attribute. + * Turn on/off the underline of the whole text field. This will removed all existing underline setting. If you want to change part of the text + * field only, please use the sh_text_set_style instead. + */ extern void sh_text_set_underline(shape_t *shape, int underline); +/*! \brief Change the font of the text field. + * Change the font of the whole text field. This will removed all existing underline setting. If you want to change part of the text + * field only, please use the sh_text_set_style instead. + */ extern void sh_text_set_font(shape_t *shape, char *family); +/*! \brief Init the text style data structure. + * + * This is usually used to initialize the mb_textstyle_t which is allocate in the stack. It will mark all property as undefined. All undefined + * property will not change when the sh_text_set_style is called. + * + */ static inline void mb_textstyle_init(mb_textstyle_t *style) { style->property = 0;