forked from enlightenment/efl
* edje: Fix embryo with fixed point and table align.
SVN revision: 44794
This commit is contained in:
parent
edf90cc827
commit
6ce037b8a3
|
@ -1480,7 +1480,7 @@ static void
|
||||||
_edje_table_recalc_apply(Edje *ed __UNUSED__, Edje_Real_Part *ep, Edje_Calc_Params *p3 __UNUSED__, Edje_Part_Description *chosen_desc)
|
_edje_table_recalc_apply(Edje *ed __UNUSED__, Edje_Real_Part *ep, Edje_Calc_Params *p3 __UNUSED__, Edje_Part_Description *chosen_desc)
|
||||||
{
|
{
|
||||||
evas_object_table_homogeneous_set(ep->object, chosen_desc->table.homogeneous);
|
evas_object_table_homogeneous_set(ep->object, chosen_desc->table.homogeneous);
|
||||||
evas_object_table_align_set(ep->object, chosen_desc->table.align.x, chosen_desc->table.align.y);
|
evas_object_table_align_set(ep->object, TO_DOUBLE(chosen_desc->table.align.x), TO_DOUBLE(chosen_desc->table.align.y));
|
||||||
evas_object_table_padding_set(ep->object, chosen_desc->table.padding.x, chosen_desc->table.padding.y);
|
evas_object_table_padding_set(ep->object, chosen_desc->table.padding.x, chosen_desc->table.padding.y);
|
||||||
if (evas_object_smart_need_recalculate_get(ep->object))
|
if (evas_object_smart_need_recalculate_get(ep->object))
|
||||||
{
|
{
|
||||||
|
|
|
@ -1633,8 +1633,8 @@ _edje_embryo_fn_set_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
case EDJE_STATE_PARAM_ALIGNMENT:
|
case EDJE_STATE_PARAM_ALIGNMENT:
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
GETFLOAT(rp->custom->description->align.x, params[3]);
|
GETFLOAT_T(rp->custom->description->align.x, params[3]);
|
||||||
GETFLOAT(rp->custom->description->align.y, params[4]);
|
GETFLOAT_T(rp->custom->description->align.y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_MIN:
|
case EDJE_STATE_PARAM_MIN:
|
||||||
|
@ -1659,21 +1659,12 @@ _edje_embryo_fn_set_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_ASPECT:
|
case EDJE_STATE_PARAM_ASPECT:
|
||||||
{
|
CHKPARAM(4);
|
||||||
double tmp;
|
|
||||||
|
|
||||||
CHKPARAM(4);
|
GETFLOAT_T(rp->custom->description->aspect.min, params[3]);
|
||||||
|
GETFLOAT_T(rp->custom->description->aspect.max, params[4]);
|
||||||
|
|
||||||
tmp = TO_DOUBLE(rp->custom->description->aspect.min);
|
break;
|
||||||
GETFLOAT(tmp, params[3]);
|
|
||||||
rp->custom->description->aspect.min = FROM_DOUBLE(tmp);
|
|
||||||
|
|
||||||
tmp = TO_DOUBLE(rp->custom->description->aspect.max);
|
|
||||||
GETFLOAT(tmp, params[4]);
|
|
||||||
rp->custom->description->aspect.max = FROM_DOUBLE(tmp);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case EDJE_STATE_PARAM_ASPECT_PREF:
|
case EDJE_STATE_PARAM_ASPECT_PREF:
|
||||||
CHKPARAM(3);
|
CHKPARAM(3);
|
||||||
|
|
||||||
|
@ -1717,8 +1708,8 @@ _edje_embryo_fn_set_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
case EDJE_STATE_PARAM_REL1:
|
case EDJE_STATE_PARAM_REL1:
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
GETFLOAT(rp->custom->description->rel1.relative_x, params[3]);
|
GETFLOAT_T(rp->custom->description->rel1.relative_x, params[3]);
|
||||||
GETFLOAT(rp->custom->description->rel1.relative_y, params[4]);
|
GETFLOAT_T(rp->custom->description->rel1.relative_y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_REL1_TO:
|
case EDJE_STATE_PARAM_REL1_TO:
|
||||||
|
@ -1743,8 +1734,8 @@ _edje_embryo_fn_set_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
case EDJE_STATE_PARAM_REL2:
|
case EDJE_STATE_PARAM_REL2:
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
GETFLOAT(rp->custom->description->rel2.relative_x, params[3]);
|
GETFLOAT_T(rp->custom->description->rel2.relative_x, params[3]);
|
||||||
GETFLOAT(rp->custom->description->rel2.relative_y, params[4]);
|
GETFLOAT_T(rp->custom->description->rel2.relative_y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_REL2_TO:
|
case EDJE_STATE_PARAM_REL2_TO:
|
||||||
|
@ -1794,8 +1785,8 @@ _edje_embryo_fn_set_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
||||||
CHKPARAM(6);
|
CHKPARAM(6);
|
||||||
|
|
||||||
GETFLOAT(rp->custom->description->fill.pos_rel_x, params[3]);
|
GETFLOAT_T(rp->custom->description->fill.pos_rel_x, params[3]);
|
||||||
GETFLOAT(rp->custom->description->fill.pos_rel_y, params[4]);
|
GETFLOAT_T(rp->custom->description->fill.pos_rel_y, params[4]);
|
||||||
GETINT(rp->custom->description->fill.pos_abs_x, params[5]);
|
GETINT(rp->custom->description->fill.pos_abs_x, params[5]);
|
||||||
GETINT(rp->custom->description->fill.pos_abs_y, params[6]);
|
GETINT(rp->custom->description->fill.pos_abs_y, params[6]);
|
||||||
|
|
||||||
|
@ -1804,8 +1795,8 @@ _edje_embryo_fn_set_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
||||||
CHKPARAM(6);
|
CHKPARAM(6);
|
||||||
|
|
||||||
GETFLOAT(rp->custom->description->fill.rel_x, params[3]);
|
GETFLOAT_T(rp->custom->description->fill.rel_x, params[3]);
|
||||||
GETFLOAT(rp->custom->description->fill.rel_y, params[4]);
|
GETFLOAT_T(rp->custom->description->fill.rel_y, params[4]);
|
||||||
GETINT(rp->custom->description->fill.abs_x, params[5]);
|
GETINT(rp->custom->description->fill.abs_x, params[5]);
|
||||||
GETINT(rp->custom->description->fill.abs_y, params[6]);
|
GETINT(rp->custom->description->fill.abs_y, params[6]);
|
||||||
|
|
||||||
|
@ -1885,8 +1876,8 @@ _edje_embryo_fn_set_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
if ((rp->part->type != EDJE_PART_TYPE_TEXT)) return 0;
|
if ((rp->part->type != EDJE_PART_TYPE_TEXT)) return 0;
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
GETFLOAT(rp->custom->description->text.align.x, params[3]);
|
GETFLOAT_T(rp->custom->description->text.align.x, params[3]);
|
||||||
GETFLOAT(rp->custom->description->text.align.y, params[4]);
|
GETFLOAT_T(rp->custom->description->text.align.y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_VISIBLE:
|
case EDJE_STATE_PARAM_VISIBLE:
|
||||||
|
@ -1933,8 +1924,8 @@ _edje_embryo_fn_get_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
case EDJE_STATE_PARAM_ALIGNMENT:
|
case EDJE_STATE_PARAM_ALIGNMENT:
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
SETFLOAT(rp->custom->description->align.x, params[3]);
|
SETFLOAT_T(rp->custom->description->align.x, params[3]);
|
||||||
SETFLOAT(rp->custom->description->align.y, params[4]);
|
SETFLOAT_T(rp->custom->description->align.y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_MIN:
|
case EDJE_STATE_PARAM_MIN:
|
||||||
|
@ -1961,8 +1952,8 @@ _edje_embryo_fn_get_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
case EDJE_STATE_PARAM_ASPECT:
|
case EDJE_STATE_PARAM_ASPECT:
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
SETFLOAT(TO_DOUBLE(rp->custom->description->aspect.min), params[3]);
|
SETFLOAT_T(rp->custom->description->aspect.min, params[3]);
|
||||||
SETFLOAT(TO_DOUBLE(rp->custom->description->aspect.max), params[4]);
|
SETFLOAT_T(rp->custom->description->aspect.max, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_ASPECT_PREF:
|
case EDJE_STATE_PARAM_ASPECT_PREF:
|
||||||
|
@ -2008,8 +1999,8 @@ _edje_embryo_fn_get_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
case EDJE_STATE_PARAM_REL1:
|
case EDJE_STATE_PARAM_REL1:
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
SETFLOAT(rp->custom->description->rel1.relative_x, params[3]);
|
SETFLOAT_T(rp->custom->description->rel1.relative_x, params[3]);
|
||||||
SETFLOAT(rp->custom->description->rel1.relative_y, params[4]);
|
SETFLOAT_T(rp->custom->description->rel1.relative_y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_REL1_TO:
|
case EDJE_STATE_PARAM_REL1_TO:
|
||||||
|
@ -2029,8 +2020,8 @@ _edje_embryo_fn_get_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
case EDJE_STATE_PARAM_REL2:
|
case EDJE_STATE_PARAM_REL2:
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
SETFLOAT(rp->custom->description->rel2.relative_x, params[3]);
|
SETFLOAT_T(rp->custom->description->rel2.relative_x, params[3]);
|
||||||
SETFLOAT(rp->custom->description->rel2.relative_y, params[4]);
|
SETFLOAT_T(rp->custom->description->rel2.relative_y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_REL2_TO:
|
case EDJE_STATE_PARAM_REL2_TO:
|
||||||
|
@ -2075,8 +2066,8 @@ _edje_embryo_fn_get_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
||||||
CHKPARAM(6);
|
CHKPARAM(6);
|
||||||
|
|
||||||
SETFLOAT(rp->custom->description->fill.pos_rel_x, params[3]);
|
SETFLOAT_T(rp->custom->description->fill.pos_rel_x, params[3]);
|
||||||
SETFLOAT(rp->custom->description->fill.pos_rel_y, params[4]);
|
SETFLOAT_T(rp->custom->description->fill.pos_rel_y, params[4]);
|
||||||
SETINT(rp->custom->description->fill.pos_abs_x, params[5]);
|
SETINT(rp->custom->description->fill.pos_abs_x, params[5]);
|
||||||
SETINT(rp->custom->description->fill.pos_abs_y, params[6]);
|
SETINT(rp->custom->description->fill.pos_abs_y, params[6]);
|
||||||
|
|
||||||
|
@ -2085,8 +2076,8 @@ _edje_embryo_fn_get_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
if ( (rp->part->type != EDJE_PART_TYPE_IMAGE) ) return 0;
|
||||||
CHKPARAM(6);
|
CHKPARAM(6);
|
||||||
|
|
||||||
SETFLOAT(rp->custom->description->fill.rel_x, params[3]);
|
SETFLOAT_T(rp->custom->description->fill.rel_x, params[3]);
|
||||||
SETFLOAT(rp->custom->description->fill.rel_y, params[4]);
|
SETFLOAT_T(rp->custom->description->fill.rel_y, params[4]);
|
||||||
SETINT(rp->custom->description->fill.abs_x, params[5]);
|
SETINT(rp->custom->description->fill.abs_x, params[5]);
|
||||||
SETINT(rp->custom->description->fill.abs_y, params[6]);
|
SETINT(rp->custom->description->fill.abs_y, params[6]);
|
||||||
|
|
||||||
|
@ -2166,8 +2157,8 @@ _edje_embryo_fn_get_state_val(Embryo_Program *ep, Embryo_Cell *params)
|
||||||
if ((rp->part->type != EDJE_PART_TYPE_TEXT)) return 0;
|
if ((rp->part->type != EDJE_PART_TYPE_TEXT)) return 0;
|
||||||
CHKPARAM(4);
|
CHKPARAM(4);
|
||||||
|
|
||||||
SETFLOAT(rp->custom->description->text.align.x, params[3]);
|
SETFLOAT_T(rp->custom->description->text.align.x, params[3]);
|
||||||
SETFLOAT(rp->custom->description->text.align.y, params[4]);
|
SETFLOAT_T(rp->custom->description->text.align.y, params[4]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case EDJE_STATE_PARAM_VISIBLE:
|
case EDJE_STATE_PARAM_VISIBLE:
|
||||||
|
|
|
@ -1358,7 +1358,17 @@ void _edje_embryo_globals_init(Edje *ed);
|
||||||
float *___cptr; \
|
float *___cptr; \
|
||||||
if ((___cptr = (float *)embryo_data_address_get(ep, (par)))) { \
|
if ((___cptr = (float *)embryo_data_address_get(ep, (par)))) { \
|
||||||
val = *___cptr; } }
|
val = *___cptr; } }
|
||||||
#define GETINT(val, par) { \
|
|
||||||
|
#define GETFLOAT_T(val, par) \
|
||||||
|
{ \
|
||||||
|
float *___cptr; \
|
||||||
|
if ((___cptr = (float *)embryo_data_address_get(ep, (par)))) \
|
||||||
|
{ \
|
||||||
|
val = FROM_DOUBLE(*___cptr); \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define GETINT(val, par) { \
|
||||||
int *___cptr; \
|
int *___cptr; \
|
||||||
if ((___cptr = (int *)embryo_data_address_get(ep, (par)))) { \
|
if ((___cptr = (int *)embryo_data_address_get(ep, (par)))) { \
|
||||||
val = *___cptr; } }
|
val = *___cptr; } }
|
||||||
|
@ -1382,6 +1392,14 @@ void _edje_embryo_globals_init(Edje *ed);
|
||||||
float *___cptr; \
|
float *___cptr; \
|
||||||
if ((___cptr = (float *)embryo_data_address_get(ep, (par)))) { \
|
if ((___cptr = (float *)embryo_data_address_get(ep, (par)))) { \
|
||||||
*___cptr = (float)val; } }
|
*___cptr = (float)val; } }
|
||||||
|
#define SETFLOAT_T(val, par) \
|
||||||
|
{ \
|
||||||
|
float *___cptr; \
|
||||||
|
if ((___cptr = (float *)embryo_data_address_get(ep, (par)))) \
|
||||||
|
{ \
|
||||||
|
*___cptr = (float) TO_DOUBLE(val); \
|
||||||
|
} \
|
||||||
|
}
|
||||||
#define SETINT(val, par) { \
|
#define SETINT(val, par) { \
|
||||||
int *___cptr; \
|
int *___cptr; \
|
||||||
if ((___cptr = (int *)embryo_data_address_get(ep, (par)))) { \
|
if ((___cptr = (int *)embryo_data_address_get(ep, (par)))) { \
|
||||||
|
|
Loading…
Reference in New Issue