summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStephan Hesse <stephan@emliri.com>2020-04-28 23:12:44 +0200
committerPhilippe Normand <philn@igalia.com>2021-03-07 17:59:35 +0000
commitd5a183cc2fc1350adb065789b2e81736c0ad9e66 (patch)
tree4db8eb4ba5bc1c1c9cd2595943fb17f86191a6e4
parentf8cbae9d6eb85381c4428998880dfcd863e205d3 (diff)
gst-play: use novel signal-adapter (requires gstplayer lib patch from https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/35)
Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-examples/-/merge_requests/33>
-rw-r--r--playback/player/gst-play/gst-play.c26
-rw-r--r--playback/player/gtk/gtk-play.c3
2 files changed, 16 insertions, 13 deletions
diff --git a/playback/player/gst-play/gst-play.c b/playback/player/gst-play/gst-play.c
index b7b98e1..62aa2cd 100644
--- a/playback/player/gst-play/gst-play.c
+++ b/playback/player/gst-play/gst-play.c
@@ -357,24 +357,28 @@ play_new (gchar ** uris, gdouble initial_volume)
play->cur_idx = -1;
play->player =
- gst_player_new (NULL, gst_player_g_main_context_signal_dispatcher_new
- (NULL));
+ gst_player_new (NULL);
- g_signal_connect (play->player, "position-updated",
+ play->loop = g_main_loop_new (NULL, FALSE);
+ play->desired_state = GST_STATE_PLAYING;
+
+ GstPlayerSignalAdapter *player_sig_adapt
+ = gst_player_signal_adapter_new(
+ gst_player_get_message_bus (play->player),
+ g_main_loop_get_context (play->loop));
+
+ g_signal_connect (player_sig_adapt, "position-updated",
G_CALLBACK (position_updated_cb), play);
- g_signal_connect (play->player, "state-changed",
+ g_signal_connect (player_sig_adapt, "state-changed",
G_CALLBACK (state_changed_cb), play);
- g_signal_connect (play->player, "buffering", G_CALLBACK (buffering_cb), play);
- g_signal_connect (play->player, "end-of-stream",
+ g_signal_connect (player_sig_adapt, "buffering", G_CALLBACK (buffering_cb), play);
+ g_signal_connect (player_sig_adapt, "end-of-stream",
G_CALLBACK (end_of_stream_cb), play);
- g_signal_connect (play->player, "error", G_CALLBACK (error_cb), play);
+ g_signal_connect (player_sig_adapt, "error", G_CALLBACK (error_cb), play);
- g_signal_connect (play->player, "media-info-updated",
+ g_signal_connect (player_sig_adapt, "media-info-updated",
G_CALLBACK (media_info_cb), play);
- play->loop = g_main_loop_new (NULL, FALSE);
- play->desired_state = GST_STATE_PLAYING;
-
play_set_relative_volume (play, initial_volume - 1.0);
return play;
diff --git a/playback/player/gtk/gtk-play.c b/playback/player/gtk/gtk-play.c
index 786458e..c6b1b42 100644
--- a/playback/player/gtk/gtk-play.c
+++ b/playback/player/gtk/gtk-play.c
@@ -1743,8 +1743,7 @@ gtk_play_constructor (GType type, guint n_construct_params,
create_ui (self);
self->player =
- gst_player_new (self->renderer,
- gst_player_g_main_context_signal_dispatcher_new (NULL));
+ gst_player_new (self->renderer);
g_signal_connect (self->player, "position-updated",
G_CALLBACK (position_updated_cb), self);