This is an automated email from the git hooks/post-receive script.
git pushed a commit to branch master
in repository enlightenment.
View the commit online.
commit f45430e3524271dfc7c3f9a1e0a6a125e0485ac9
Author: Carsten Haitzler <ras...@rasterman.com>
AuthorDate: Tue Dec 17 14:35:44 2024 +0000
music control - support new swallow for gadget cover
---
src/modules/music-control/e_mod_main.c | 3 +
src/modules/music-control/ui.c | 405 +++++++++++++++++----------------
2 files changed, 218 insertions(+), 190 deletions(-)
diff --git a/src/modules/music-control/e_mod_main.c b/src/modules/music-control/e_mod_main.c
index 622c25022..997475c85 100644
--- a/src/modules/music-control/e_mod_main.c
+++ b/src/modules/music-control/e_mod_main.c
@@ -165,10 +165,13 @@ _gc_shutdown(E_Gadcon_Client *gcc)
{
E_Music_Control_Instance *inst;
E_Music_Control_Module_Context *ctxt;
+ Evas_Object *img;
EINA_SAFETY_ON_NULL_RETURN(music_control_mod);
ctxt = music_control_mod->data;
inst = gcc->data;
+ img = edje_object_part_swallow_get(inst->gadget, "e.swallow.cover");
+ if (img) evas_object_del(img);
evas_object_del(inst->gadget);
if (inst->popup) music_control_popup_del(inst);
ctxt->instances = eina_list_remove(ctxt->instances, inst);
diff --git a/src/modules/music-control/ui.c b/src/modules/music-control/ui.c
index da1f934e1..6d10bba4f 100644
--- a/src/modules/music-control/ui.c
+++ b/src/modules/music-control/ui.c
@@ -14,27 +14,34 @@ _pos_update(E_Music_Control_Instance *inst)
msg->val[1] = inst->ctxt->meta_length;
if (msg->val[0] < 0.0) msg->val[0] = 0.0;
if (msg->val[0] > msg->val[1]) msg->val[0] = msg->val[1];
- edje_object_message_send(inst->content_popup, EDJE_MESSAGE_FLOAT_SET, 1, msg);
+ if (inst->popup)
+ edje_object_message_send(inst->content_popup, EDJE_MESSAGE_FLOAT_SET, 1,
+ msg);
+ // XXX: send msg to gadget edje
}
static void
_play_state_update(E_Music_Control_Instance *inst, Eina_Bool without_delay)
{
- if (!inst->popup) return;
if (inst->ctxt->playing)
{
- edje_object_signal_emit(inst->content_popup, "btn,state,image,pause", "play");
+ if (inst->popup)
+ edje_object_signal_emit(inst->content_popup, "btn,state,image,pause", "play");
+ // XXX: emit to gadget
return;
}
-
- if (without_delay)
- edje_object_signal_emit(inst->content_popup, "btn,state,image,play,no_delay", "play");
- else
- edje_object_signal_emit(inst->content_popup, "btn,state,image,play", "play");
- if (inst->ctxt->loop)
- edje_object_signal_emit(inst->content_popup, "loop,state,on", "play");
- else
- edje_object_signal_emit(inst->content_popup, "loop,state,off", "play");
+ if (inst->popup)
+ {
+ if (without_delay)
+ edje_object_signal_emit(inst->content_popup, "btn,state,image,play,no_delay", "play");
+ else
+ edje_object_signal_emit(inst->content_popup, "btn,state,image,play", "play");
+ if (inst->ctxt->loop)
+ edje_object_signal_emit(inst->content_popup, "loop,state,on", "play");
+ else
+ edje_object_signal_emit(inst->content_popup, "loop,state,off", "play");
+ }
+ // XXX: emit to gadget
_pos_update(inst);
}
@@ -64,282 +71,300 @@ music_control_pos_update(E_Music_Control_Module_Context *ctxt)
}
static void
-_metadata_update(E_Music_Control_Instance *inst)
+_obj_meta_text_set(E_Music_Control_Instance *inst, Evas_Object *obj)
{
- Eina_Strbuf *str;
- Evas_Object *img;
+ Eina_Strbuf *str;
- if (!inst->popup) return;
+ str = eina_strbuf_new();
+ if (!str) return;
- str = eina_strbuf_new();
+ if (inst->ctxt->meta_title)
+ eina_strbuf_append_printf(str, "<title>%s</><ps/>",
+ inst->ctxt->meta_title);
+ if (inst->ctxt->meta_artist)
+ eina_strbuf_append_printf(str, "<tag>by</> %s<ps/>",
+ inst->ctxt->meta_artist);
+ if (inst->ctxt->meta_album)
+ eina_strbuf_append_printf(str, "<tag>from</> %s<ps/>",
+ inst->ctxt->meta_album);
+ edje_object_part_text_set(obj, "metadata",
+ eina_strbuf_string_get(str));
+ eina_strbuf_free(str);
+}
- if (inst->ctxt->meta_title)
- eina_strbuf_append_printf(str, "<title>%s</><ps/>", inst->ctxt->meta_title);
- if (inst->ctxt->meta_artist)
- eina_strbuf_append_printf(str, "<tag>by</> %s<ps/>", inst->ctxt->meta_artist);
- if (inst->ctxt->meta_album)
- eina_strbuf_append_printf(str, "<tag>from</> %s<ps/>", inst->ctxt->meta_album);
- edje_object_part_text_set(inst->content_popup, "metadata", eina_strbuf_string_get(str));
- eina_strbuf_free(str);
+static void
+_obj_meta_cover_set(E_Music_Control_Instance *inst, Evas_Object *obj, Evas_Object *cobj, const char *swallow)
+{
+ Evas_Object *img;
- img = edje_object_part_swallow_get(inst->content_popup, "cover_swallow");
- if (img)
- {
- if (inst->ctxt->meta_cover_prev != inst->ctxt->meta_cover)
- {
- e_comp_object_util_del_list_remove(inst->popup->comp_object, img);
- evas_object_del(img);
- img = NULL;
- if (inst->ctxt->meta_cover_prev)
- {
- eina_stringshare_del(inst->ctxt->meta_cover_prev);
- inst->ctxt->meta_cover_prev = NULL;
- }
- }
- }
- if ((!img) && (inst->ctxt->meta_cover))
- {
- if (inst->ctxt->meta_cover)
- inst->ctxt->meta_cover_prev = eina_stringshare_add(inst->ctxt->meta_cover);
+ img = edje_object_part_swallow_get(obj, swallow);
+ printf("MUS: img=%p\n", img);
+ if ((img) && (inst->ctxt->meta_cover_prev == inst->ctxt->meta_cover)) return;
+ printf("MUS: [%s] change %s -> %s\n", swallow, inst->ctxt->meta_cover_prev,
+ inst->ctxt->meta_cover);
+ if (img)
+ {
+ if (cobj) e_comp_object_util_del_list_remove(cobj, img);
+ evas_object_del(img);
+ }
+ img = e_icon_add(evas_object_evas_get(obj));
+ e_icon_preload_set(img, EINA_TRUE);
+ e_icon_scale_size_set(img, 512);
+ e_icon_scale_up_set(img, EINA_TRUE);
+ e_icon_fill_inside_set(img, EINA_FALSE);
+ e_icon_file_set(img, inst->ctxt->meta_cover);
+ edje_object_part_swallow(obj, swallow, img);
+ if (cobj) e_comp_object_util_del_list_append(cobj, img);
+}
- img = e_icon_add(evas_object_evas_get(inst->content_popup));
- e_icon_preload_set(img, EINA_TRUE);
- e_icon_scale_size_set(img, 512);
- e_icon_scale_up_set(img, EINA_TRUE);
- e_icon_fill_inside_set(img, EINA_FALSE);
- e_icon_file_set(img, inst->ctxt->meta_cover);
- edje_object_part_swallow(inst->content_popup, "cover_swallow", img);
- e_comp_object_util_del_list_append(inst->popup->comp_object, img);
- }
+static void
+_metadata_update(E_Music_Control_Instance * inst)
+{
+ if (inst->popup)
+ {
+ _obj_meta_text_set(inst, inst->content_popup);
+ _obj_meta_cover_set(inst, inst->content_popup, inst->popup->comp_object, "cover_swallow");
+ }
+ if (edje_object_part_exists(inst->gadget, "e.swallow.cover"))
+ {
+ printf("MUS: swallow exists\n");
+ _obj_meta_cover_set(inst, inst->gadget, NULL, "e.swallow.cover");
+ }
+ printf("MUS: store %s\n", inst->ctxt->meta_cover);
+ eina_stringshare_replace(&(inst->ctxt->meta_cover_prev),
+ inst->ctxt->meta_cover);
}
void
music_control_metadata_update_all(E_Music_Control_Module_Context *ctxt)
{
- E_Music_Control_Instance *inst;
- Eina_List *list;
+ E_Music_Control_Instance *inst;
+ Eina_List *list;
- EINA_LIST_FOREACH(ctxt->instances, list, inst)
- _metadata_update(inst);
+ EINA_LIST_FOREACH(ctxt->instances, list, inst) _metadata_update(inst);
}
static void
-_btn_clicked(void *data, Evas_Object *obj EINA_UNUSED, const char *emission EINA_UNUSED, const char *source)
+_btn_clicked(void *data, Evas_Object *obj EINA_UNUSED,
+ const char *emission EINA_UNUSED,
+ const char *source)
{
- E_Music_Control_Instance *inst = data;
- if (!strcmp(source, "play"))
- media_player2_player_play_pause_call(inst->ctxt->mpris2_player);
- else if (!strcmp(source, "next"))
- media_player2_player_next_call(inst->ctxt->mpris2_player);
- else if (!strcmp(source, "previous"))
+ E_Music_Control_Instance *inst = data;
+
+ if (!strcmp(source, "play"))
+ media_player2_player_play_pause_call(inst->ctxt->mpris2_player);
+ else if (!strcmp(source, "next"))
+ media_player2_player_next_call(inst->ctxt->mpris2_player);
+ else if (!strcmp(source, "previous"))
media_player2_player_previous_call(inst->ctxt->mpris2_player);
}
static void
-_label_clicked(void *data, Evas_Object *obj EINA_UNUSED, const char *emission EINA_UNUSED, const char *source EINA_UNUSED)
+_label_clicked(void *data, Evas_Object *obj EINA_UNUSED,
+ const char *emission EINA_UNUSED,
+ const char *source EINA_UNUSED)
{
- E_Music_Control_Instance *inst = data;
- music_control_popup_del(inst);
- music_control_launch(inst);
- mpris_media_player2_raise_call(inst->ctxt->mrpis2);
+ E_Music_Control_Instance *inst = data;
+
+ music_control_popup_del(inst);
+ music_control_launch(inst);
+ mpris_media_player2_raise_call(inst->ctxt->mrpis2);
}
static void
_player_name_update(E_Music_Control_Instance *inst)
{
- Edje_Message_String msg;
- msg.str = (char *)music_player_players[inst->ctxt->config->player_selected].name;
- EINA_SAFETY_ON_NULL_RETURN(msg.str);
- edje_object_message_send(inst->content_popup, EDJE_MESSAGE_STRING, 0, &msg);
+ Edje_Message_String msg;
+
+ msg.str = (char *)music_player_players[inst->ctxt->config->player_selected].name;
+ EINA_SAFETY_ON_NULL_RETURN(msg.str);
+ edje_object_message_send(inst->content_popup, EDJE_MESSAGE_STRING, 0, &msg);
}
static void
_popup_del_cb(void *obj)
{
- music_control_popup_del(e_object_data_get(obj));
+ music_control_popup_del(e_object_data_get(obj));
}
static void
_popup_autoclose_cb(void *data, Evas_Object *obj EINA_UNUSED)
{
- music_control_popup_del((E_Music_Control_Instance *)data);
+ music_control_popup_del((E_Music_Control_Instance *)data);
}
static void
_popup_new(E_Music_Control_Instance *inst)
{
- Evas_Object *o;
- inst->popup = e_gadcon_popup_new(inst->gcc, 0);
+ Evas_Object *o;
+ inst->popup = e_gadcon_popup_new(inst->gcc, 0);
- o = edje_object_add(e_comp->evas);
- e_theme_edje_object_set(o, "base/theme/modules/music-control",
- "e/modules/music-control/popup");
- edje_object_signal_callback_add(o, "btn,clicked", "*", _btn_clicked, inst);
- edje_object_signal_callback_add(o, "label,clicked", "player_name", _label_clicked, inst);
+ o = edje_object_add(e_comp->evas);
+ e_theme_edje_object_set(o, "base/theme/modules/music-control",
+ "e/modules/music-control/popup");
+ edje_object_signal_callback_add(o, "btn,clicked", "*", _btn_clicked, inst);
+ edje_object_signal_callback_add(o, "label,clicked", "player_name",
+ _label_clicked, inst);
- e_gadcon_popup_content_set(inst->popup, o);
- inst->content_popup = o;
+ e_gadcon_popup_content_set(inst->popup, o);
+ inst->content_popup = o;
- _player_name_update(inst);
- _play_state_update(inst, EINA_TRUE);
- _metadata_update(inst);
- _pos_update(inst);
- e_comp_object_util_autoclose(inst->popup->comp_object,
- _popup_autoclose_cb, NULL, inst);
- e_gadcon_popup_show(inst->popup);
- e_object_data_set(E_OBJECT(inst->popup), inst);
- E_OBJECT_DEL_SET(inst->popup, _popup_del_cb);
+ _player_name_update(inst);
+ _play_state_update(inst, EINA_TRUE);
+ _metadata_update(inst);
+ _pos_update(inst);
+ e_comp_object_util_autoclose(inst->popup->comp_object, _popup_autoclose_cb,
+ NULL, inst);
+ e_gadcon_popup_show(inst->popup);
+ e_object_data_set(E_OBJECT(inst->popup), inst);
+ E_OBJECT_DEL_SET(inst->popup, _popup_del_cb);
}
void
music_control_popup_del(E_Music_Control_Instance *inst)
{
- E_FREE_FUNC(inst->popup, e_object_del);
+ E_FREE_FUNC(inst->popup, e_object_del);
}
struct _E_Config_Dialog_Data
{
- int index;
- int pause_on_desklock;
+ int index;
+ int pause_on_desklock;
};
static Evas_Object *
-_cfg_widgets_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
+_cfg_widgets_create(E_Config_Dialog *cfd, Evas *evas,
+ E_Config_Dialog_Data *cfdata)
{
- Evas_Object *o, *of, *ob, *oc;
- E_Radio_Group *rg;
- int i;
- E_Music_Control_Instance *inst = cfd->data;
- int player_selected = inst->ctxt->config->player_selected;
+ Evas_Object *o, *of, *ob, *oc;
+ E_Radio_Group *rg;
+ int i;
+ E_Music_Control_Instance *inst = cfd->data;
+ int player_selected = inst->ctxt->config->player_selected;
- o = e_widget_list_add(evas, 0, 0);
+ o = e_widget_list_add(evas, 0, 0);
+ of = e_widget_framelist_add(evas, _("Music Player"), 0);
+ e_widget_framelist_content_align_set(of, 0.0, 0.0);
+ rg = e_widget_radio_group_new(&(cfdata->index));
+ for (i = 0; music_player_players[i].dbus_name; i++)
+ {
+ ob = e_widget_radio_add(evas, music_player_players[i].name, i, rg);
+ e_widget_framelist_object_append(of, ob);
+ if (i == player_selected) e_widget_radio_toggle_set(ob, EINA_TRUE);
+ }
+ ob = e_widget_label_add(evas, _("* Your player must be configured to "
+ "export the DBus interface MPRIS2."));
+ e_widget_framelist_object_append(of, ob);
- of = e_widget_framelist_add(evas, _("Music Player"), 0);
- e_widget_framelist_content_align_set(of, 0.0, 0.0);
- rg = e_widget_radio_group_new(&(cfdata->index));
- for (i = 0; music_player_players[i].dbus_name; i++)
- {
- ob = e_widget_radio_add(evas, music_player_players[i].name, i, rg);
- e_widget_framelist_object_append(of, ob);
- if (i == player_selected)
- e_widget_radio_toggle_set(ob, EINA_TRUE);
- }
- ob = e_widget_label_add(evas, _("* Your player must be configured to export the DBus interface MPRIS2."));
- e_widget_framelist_object_append(of, ob);
-
- oc = e_widget_check_add(evas, _("Pause music when screen is locked"), &(cfdata->pause_on_desklock));
- e_widget_framelist_object_append(of, oc);
-
- e_widget_list_object_append(o, of, 1, 1, 0.5);
-
- return o;
+ oc = e_widget_check_add(evas, _("Pause music when screen is locked"),
+ &(cfdata->pause_on_desklock));
+ e_widget_framelist_object_append(of, oc);
+ e_widget_list_object_append(o, of, 1, 1, 0.5);
+ return o;
}
static void *
_cfg_data_create(E_Config_Dialog *cfd)
{
- E_Music_Control_Instance *inst = cfd->data;
- E_Config_Dialog_Data *cfdata = calloc(1, sizeof(E_Config_Dialog_Data));
- cfdata->index = inst->ctxt->config->player_selected;
- cfdata->pause_on_desklock = inst->ctxt->config->pause_on_desklock;
+ E_Music_Control_Instance *inst = cfd->data;
+ E_Config_Dialog_Data *cfdata = calloc(1, sizeof(E_Config_Dialog_Data));
- return cfdata;
+ cfdata->index = inst->ctxt->config->player_selected;
+ cfdata->pause_on_desklock = inst->ctxt->config->pause_on_desklock;
+ return cfdata;
}
static void
_cfg_data_free(E_Config_Dialog *cfd EINA_UNUSED, E_Config_Dialog_Data *cfdata)
{
- free(cfdata);
+ free(cfdata);
}
static int
_cfg_check_changed(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
{
- E_Music_Control_Instance *inst = cfd->data;
+ E_Music_Control_Instance *inst = cfd->data;
- return ((inst->ctxt->config->pause_on_desklock != cfdata->pause_on_desklock) ||
- (inst->ctxt->config->player_selected != cfdata->index));
+ return ((inst->ctxt->config->pause_on_desklock != cfdata->pause_on_desklock)
+ || (inst->ctxt->config->player_selected != cfdata->index));
}
static int
_cfg_data_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
{
- E_Music_Control_Instance *inst = cfd->data;
+ E_Music_Control_Instance *inst = cfd->data;
- if ((inst->ctxt->config->player_selected == cfdata->index) &&
- (inst->ctxt->config->pause_on_desklock == cfdata->pause_on_desklock))
- return 1;
+ if ((inst->ctxt->config->player_selected == cfdata->index)
+ && (inst->ctxt->config->pause_on_desklock == cfdata->pause_on_desklock))
+ return 1;
- inst->ctxt->config->player_selected = cfdata->index;
- inst->ctxt->config->pause_on_desklock = cfdata->pause_on_desklock;
+ inst->ctxt->config->player_selected = cfdata->index;
+ inst->ctxt->config->pause_on_desklock = cfdata->pause_on_desklock;
- if (inst->ctxt->config->pause_on_desklock)
- {
- if (!desklock_handler)
- desklock_handler = ecore_event_handler_add(E_EVENT_DESKLOCK, _desklock_cb, inst->ctxt);
- }
- else
- E_FREE_FUNC(desklock_handler, ecore_event_handler_del);
+ if (inst->ctxt->config->pause_on_desklock)
+ {
+ if (!desklock_handler)
+ desklock_handler
+ = ecore_event_handler_add(E_EVENT_DESKLOCK, _desklock_cb, inst->ctxt);
+ }
+ else E_FREE_FUNC(desklock_handler, ecore_event_handler_del);
- inst->ctxt->playing = EINA_FALSE;
- music_control_dbus_init(inst->ctxt,
- music_player_players[inst->ctxt->config->player_selected].dbus_name);
- return 1;
+ inst->ctxt->playing = EINA_FALSE;
+ music_control_dbus_init(
+ inst->ctxt,
+ music_player_players[inst->ctxt->config->player_selected].dbus_name);
+ return 1;
}
static void
_cb_menu_cfg(void *data, E_Menu *m EINA_UNUSED, E_Menu_Item *mi EINA_UNUSED)
{
- E_Config_Dialog_View *v;
+ E_Config_Dialog_View *v;
- v = calloc(1, sizeof(E_Config_Dialog_View));
- v->create_cfdata = _cfg_data_create;
- v->free_cfdata = _cfg_data_free;
- v->basic.create_widgets = _cfg_widgets_create;
- v->basic.apply_cfdata = _cfg_data_apply;
- v->basic.check_changed = _cfg_check_changed;
+ v = calloc(1, sizeof(E_Config_Dialog_View));
+ v->create_cfdata = _cfg_data_create;
+ v->free_cfdata = _cfg_data_free;
+ v->basic.create_widgets = _cfg_widgets_create;
+ v->basic.apply_cfdata = _cfg_data_apply;
+ v->basic.check_changed = _cfg_check_changed;
- e_config_dialog_new(NULL, _("Music control Settings"), "E",
- "_e_mod_music_config_dialog",
- NULL, 0, v, data);
+ e_config_dialog_new(NULL, _("Music control Settings"), "E",
+ "_e_mod_music_config_dialog", NULL, 0, v, data);
}
void
-music_control_mouse_down_cb(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event)
+music_control_mouse_down_cb(void *data, Evas *evas EINA_UNUSED,
+ Evas_Object *obj EINA_UNUSED, void *event)
{
- E_Music_Control_Instance *inst = data;
- Evas_Event_Mouse_Down *ev = event;
+ E_Music_Control_Instance *inst = data;
+ Evas_Event_Mouse_Down *ev = event;
- if (ev->button == 1)
- {
- music_control_launch(inst);
- if (!inst->popup)
- _popup_new(inst);
- else
- music_control_popup_del(inst);
- }
- else if (ev->button == 3)
- {
- E_Menu *m;
- E_Menu_Item *mi;
- E_Zone *zone = e_zone_current_get();
- int x, y;
+ if (ev->button == 1)
+ {
+ music_control_launch(inst);
+ if (!inst->popup) _popup_new(inst);
+ else music_control_popup_del(inst);
+ }
+ else if (ev->button == 3)
+ {
+ E_Menu *m;
+ E_Menu_Item *mi;
+ E_Zone *zone = e_zone_current_get();
+ int x, y;
- if (inst->popup)
- music_control_popup_del(inst);
+ if (inst->popup) music_control_popup_del(inst);
- m = e_menu_new();
- mi = e_menu_item_new(m);
- e_menu_item_label_set(mi, _("Settings"));
- e_util_menu_item_theme_icon_set(mi, "configure");
- e_menu_item_callback_set(mi, _cb_menu_cfg, inst);
+ m = e_menu_new();
+ mi = e_menu_item_new(m);
+ e_menu_item_label_set(mi, _("Settings"));
+ e_util_menu_item_theme_icon_set(mi, "configure");
+ e_menu_item_callback_set(mi, _cb_menu_cfg, inst);
- m = e_gadcon_client_util_menu_items_append(inst->gcc, m, 0);
-
- e_gadcon_canvas_zone_geometry_get(inst->gcc->gadcon, &x, &y, NULL, NULL);
- e_menu_activate_mouse(m, zone, (x + ev->output.x),(y + ev->output.y),
- 1, 1, E_MENU_POP_DIRECTION_AUTO, ev->timestamp);
- evas_event_feed_mouse_up(inst->gcc->gadcon->evas, ev->button,
- EVAS_BUTTON_NONE, ev->timestamp, NULL);
- }
+ m = e_gadcon_client_util_menu_items_append(inst->gcc, m, 0);
+ e_gadcon_canvas_zone_geometry_get(inst->gcc->gadcon, &x, &y, NULL, NULL);
+ e_menu_activate_mouse(m, zone, (x + ev->output.x), (y + ev->output.y), 1,
+ 1, E_MENU_POP_DIRECTION_AUTO, ev->timestamp);
+ evas_event_feed_mouse_up(inst->gcc->gadcon->evas, ev->button,
+ EVAS_BUTTON_NONE, ev->timestamp, NULL);
+ }
}
--
To stop receiving notification emails like this one, please contact
the administrator of this repository.