Efl.Ui.Progressbar: implement format_cb.set

Also remove format_string.set/get implmentation
since it takes care by base Efl.Ui.Format.format_string

Ref T6204
This commit is contained in:
Amitesh Singh 2017-10-26 02:10:29 +09:00
parent 5298cb59d2
commit 3092c0fdea
3 changed files with 86 additions and 45 deletions

View File

@ -104,22 +104,22 @@ _units_set(Evas_Object *obj)
{ {
EFL_UI_PROGRESSBAR_DATA_GET(obj, sd); EFL_UI_PROGRESSBAR_DATA_GET(obj, sd);
if (sd->unit_format_func) if (sd->format_cb)
{ {
char *buf; Eina_Value val;
buf = sd->unit_format_func(sd->val); eina_value_setup(&val, EINA_VALUE_TYPE_DOUBLE);
elm_layout_text_set(obj, "elm.text.status", buf); if (!sd->is_legacy_format)
if (sd->unit_format_free) sd->unit_format_free(buf); eina_value_set(&val, sd->val);
} else // Keeping this bug since the legacy code was like that.
else if (sd->units) eina_value_set(&val, 100 * sd->val);
{
char buf[1024];
snprintf(buf, sizeof(buf), sd->units, 100 * sd->val); eina_strbuf_reset(sd->format_strbuf);
elm_layout_text_set(obj, "elm.text.status", buf); sd->format_cb(sd->format_cb_data, sd->format_strbuf, val);
elm_layout_text_set(obj, "elm.text.status", eina_strbuf_string_get(sd->format_strbuf));
} }
else elm_layout_text_set(obj, "elm.text.status", NULL); else
elm_layout_text_set(obj, "elm.text.status", NULL);
} }
static void static void
@ -216,7 +216,7 @@ _efl_ui_progressbar_elm_widget_theme_apply(Eo *obj, Efl_Ui_Progressbar_Data *sd)
if (sd->pulse_state) if (sd->pulse_state)
elm_layout_signal_emit(obj, "elm,state,pulse,start", "elm"); elm_layout_signal_emit(obj, "elm,state,pulse,start", "elm");
if (((sd->units) || (sd->unit_format_func)) && (!sd->pulse)) if (sd->format_cb && (!sd->pulse))
elm_layout_signal_emit(obj, "elm,state,units,visible", "elm"); elm_layout_signal_emit(obj, "elm,state,units,visible", "elm");
if (_is_horizontal(sd->dir)) if (_is_horizontal(sd->dir))
@ -292,13 +292,14 @@ _efl_ui_progressbar_efl_canvas_group_group_add(Eo *obj, Efl_Ui_Progressbar_Data
elm_widget_sub_object_parent_add(obj); elm_widget_sub_object_parent_add(obj);
priv->dir = EFL_UI_DIR_RIGHT; priv->dir = EFL_UI_DIR_RIGHT;
priv->units = eina_stringshare_add("%.0f %%");
priv->val = MIN_RATIO_LVL; priv->val = MIN_RATIO_LVL;
if (!elm_layout_theme_set if (!elm_layout_theme_set
(obj, "progressbar", "horizontal", elm_widget_style_get(obj))) (obj, "progressbar", "horizontal", elm_widget_style_get(obj)))
CRI("Failed to set layout!"); CRI("Failed to set layout!");
efl_ui_format_string_set(obj, "%.0f %%");
priv->spacer = evas_object_rectangle_add(evas_object_evas_get(obj)); priv->spacer = evas_object_rectangle_add(evas_object_evas_get(obj));
evas_object_color_set(priv->spacer, 0, 0, 0, 0); evas_object_color_set(priv->spacer, 0, 0, 0, 0);
evas_object_pass_events_set(priv->spacer, EINA_TRUE); evas_object_pass_events_set(priv->spacer, EINA_TRUE);
@ -327,8 +328,6 @@ _efl_ui_progressbar_efl_canvas_group_group_del(Eo *obj, Efl_Ui_Progressbar_Data
{ {
Efl_Ui_Progress_Status *progress_obj; Efl_Ui_Progress_Status *progress_obj;
eina_stringshare_del(sd->units);
sd->units = NULL;
if (sd->progress_status) if (sd->progress_status)
{ {
EINA_LIST_FREE(sd->progress_status, progress_obj) EINA_LIST_FREE(sd->progress_status, progress_obj)
@ -337,6 +336,9 @@ _efl_ui_progressbar_efl_canvas_group_group_del(Eo *obj, Efl_Ui_Progressbar_Data
} }
} }
efl_ui_format_cb_set(obj, NULL, NULL, NULL);
eina_strbuf_free(sd->format_strbuf);
efl_canvas_group_del(efl_super(obj, MY_CLASS)); efl_canvas_group_del(efl_super(obj, MY_CLASS));
} }
@ -344,7 +346,10 @@ EAPI Evas_Object *
elm_progressbar_add(Evas_Object *parent) elm_progressbar_add(Evas_Object *parent)
{ {
EINA_SAFETY_ON_NULL_RETURN_VAL(parent, NULL); EINA_SAFETY_ON_NULL_RETURN_VAL(parent, NULL);
return efl_add(MY_CLASS, parent, efl_canvas_object_legacy_ctor(efl_added)); Eo *obj = efl_add(MY_CLASS, parent, efl_canvas_object_legacy_ctor(efl_added));
elm_progressbar_unit_format_set(obj, "%.0f %%");
return obj;
} }
EOLIAN static Eo * EOLIAN static Eo *
@ -473,26 +478,28 @@ _efl_ui_progressbar_efl_ui_range_range_value_get(Eo *obj EINA_UNUSED, Efl_Ui_Pro
} }
EOLIAN static void EOLIAN static void
_efl_ui_progressbar_efl_ui_format_format_string_set(Eo *obj, Efl_Ui_Progressbar_Data *sd, const char *units) _efl_ui_progressbar_efl_ui_format_format_cb_set(Eo *obj, Efl_Ui_Progressbar_Data *sd, void *func_data, Efl_Ui_Format_Func_Cb func, Eina_Free_Cb func_free_cb)
{ {
const char *sig;
ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd); ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
eina_stringshare_replace(&sd->units, units); if (sd->format_cb_data == func_data && sd->format_cb == func)
sig = (units) ? "elm,state,units,visible" : "elm,state,units,hidden"; return;
elm_layout_signal_emit(obj, sig, "elm");
if (sd->format_cb_data && sd->format_free_cb)
sd->format_free_cb(sd->format_cb_data);
sd->format_cb = func;
sd->format_cb_data = func_data;
sd->format_free_cb = func_free_cb;
if (!sd->format_strbuf) sd->format_strbuf = eina_strbuf_new();
elm_layout_signal_emit(obj, "elm,state,units,visible", "elm");
edje_object_message_signal_process(wd->resize_obj); edje_object_message_signal_process(wd->resize_obj);
_units_set(obj); _units_set(obj);
elm_layout_sizing_eval(obj); elm_layout_sizing_eval(obj);
} }
EOLIAN static const char *
_efl_ui_progressbar_efl_ui_format_format_string_get(Eo *obj EINA_UNUSED, Efl_Ui_Progressbar_Data *sd)
{
return sd->units;
}
EOLIAN static void EOLIAN static void
_efl_ui_progressbar_pulse_set(Eo *obj, Efl_Ui_Progressbar_Data *sd, Eina_Bool state) _efl_ui_progressbar_pulse_set(Eo *obj, Efl_Ui_Progressbar_Data *sd, Eina_Bool state)
{ {
@ -542,6 +549,10 @@ elm_progressbar_span_size_get(const Evas_Object *obj)
EAPI void EAPI void
elm_progressbar_unit_format_set(Evas_Object *obj, const char *units) elm_progressbar_unit_format_set(Evas_Object *obj, const char *units)
{ {
EFL_UI_PROGRESSBAR_DATA_GET_OR_RETURN(obj, sd);
sd->is_legacy_format = EINA_TRUE;
efl_ui_format_string_set(obj, units); efl_ui_format_string_set(obj, units);
} }
@ -551,21 +562,47 @@ elm_progressbar_unit_format_get(const Evas_Object *obj)
return efl_ui_format_string_get(obj); return efl_ui_format_string_get(obj);
} }
typedef struct
{
progressbar_func_type format_cb;
progressbar_freefunc_type format_free_cb;
} Pb_Format_Wrapper_Data;
static void
_format_legacy_to_format_eo_cb(void *data, Eina_Strbuf *str, const Eina_Value value)
{
Pb_Format_Wrapper_Data *pfwd = data;
char *buf = NULL;
double val = 0;
const Eina_Value_Type *type = eina_value_type_get(&value);
if (type == EINA_VALUE_TYPE_DOUBLE)
eina_value_get(&value, &val);
if (pfwd->format_cb)
buf = pfwd->format_cb(val);
if (buf)
eina_strbuf_append(str, buf);
if (pfwd->format_free_cb) pfwd->format_free_cb(buf);
}
static void
_format_legacy_to_format_eo_free_cb(void *data)
{
Pb_Format_Wrapper_Data *pfwd = data;
free(pfwd);
}
EAPI void EAPI void
elm_progressbar_unit_format_function_set(Evas_Object *obj, progressbar_func_type func, progressbar_freefunc_type free_func) elm_progressbar_unit_format_function_set(Evas_Object *obj, progressbar_func_type func, progressbar_freefunc_type free_func)
{ {
const char *sig; Pb_Format_Wrapper_Data *pfwd = malloc(sizeof(Pb_Format_Wrapper_Data));
EFL_UI_PROGRESSBAR_DATA_GET(obj, sd);
ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
sd->unit_format_func = func; pfwd->format_cb = func;
sd->unit_format_free = free_func; pfwd->format_free_cb = free_func;
sig = (func) ? "elm,state,units,visible" : "elm,state,units,hidden";
elm_layout_signal_emit(obj, sig, "elm");
edje_object_message_signal_process(wd->resize_obj);
_units_set(obj); efl_ui_format_cb_set(obj, pfwd, _format_legacy_to_format_eo_cb,
elm_layout_sizing_eval(obj); _format_legacy_to_format_eo_free_cb);
} }
EAPI void EAPI void

View File

@ -54,7 +54,7 @@ class Efl.Ui.Progressbar (Efl.Ui.Layout, Efl.Ui.Range, Efl.Ui.Format, Efl.Ui.Dir
Elm.Widget.widget_sub_object_del; Elm.Widget.widget_sub_object_del;
Efl.Ui.Range.range_value { get; set; } Efl.Ui.Range.range_value { get; set; }
Efl.Ui.Direction.direction { get; set; } Efl.Ui.Direction.direction { get; set; }
Efl.Ui.Format.format_string { get; set; } Efl.Ui.Format.format_cb { set; }
Efl.Part.part; Efl.Part.part;
} }
events { events {

View File

@ -29,18 +29,22 @@ typedef struct _Efl_Ui_Progress_Status Efl_Ui_Progress_Status;
struct _Efl_Ui_Progressbar_Data struct _Efl_Ui_Progressbar_Data
{ {
Evas_Object *spacer; /**< The rect actual progressbar area, gets the progressbar size and gets the events */ Evas_Object *spacer; /**< The rect actual progressbar area, gets the progressbar size and gets the events */
const char *units; /**< The units will be displayed on progressbar */
Evas_Coord size; /**< Width or height of progressbar */ Evas_Coord size; /**< Width or height of progressbar */
double val; /**< Value of progressbar */ double val; /**< Value of progressbar */
Efl_Ui_Dir dir; /**< Orientation of the progressbar */
Eina_Bool pulse : 1; /**< Whether object is put in the pulsing mode */
Eina_Bool pulse_state : 1; /**< To start the pulsing animation, otherwise to stop it */
Eina_List *progress_status; /**< The list of _Elm_Progress_Status. To save the progress value(in percentage) each part of given progress bar */ Eina_List *progress_status; /**< The list of _Elm_Progress_Status. To save the progress value(in percentage) each part of given progress bar */
char *(*unit_format_func)(double val); /**< The function pointer will be called when user wants to set a customized unit format */ Efl_Ui_Format_Func_Cb format_cb;
void (*unit_format_free)(char *str); /**< The freeing function for the format string */ Eina_Free_Cb format_free_cb;
void *format_cb_data;
Eina_Strbuf *format_strbuf;
Efl_Ui_Dir dir; /**< Orientation of the progressbar */
Eina_Bool pulse : 1; /**< Whether object is put in the pulsing mode */
Eina_Bool pulse_state : 1; /**< To start the pulsing animation, otherwise to stop it */
Eina_Bool is_legacy_format : 1;
}; };
struct _Efl_Ui_Progress_Status struct _Efl_Ui_Progress_Status