From: Victor Toso <me@xxxxxxxxxxxxxx> By using stream-video-codec-type property, we can display which video-codec is being used. Signed-off-by: Victor Toso <victortoso@xxxxxxxxxx> --- tools/spicy.c | 43 +++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 41 insertions(+), 2 deletions(-) diff --git a/tools/spicy.c b/tools/spicy.c index 4712db6..5bb95f2 100644 --- a/tools/spicy.c +++ b/tools/spicy.c @@ -71,6 +71,7 @@ struct _SpiceWindow { bool fullscreen; bool mouse_grabbed; SpiceChannel *display_channel; + gint video_codec; #ifdef G_OS_WIN32 gint win_x; gint win_y; @@ -180,9 +181,18 @@ static int ask_user(GtkWidget *parent, char *title, char *message, return retval; } -#define SPICY_STATUS_LABEL "mouse: %6s, agent: %3s" +#define SPICY_STATUS_LABEL "mouse: %6s, agent: %3s, streaming: %5s" #define SPICY_UNGRAB_INFO "Use %s to ungrab mouse" +static const gchar *video_codec_enum_to_str[] = { + [0] = "none", + [SPICE_VIDEO_CODEC_TYPE_MJPEG] = "mjpeg", + [SPICE_VIDEO_CODEC_TYPE_VP8] = "vp8", + [SPICE_VIDEO_CODEC_TYPE_H264] = "h264", + [SPICE_VIDEO_CODEC_TYPE_VP9] = "vp9", + [SPICE_VIDEO_CODEC_TYPE_ENUM_END] = "error", +}; + static void update_status_window(SpiceWindow *win) { GString *status; @@ -193,7 +203,8 @@ static void update_status_window(SpiceWindow *win) status = g_string_new(NULL); g_string_printf(status, SPICY_STATUS_LABEL, win->conn->mouse_state, - win->conn->agent_state); + win->conn->agent_state, + video_codec_enum_to_str[win->video_codec]); if (win->mouse_grabbed) { SpiceGrabSequence *sequence = spice_display_get_grab_keys(SPICE_DISPLAY(win->spice)); @@ -1391,6 +1402,32 @@ static void del_window(spice_connection *conn, SpiceWindow *win) destroy_spice_window(win); } +static void display_stream_changes(SpiceChannel *display, GParamSpec *pspec, + spice_connection *conn) +{ + gint i; + gint id, codec_type; + GArray *monitors; + + g_object_get(display, + "channel-id", &id, + "monitors", &monitors, + "stream-video-codec-type", &codec_type, + NULL); + + for (i = 0; i < monitors->len; i++) { + SpiceWindow *win = get_window(conn, id, i); + + if (win == NULL) + continue; + + win->video_codec = codec_type; + update_status_window(win); + } + + g_clear_pointer(&monitors, g_array_unref); +} + static void display_monitors(SpiceChannel *display, GParamSpec *pspec, spice_connection *conn) { @@ -1691,6 +1728,8 @@ static void channel_new(SpiceSession *s, SpiceChannel *channel, gpointer data) SPICE_DEBUG("new display channel (#%d)", id); g_signal_connect(channel, "notify::monitors", G_CALLBACK(display_monitors), conn); + g_signal_connect(channel, "notify::stream-video-codec-type", + G_CALLBACK(display_stream_changes), conn); spice_channel_connect(channel); } -- 2.9.3 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/spice-devel