redo color dialog to use elm colorselector

this is waaaaaaay less functional and good-looking, but at least it doesn't
crash
This commit is contained in:
Mike Blumenkrantz 2015-04-09 16:34:00 -04:00
parent 155a678ff4
commit aeca417ebe
1 changed files with 42 additions and 12 deletions

View File

@ -4,7 +4,7 @@ static void _e_color_dialog_button1_click(void *data, E_Dialog *edia);
static void _e_color_dialog_button2_click(void *data, E_Dialog *edia); static void _e_color_dialog_button2_click(void *data, E_Dialog *edia);
static void _e_color_dialog_free(E_Color_Dialog *dia); static void _e_color_dialog_free(E_Color_Dialog *dia);
static void _e_color_dialog_dia_del(void *obj); static void _e_color_dialog_dia_del(void *obj);
static void _e_color_dialog_cb_csel_change(void *data, Evas_Object *obj); static void _e_color_dialog_cb_csel_change(void *data, Evas_Object *obj, void *ev);
/** /**
* Create a color selector dialog. * Create a color selector dialog.
@ -17,8 +17,7 @@ E_Color_Dialog *
e_color_dialog_new(const E_Color *color, Eina_Bool alpha_enabled) e_color_dialog_new(const E_Color *color, Eina_Bool alpha_enabled)
{ {
E_Color_Dialog *dia; E_Color_Dialog *dia;
Evas_Object *o; Evas_Object *o, *bx, *re, *fr;
Evas_Coord mw, mh;
dia = E_OBJECT_ALLOC(E_Color_Dialog, E_COLOR_DIALOG_TYPE, _e_color_dialog_free); dia = E_OBJECT_ALLOC(E_Color_Dialog, E_COLOR_DIALOG_TYPE, _e_color_dialog_free);
if (!dia) return NULL; if (!dia) return NULL;
@ -36,11 +35,33 @@ e_color_dialog_new(const E_Color *color, Eina_Bool alpha_enabled)
e_color_copy(dia->color, dia->initial); e_color_copy(dia->color, dia->initial);
o = e_widget_csel_add(evas_object_evas_get(dia->dia->win), dia->color, alpha_enabled); bx = elm_box_add(dia->dia->win);
E_EXPAND(bx);
E_FILL(bx);
o = elm_colorselector_add(bx);
elm_colorselector_mode_set(o, ELM_COLORSELECTOR_COMPONENTS);
elm_colorselector_color_set(o, dia->color->r, dia->color->g, dia->color->b, dia->color->a);
E_EXPAND(o);
E_FILL(o);
evas_object_show(o); evas_object_show(o);
e_widget_size_min_get(o, &mw, &mh); elm_box_pack_end(bx, o);
e_dialog_content_set(dia->dia, o, mw, mh);
e_widget_on_change_hook_set(o, _e_color_dialog_cb_csel_change, dia); fr = elm_frame_add(bx);
E_WEIGHT(fr, EVAS_HINT_EXPAND, 0);
E_FILL(fr);
elm_object_text_set(fr, _("Color Preview"));
evas_object_show(fr);
elm_box_pack_end(bx, fr);
re = evas_object_rectangle_add(evas_object_evas_get(dia->dia->win));
evas_object_data_set(o, "rect", re);
evas_object_size_hint_min_set(re, 1, ELM_SCALE_SIZE(100));
evas_object_show(re);
elm_object_content_set(fr, re);
evas_object_smart_callback_add(o, "changed", _e_color_dialog_cb_csel_change, dia);
e_dialog_content_set(dia->dia, bx, 250, -1);
/* buttons at the bottom */ /* buttons at the bottom */
e_dialog_button_add(dia->dia, _("Select"), NULL, _e_color_dialog_button1_click, dia); e_dialog_button_add(dia->dia, _("Select"), NULL, _e_color_dialog_button1_click, dia);
@ -58,6 +79,7 @@ e_color_dialog_show(E_Color_Dialog *dia)
{ {
e_dialog_show(dia->dia); e_dialog_show(dia->dia);
e_dialog_border_icon_set(dia->dia, "enlightenment/colors"); e_dialog_border_icon_set(dia->dia, "enlightenment/colors");
evas_object_size_hint_min_set(dia->dia->win, 250, -1);
} }
void void
@ -88,11 +110,19 @@ e_color_dialog_change_callback_set(E_Color_Dialog *dia, void (*func)(E_Color_Dia
} }
static void static void
_e_color_dialog_cb_csel_change(void *data, Evas_Object *obj EINA_UNUSED) _e_color_dialog_cb_csel_change(void *data, Evas_Object *obj, void *ev EINA_UNUSED)
{ {
E_Color_Dialog *dia; E_Color_Dialog *dia = data;
Evas_Object *re;
int r, g, b;
dia = data; elm_colorselector_color_get(obj, &dia->color->r, &dia->color->g, &dia->color->b, &dia->color->a);
r = dia->color->r;
g = dia->color->g;
b = dia->color->b;
re = evas_object_data_get(obj, "rect");
evas_color_argb_premul(dia->color->a, &r, &g, &b);
evas_object_color_set(re, r, g, b, dia->color->a);
if (dia->change_func && dia->color) if (dia->change_func && dia->color)
dia->change_func(dia, dia->color, dia->change_data); dia->change_func(dia, dia->color, dia->change_data);
} }
@ -103,7 +133,7 @@ _e_color_dialog_button1_click(void *data, E_Dialog *edia EINA_UNUSED)
E_Color_Dialog *dia; E_Color_Dialog *dia;
dia = data; dia = data;
if (dia->select_func && dia->color) if (dia->select_func)
dia->select_func(dia, dia->color, dia->select_data); dia->select_func(dia, dia->color, dia->select_data);
_e_color_dialog_free(dia); _e_color_dialog_free(dia);
} }
@ -114,7 +144,7 @@ _e_color_dialog_button2_click(void *data, E_Dialog *edia EINA_UNUSED)
E_Color_Dialog *dia; E_Color_Dialog *dia;
dia = data; dia = data;
if (dia->cancel_func && dia->initial) if (dia->cancel_func)
dia->cancel_func(dia, dia->initial, dia->cancel_data); dia->cancel_func(dia, dia->initial, dia->cancel_data);
_e_color_dialog_free(data); _e_color_dialog_free(data);
} }