forked from enlightenment/efl
Evas font/text: Fixed an issue with asc/desc calculation in text object.
Added font_int asc/desc getters in order to achieve that. Thanks to MinSu Seo for reporting.
This commit is contained in:
parent
7d5583530e
commit
cc4cf77865
|
@ -1,3 +1,8 @@
|
|||
2013-05-10 Tom Hacohen
|
||||
|
||||
* Evas text: Fixed line size calculation when using multiple
|
||||
fonts.
|
||||
|
||||
2013-05-10 ChunEon Park (Hermet)
|
||||
|
||||
* Evas: don't try blend on gl backened if the render option is COPY
|
||||
|
|
1
NEWS
1
NEWS
|
@ -265,3 +265,4 @@ Fixes:
|
|||
* Ecore_Input_Evas: Fix ecore_input_evas didn't check the device id of mouse event
|
||||
* Edje: fix custom states for proxy parts
|
||||
* Evas: Don't try blend on gl backened if the render option is COPY
|
||||
* Evas text: Fixed line size calculation when using multiple fonts.
|
||||
|
|
|
@ -2399,6 +2399,38 @@ _evas_object_text_recalc(Evas_Object *eo_obj, Eina_Unicode *text)
|
|||
|
||||
_evas_object_text_layout(eo_obj, o, text);
|
||||
|
||||
/* Calc ascent/descent. */
|
||||
{
|
||||
Evas_Object_Text_Item *item;
|
||||
|
||||
for (item = o->items ; item ;
|
||||
item = EINA_INLIST_CONTAINER_GET(
|
||||
EINA_INLIST_GET(item)->next, Evas_Object_Text_Item))
|
||||
{
|
||||
int asc = 0, desc = 0;
|
||||
int max_asc = 0, max_desc = 0;
|
||||
|
||||
/* Skip items without meaning full information. */
|
||||
if (!item->text_props.font_instance)
|
||||
continue;
|
||||
|
||||
asc = evas_common_font_instance_ascent_get(item->text_props.font_instance);
|
||||
desc = evas_common_font_instance_descent_get(item->text_props.font_instance);
|
||||
if (asc > o->ascent)
|
||||
o->ascent = asc;
|
||||
if (desc > o->descent)
|
||||
o->descent = desc;
|
||||
|
||||
max_asc = evas_common_font_instance_max_ascent_get(item->text_props.font_instance);
|
||||
max_desc = evas_common_font_instance_max_descent_get(item->text_props.font_instance);
|
||||
|
||||
if (max_asc > o->max_ascent)
|
||||
o->max_ascent = max_asc;
|
||||
if (max_desc > o->max_descent)
|
||||
o->max_descent = max_desc;
|
||||
}
|
||||
}
|
||||
|
||||
if ((o->font) && (o->items))
|
||||
{
|
||||
int w, h;
|
||||
|
|
|
@ -14,6 +14,10 @@ EAPI int evas_common_font_ascent_get (RGBA_Font *fn);
|
|||
EAPI int evas_common_font_descent_get (RGBA_Font *fn);
|
||||
EAPI int evas_common_font_max_ascent_get (RGBA_Font *fn);
|
||||
EAPI int evas_common_font_max_descent_get (RGBA_Font *fn);
|
||||
EAPI int evas_common_font_instance_ascent_get (RGBA_Font_Int *fi);
|
||||
EAPI int evas_common_font_instance_descent_get (RGBA_Font_Int *fi);
|
||||
EAPI int evas_common_font_instance_max_ascent_get (RGBA_Font_Int *fi);
|
||||
EAPI int evas_common_font_instance_max_descent_get (RGBA_Font_Int *fi);
|
||||
EAPI int evas_common_font_get_line_advance (RGBA_Font *fn);
|
||||
|
||||
/* draw */
|
||||
|
|
|
@ -73,36 +73,9 @@ evas_common_font_font_all_unload(void)
|
|||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_ascent_get(RGBA_Font *fn)
|
||||
evas_common_font_instance_ascent_get(RGBA_Font_Int *fi)
|
||||
{
|
||||
int val;
|
||||
RGBA_Font_Int *fi;
|
||||
|
||||
// evas_common_font_size_use(fn);
|
||||
#if 0
|
||||
{
|
||||
Eina_List *l;
|
||||
|
||||
EINA_LIST_FOREACH(fn->fonts, l, fi)
|
||||
{
|
||||
if (!fi->src->ft.face) continue;
|
||||
if (fi->src->current_size != fi->size)
|
||||
{
|
||||
FTLOCK();
|
||||
FT_Activate_Size(fi->ft.size);
|
||||
FTUNLOCK();
|
||||
fi->src->current_size = fi->size;
|
||||
}
|
||||
val = (int)fi->src->ft.face->size->metrics.ascender;
|
||||
if (fi->src->ft.face->units_per_EM == 0)
|
||||
return val;
|
||||
dv = (fi->src->ft.orig_upem * 2048) / fi->src->ft.face->units_per_EM;
|
||||
ret = (val * fi->src->ft.face->size->metrics.y_scale) / (dv * dv);
|
||||
printf(" ==== %p: %i\n", fi, ret);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
fi = fn->fonts->data;
|
||||
evas_common_font_int_reload(fi);
|
||||
if (fi->src->current_size != fi->size)
|
||||
{
|
||||
|
@ -126,13 +99,9 @@ evas_common_font_ascent_get(RGBA_Font *fn)
|
|||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_descent_get(RGBA_Font *fn)
|
||||
evas_common_font_instance_descent_get(RGBA_Font_Int *fi)
|
||||
{
|
||||
int val;
|
||||
RGBA_Font_Int *fi;
|
||||
|
||||
// evas_common_font_size_use(fn);
|
||||
fi = fn->fonts->data;
|
||||
evas_common_font_int_reload(fi);
|
||||
if (fi->src->current_size != fi->size)
|
||||
{
|
||||
|
@ -151,14 +120,11 @@ evas_common_font_descent_get(RGBA_Font *fn)
|
|||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_max_ascent_get(RGBA_Font *fn)
|
||||
evas_common_font_instance_max_ascent_get(RGBA_Font_Int *fi)
|
||||
{
|
||||
int val, dv;
|
||||
int ret;
|
||||
RGBA_Font_Int *fi;
|
||||
|
||||
// evas_common_font_size_use(fn);
|
||||
fi = fn->fonts->data;
|
||||
evas_common_font_int_reload(fi);
|
||||
if (fi->src->current_size != fi->size)
|
||||
{
|
||||
|
@ -181,14 +147,11 @@ evas_common_font_max_ascent_get(RGBA_Font *fn)
|
|||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_max_descent_get(RGBA_Font *fn)
|
||||
evas_common_font_instance_max_descent_get(RGBA_Font_Int *fi)
|
||||
{
|
||||
int val, dv;
|
||||
int ret;
|
||||
RGBA_Font_Int *fi;
|
||||
|
||||
// evas_common_font_size_use(fn);
|
||||
fi = fn->fonts->data;
|
||||
evas_common_font_int_reload(fi);
|
||||
if (fi->src->current_size != fi->size)
|
||||
{
|
||||
|
@ -210,6 +173,34 @@ evas_common_font_max_descent_get(RGBA_Font *fn)
|
|||
return ret;
|
||||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_ascent_get(RGBA_Font *fn)
|
||||
{
|
||||
// evas_common_font_size_use(fn);
|
||||
return evas_common_font_instance_ascent_get(fn->fonts->data);
|
||||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_descent_get(RGBA_Font *fn)
|
||||
{
|
||||
// evas_common_font_size_use(fn);
|
||||
return evas_common_font_instance_descent_get(fn->fonts->data);
|
||||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_max_ascent_get(RGBA_Font *fn)
|
||||
{
|
||||
// evas_common_font_size_use(fn);
|
||||
return evas_common_font_instance_max_ascent_get(fn->fonts->data);
|
||||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_max_descent_get(RGBA_Font *fn)
|
||||
{
|
||||
// evas_common_font_size_use(fn);
|
||||
return evas_common_font_instance_max_descent_get(fn->fonts->data);
|
||||
}
|
||||
|
||||
EAPI int
|
||||
evas_common_font_get_line_advance(RGBA_Font *fn)
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue