Add the fitting the size of items according the viewport size.
If the sum of item's min is larger than the viewport size in ELM_TOOLBAR_SHRINK_EXPAND mode, it can be scroll. And the end of the item is fitted on the end of the viewport. SVN revision: 78156
This commit is contained in:
parent
5d488c8ffb
commit
0487a76057
|
@ -624,3 +624,9 @@
|
||||||
* elm: Fixed on_focus_region() issue. Focused area should be scrolled
|
* elm: Fixed on_focus_region() issue. Focused area should be scrolled
|
||||||
only when it is needed. Now only entry needs this feature.
|
only when it is needed. Now only entry needs this feature.
|
||||||
|
|
||||||
|
2012-10-18 Jaehwan Kim
|
||||||
|
|
||||||
|
* Add the fitting the size of items according the viewport size.
|
||||||
|
If the sum of item's min is larger than the viewport size in ELM_TOOLBAR_SHRINK_EXPAND mode,
|
||||||
|
it can be scroll. And the end of the item is fitted on the end of the viewport.
|
||||||
|
|
||||||
|
|
|
@ -214,6 +214,59 @@ _mirrored_set(Evas_Object *obj,
|
||||||
_item_mirrored_set(obj, sd->more_item, mirrored);
|
_item_mirrored_set(obj, sd->more_item, mirrored);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_items_size_fit(Evas_Object *obj, Evas_Coord *bl, Evas_Coord view)
|
||||||
|
{
|
||||||
|
Elm_Toolbar_Item *it, *prev;
|
||||||
|
Eina_Bool full = EINA_FALSE, more = EINA_FALSE;
|
||||||
|
Evas_Coord min, mw, mh;
|
||||||
|
int sumf = 0, sumb = 0, prev_min = 0;
|
||||||
|
|
||||||
|
ELM_TOOLBAR_DATA_GET(obj, sd);
|
||||||
|
|
||||||
|
EINA_INLIST_FOREACH(sd->items, it)
|
||||||
|
{
|
||||||
|
min = mw = mh = -1;
|
||||||
|
if (it->in_box && it->in_box == sd->bx)
|
||||||
|
{
|
||||||
|
if (!it->separator && !it->object)
|
||||||
|
elm_coords_finger_size_adjust(1, &mw, 1, &mh);
|
||||||
|
edje_object_size_min_restricted_calc(VIEW(it), &mw, &mh, mw, mh);
|
||||||
|
if (!it->separator && !it->object)
|
||||||
|
elm_coords_finger_size_adjust(1, &mw, 1, &mh);
|
||||||
|
}
|
||||||
|
else if (!more)
|
||||||
|
{
|
||||||
|
more = EINA_TRUE;
|
||||||
|
elm_coords_finger_size_adjust(1, &mw, 1, &mh);
|
||||||
|
edje_object_size_min_restricted_calc(sd->VIEW(more_item), &mw, &mh, mw, mh);
|
||||||
|
elm_coords_finger_size_adjust(1, &mw, 1, &mh);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mw != -1 || mh != -1)
|
||||||
|
{
|
||||||
|
if (sd->vertical) min = mh;
|
||||||
|
else min = mw;
|
||||||
|
|
||||||
|
if ((!full) && ((sumf + min) > view))
|
||||||
|
{
|
||||||
|
prev = ELM_TOOLBAR_ITEM_FROM_INLIST(EINA_INLIST_GET(it)->prev);
|
||||||
|
if (prev && prev->separator)
|
||||||
|
{
|
||||||
|
sumf -= prev_min;
|
||||||
|
sumb += prev_min;
|
||||||
|
}
|
||||||
|
full = EINA_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!full) sumf += min;
|
||||||
|
else sumb += min;
|
||||||
|
prev_min = min;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (sumf != 0) *bl = (Evas_Coord)(((sumf + sumb) * view) / sumf);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_resize_job(void *data)
|
_resize_job(void *data)
|
||||||
{
|
{
|
||||||
|
@ -382,6 +435,15 @@ _resize_job(void *data)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
evas_object_hide(sd->VIEW(more_item));
|
evas_object_hide(sd->VIEW(more_item));
|
||||||
|
|
||||||
|
if (sd->vertical)
|
||||||
|
{
|
||||||
|
if (h > vh) _items_size_fit(obj, &h, vh);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (w > vw) _items_size_fit(obj, &w, vw);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -835,15 +897,17 @@ _sizing_eval(Evas_Object *obj)
|
||||||
}
|
}
|
||||||
else if (sd->shrink_mode == ELM_TOOLBAR_SHRINK_EXPAND)
|
else if (sd->shrink_mode == ELM_TOOLBAR_SHRINK_EXPAND)
|
||||||
{
|
{
|
||||||
minw = minw_bx + (w - vw);
|
|
||||||
minh = minh_bx + (h - vh);
|
|
||||||
if (sd->vertical)
|
if (sd->vertical)
|
||||||
{
|
{
|
||||||
if (minh_bx < vh) minh_bx = vh;
|
minw = minw_bx + (w - vw);
|
||||||
|
if (minh_bx <= vh) minh_bx = vh;
|
||||||
|
else _items_size_fit(obj, &minh_bx, vh);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (minw_bx < vw) minw_bx = vw;
|
minh = minh_bx + (h - vh);
|
||||||
|
if (minw_bx <= vw) minw_bx = vw;
|
||||||
|
else _items_size_fit(obj, &minw_bx, vw);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue