diff options
Diffstat (limited to 'gst/librfb/gstrfbsrc.c')
-rw-r--r-- | gst/librfb/gstrfbsrc.c | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/gst/librfb/gstrfbsrc.c b/gst/librfb/gstrfbsrc.c index 376d901d..fdb03625 100644 --- a/gst/librfb/gstrfbsrc.c +++ b/gst/librfb/gstrfbsrc.c @@ -44,7 +44,8 @@ enum ARG_HEIGHT, ARG_INCREMENTAL, ARG_USE_COPYRECT, - ARG_SHARED + ARG_SHARED, + ARG_VIEWONLY }; GST_DEBUG_CATEGORY_STATIC (rfbsrc_debug); @@ -152,6 +153,9 @@ gst_rfb_src_class_init (GstRfbSrcClass * klass) g_object_class_install_property (gobject_class, ARG_SHARED, g_param_spec_boolean ("shared", "Share desktop with other clients", "Share desktop with other clients", TRUE, G_PARAM_READWRITE)); + g_object_class_install_property (gobject_class, ARG_VIEWONLY, + g_param_spec_boolean ("view-only", "Only view the desktop", + "only view the desktop", FALSE, G_PARAM_READWRITE)); gstbasesrc_class->start = GST_DEBUG_FUNCPTR (gst_rfb_src_start); gstbasesrc_class->stop = GST_DEBUG_FUNCPTR (gst_rfb_src_stop); gstbasesrc_class->event = GST_DEBUG_FUNCPTR (gst_rfb_src_event); @@ -174,6 +178,8 @@ gst_rfb_src_init (GstRfbSrc * src, GstRfbSrcClass * klass) src->incremental_update = TRUE; + src->view_only = FALSE; + src->decoder = rfb_decoder_new (); } @@ -280,6 +286,9 @@ gst_rfb_src_set_property (GObject * object, guint prop_id, case ARG_SHARED: src->decoder->shared_flag = g_value_get_boolean (value); break; + case ARG_VIEWONLY: + src->view_only = g_value_get_boolean (value); + break; default: break; } @@ -325,6 +334,9 @@ gst_rfb_src_get_property (GObject * object, guint prop_id, case ARG_SHARED: g_value_set_boolean (value, src->decoder->shared_flag); break; + case ARG_VIEWONLY: + g_value_set_boolean (value, src->view_only); + break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); break; @@ -453,6 +465,11 @@ gst_rfb_src_event (GstBaseSrc * bsrc, GstEvent * event) switch (GST_EVENT_TYPE (event)) { case GST_EVENT_NAVIGATION: + + /* if in view_only mode ignore the navigation event */ + if (src->view_only) + break; + structure = event->structure; event_type = gst_structure_get_string (structure, "event"); gst_structure_get_double (structure, "pointer_x", &x); |