diff src/shape_stext.c @ 397:55f38c2cdb8f

Refactor function of computing text extents
author Thinker K.F. Li <thinker@branda.to>
date Thu, 11 Jun 2009 08:20:39 +0800
parents 7fe0b1ee92b6
children aee0f66b1154
line wrap: on
line diff
--- a/src/shape_stext.c	Wed Jun 10 22:46:13 2009 +0800
+++ b/src/shape_stext.c	Thu Jun 11 08:20:39 2009 +0800
@@ -36,6 +36,8 @@
 
 #define MBE_GET_X_ADV(ext) ((ext)->x_advance)
 #define MBE_GET_Y_ADV(ext) ((ext)->y_advance)
+#define MBE_GET_X_BEARING(ext) ((ext)->x_bearing)
+#define MBE_GET_Y_BEARING(ext) ((ext)->y_bearing)
 #define MBE_GET_WIDTH(ext) ((ext)->width)
 #define MBE_GET_HEIGHT(ext) ((ext)->height)
 
@@ -131,8 +133,8 @@
  * user space of cairo surface.
  */
 static
-mb_scaled_font_t *get_cairo_scaled_font(mb_font_face_t *face,
-					co_aix *matrix) {
+mb_scaled_font_t *make_scaled_font_face_matrix(mb_font_face_t *face,
+					       co_aix *matrix) {
     cairo_font_face_t *scaled_font;
     cairo_matrix_t font_matrix;
     static cairo_matir_t id = {
@@ -164,13 +166,13 @@
 }
 
 static
-void free_scaled_font(mb_scaled_font_t *scaled_font) {
+void scaled_font_free(mb_scaled_font_t *scaled_font) {
     cairo_scaled_font_destroy((cairo_scaled_font_t *)scaled_font);
 }
 
 static
-void text_extents(mb_scaled_font_t *scaled_font, const char *txt,
-		  mb_text_extents_t *extents) {
+void compute_text_extents(mb_scaled_font_t *scaled_font, const char *txt,
+			  mb_text_extents_t *extents) {
     cairo_scaled_font_text_extents((cairo_scaled_font_t *)scaled_font,
 				   txt,
 				   (cairo_text_extents_t *)extents);
@@ -275,82 +277,68 @@
 }
 
 static
-void compute_text_extents(char *txt, int txt_len,
-			 cairo_scaled_font_t *scaled_font,
-			 cairo_text_extents_t *extents) {
-    char saved;
-
-    saved = txt[txt_len];
-    txt[txt_len] = 0;
-    cairo_scaled_font_text_extents(scaled_font, txt, extents);
-    txt[txt_len] = saved;
-}
-
-static
-cairo_scaled_font_t *make_scaled_font_face(sh_stext_t *txt_o,
+mb_scaled_font_t *make_scaled_font_face(sh_stext_t *txt_o,
 					   cairo_font_face_t *face,
 					   co_aix shift_x, co_aix shift_y,
 					   co_aix font_sz) {
-    cairo_matrix_t cmtx;
-    static cairo_matrix_t cid;
-    static cairo_font_options_t *fopt = NULL;
-    co_aix *matrix;
-    cairo_scaled_font_t *scaled;
-    int i;
+    co_aix matrix[6], scaled_matrix[6];
+    co_aix *aggr;
+    mb_scaled_font_t *scaled;
 
-    if(fopt == NULL) {
-	cairo_matrix_init_identify(&cid);
-	fopt = cairo_font_options_create();
-	if(fopt == NULL)
-	    return NULL;
-    }
+    aggr = sh_get_aggr_matrix((shape_t *)txt_o);
+    matrix[0] = font_sz;
+    matrix[1] = 0;
+    matrix[2] = shift_x;
+    matrix[3] = 0;
+    matrix[4] = font_sz;
+    matrix[5] += shift_y;
+    matrix_mul(aggr, matrix, scaled_matrix);
+    
+    scaled = make_scaled_font_face_matrix(face, scaled_matrix);
 
-    matrix = sh_get_aggr_matrix((shape_t *)txt_o);
-    i = 0;
-    cmtx.xx = matrix[i++];
-    cmtx.xy = matrix[i++];
-    cmtx.x0 = matrix[i++] + shift_x;
-    cmtx.yx = matrix[i++];
-    cmtx.yy = matrix[i++];
-    cmtx.y0 = matrix[i] + shift_y;
-    
-    scaled = cairo_scaled_font_create(face, &cmtx, &cid, fopt);
-    
     return scaled;
 }
 
 static
-void compute_extents(sh_stext_t *txt_o) {
-    co_aix adv_x, adv_y;
-    cairo_text_extents_t extents;
+void compute_styled_extents(sh_stext_t *txt_o) {
+    mb_text_extents_t sub_extents, full_extents;
+    mb_text_extents_t *ext;
     mb_style_blk_t *blk;
-    cairo_scaled_font_t *scaled_font;
-    char *txt;
+    int blk_txt_len;
+    mb_scaled_font_t *scaled_font;
+    char *txt, saved;
     co_aix shift_x, shift_y;
-    int blk_txt_len;
     int i;
-
-    adv_x = adv_y = 0;
+    
+    memset(&full_extents, sizeof(mb_text_extents_t), 0);
+    
     blk = txt_o->style_blks;
     scaled_font = txt_o->scaled_fonts;
     txt = (char *)txt_o->txt;
-    shift_x = txt_o->x;
-    shift_y = txt_o->y;
+    ext = &full_extents;
     for(i = 0; i < txt_o->nblks; i++) {
-	*scaled_font = make_scaled_fonts(txt_o, blk->face,
-					 shift_x, shift_y, font_sz);
+	shift_x = txt_o->x + full_extents.x_adv;
+	shift_y = txt_o->y + full_extents.y_adv;
+	
+	*scaled_font = make_scaled_font_face(txt_o, blk->face,
+					     shift_x, shift_y, font_sz);
 	ASSERT(*scaled_font != NULL);
 	
 	blk_txt_len = compute_utf8_chars_sz(txt, blk->n_chars);
 	ASSERT(blk_txt_len != ERR);
 	
-	compute_text_extents(txt, blk_txt_len, *scaled_font, &extents);
-	adv_x += extents.x_advance;
-	adv_y += extents.y_advance;
+	saved = txt[blk_txt_len];
+	txt[blk_txt_len] = 0;
+	compute_text_extents(scaled_font, txt, &extents);
+	txt[blk_txt_len] = saved;
+
+	adv_x += MBE_GET_X_ADV(&extents);
+	adv_y += MBE_GET_Y_ADV(&extents);
 	
 	scaled_font++;
 	blk++;
 	txt += blk_txt_len;
+	ext = &sub_extents;
     }
 }