diff src/shape_stext.c @ 433:099941c3becf

Test cases for ratation on sh_stext
author Thinker K.F. Li <thinker@branda.to>
date Wed, 29 Jul 2009 16:35:03 +0800
parents 9d5506968efb
children c02d2aa2c45e
line wrap: on
line diff
--- a/src/shape_stext.c	Wed Jul 29 15:03:37 2009 +0800
+++ b/src/shape_stext.c	Wed Jul 29 16:35:03 2009 +0800
@@ -853,6 +853,57 @@
 }
 
 static
+void test_compute_styled_extents_n_scaled_font_rotate(void) {
+    sh_stext_t *txt_o;
+    co_aix *aggr;
+    mb_style_blk_t blks[2];
+    mb_font_face_t *face;
+    mb_text_extents_t *ext;
+    int r;
+
+    txt_o = (sh_stext_t *)rdman_shape_stext_new((redraw_man_t *)NULL,
+						"Hello World", 10, 15);
+    CU_ASSERT(txt_o != NULL);
+
+    aggr = txt_o->shape.aggr;
+    aggr[0] = 1;
+    aggr[1] = 0;
+    aggr[2] = 0;
+    aggr[3] = 1;
+    aggr[4] = 1;
+    aggr[5] = 0;
+
+    face = query_font_face("serif", MB_FONT_SLANT_ROMAN, 100);
+    CU_ASSERT(face != NULL);
+    
+    blks[0].n_chars = 5;
+    blks[0].face = face;
+    blks[0].font_sz = 10;
+    
+    blks[1].n_chars = 4;
+    blks[1].face = face;
+    blks[1].font_sz = 15.5;
+    
+    r = sh_stext_set_style((shape_t *)txt_o, blks, 2);
+    CU_ASSERT(r == OK);
+
+    compute_styled_extents_n_scaled_font(txt_o);
+
+    ext = &txt_o->extents;
+    CU_ASSERT(MBE_GET_HEIGHT(ext) > 47);
+    CU_ASSERT(MBE_GET_HEIGHT(ext) < 92);
+    CU_ASSERT(MBE_GET_WIDTH(ext) > 36);
+    CU_ASSERT(MBE_GET_WIDTH(ext) < 72);
+    CU_ASSERT(MBE_GET_X_ADV(ext) > 36);
+    CU_ASSERT(MBE_GET_X_ADV(ext) < 72);
+    CU_ASSERT(MBE_GET_Y_ADV(ext) > 36);
+    CU_ASSERT(MBE_GET_Y_ADV(ext) < 72);
+    
+    _rdman_shape_stext_free((shape_t *)txt_o);
+    free_font_face(face);
+}
+
+static
 void test_sh_stext_transform(void) {
     sh_stext_t *txt_o;
     mb_style_blk_t blks[2];
@@ -934,6 +985,7 @@
 
     sh_stext_transform((shape_t *)txt_o);
 
+    move_cnt = 0;
     sh_stext_draw((shape_t *)txt_o, NULL);
     CU_ASSERT(move_cnt == 2);
     CU_ASSERT(move_xys[0][0] == 200);
@@ -945,6 +997,54 @@
     free_font_face(face);
 }
 
+static
+void test_sh_stext_draw_rotate(void) {
+    sh_stext_t *txt_o;
+    mb_style_blk_t blks[2];
+    co_aix *aggr;
+    mb_font_face_t *face;
+    area_t *area;
+    int r;
+
+    txt_o = (sh_stext_t *)rdman_shape_stext_new(NULL, "hello world", 100, 50);
+    CU_ASSERT(txt_o != NULL);
+    
+    aggr = txt_o->shape.aggr;
+    aggr[0] = 2;
+    aggr[1] = 0;
+    aggr[2] = 0;
+    aggr[3] = 1;
+    aggr[4] = 1;
+    aggr[5] = 0;
+
+    face = query_font_face("serif", MB_FONT_SLANT_ROMAN, 100);
+    CU_ASSERT(face != NULL);
+    
+    blks[0].n_chars = 5;
+    blks[0].face = face;
+    blks[0].font_sz = 10;
+    
+    blks[1].n_chars = 6;
+    blks[1].face = face;
+    blks[1].font_sz = 15.5;
+    
+    r = sh_stext_set_style((shape_t *)txt_o, blks, 2);
+    CU_ASSERT(r == OK);
+
+    sh_stext_transform((shape_t *)txt_o);
+
+    move_cnt = 0;
+    sh_stext_draw((shape_t *)txt_o, NULL);
+    CU_ASSERT(move_cnt == 2);
+    CU_ASSERT(move_xys[0][0] == 200);
+    CU_ASSERT(move_xys[0][1] == 150);
+    CU_ASSERT(move_xys[1][0] >= 240 && move_xys[1][0] < 270);
+    CU_ASSERT(move_xys[1][1] >= 170 && move_xys[1][1] < 185);
+
+    _rdman_shape_stext_free((shape_t *)txt_o);
+    free_font_face(face);
+}
+
 #include <CUnit/Basic.h>
 CU_pSuite get_stext_suite(void) {
     CU_pSuite suite;
@@ -956,8 +1056,10 @@
     CU_ADD_TEST(suite, test_extent_extents);
     CU_ADD_TEST(suite, test_compute_utf8_chars_sz);
     CU_ADD_TEST(suite, test_compute_styled_extents_n_scaled_font);
+    CU_ADD_TEST(suite, test_compute_styled_extents_n_scaled_font_rotate);
     CU_ADD_TEST(suite, test_sh_stext_transform);
     CU_ADD_TEST(suite, test_sh_stext_draw);
+    CU_ADD_TEST(suite, test_sh_stext_draw_rotate);
 
     return suite;
 }