summaryrefslogtreecommitdiffstats
path: root/gst/librfb
diff options
context:
space:
mode:
Diffstat (limited to 'gst/librfb')
-rw-r--r--gst/librfb/gstrfbsrc.c47
-rw-r--r--gst/librfb/rfbdecoder.c40
-rw-r--r--gst/librfb/rfbdecoder.h6
3 files changed, 88 insertions, 5 deletions
diff --git a/gst/librfb/gstrfbsrc.c b/gst/librfb/gstrfbsrc.c
index a4323815..b207030e 100644
--- a/gst/librfb/gstrfbsrc.c
+++ b/gst/librfb/gstrfbsrc.c
@@ -38,6 +38,10 @@ enum
ARG_PORT,
ARG_VERSION,
ARG_PASSWORD,
+ ARG_OFFSET_X,
+ ARG_OFFSET_Y,
+ ARG_WIDTH,
+ ARG_HEIGHT,
};
GST_DEBUG_CATEGORY_STATIC (rfbsrc_debug);
@@ -122,6 +126,18 @@ gst_rfb_src_class_init (GstRfbSrcClass * klass)
g_object_class_install_property (gobject_class, ARG_PASSWORD,
g_param_spec_string ("password", "Password for authentication",
"Password for authentication", "", G_PARAM_WRITABLE));
+ g_object_class_install_property (gobject_class, ARG_OFFSET_X,
+ g_param_spec_int ("offset-x", "x offset for screen scrapping",
+ "x offset for screen scrapping", 0, 65535, 0, G_PARAM_READWRITE));
+ g_object_class_install_property (gobject_class, ARG_OFFSET_Y,
+ g_param_spec_int ("offset-y", "y offset for screen scrapping",
+ "y offset for screen scrapping", 0, 65535, 0, G_PARAM_READWRITE));
+ g_object_class_install_property (gobject_class, ARG_WIDTH,
+ g_param_spec_int ("width", "width of screen", "width of screen", 0, 65535,
+ 0, G_PARAM_READWRITE));
+ g_object_class_install_property (gobject_class, ARG_HEIGHT,
+ g_param_spec_int ("height", "height of screen", "height of screen", 0,
+ 65535, 0, G_PARAM_READWRITE));
gstbasesrc_class->start = GST_DEBUG_FUNCPTR (gst_rfb_src_start);
gstbasesrc_class->stop = GST_DEBUG_FUNCPTR (gst_rfb_src_stop);
@@ -222,6 +238,18 @@ gst_rfb_src_set_property (GObject * object, guint prop_id,
g_free (src->decoder->password);
src->decoder->password = g_strdup (g_value_get_string (value));
break;
+ case ARG_OFFSET_X:
+ src->decoder->offset_x = g_value_get_int (value);
+ break;
+ case ARG_OFFSET_Y:
+ src->decoder->offset_y = g_value_get_int (value);
+ break;
+ case ARG_WIDTH:
+ src->decoder->rect_width = g_value_get_int (value);
+ break;
+ case ARG_HEIGHT:
+ src->decoder->rect_height = g_value_get_int (value);
+ break;
default:
break;
}
@@ -246,6 +274,18 @@ gst_rfb_src_get_property (GObject * object, guint prop_id,
g_value_set_string (value, version);
g_free (version);
break;
+ case ARG_OFFSET_X:
+ g_value_set_int (value, src->decoder->offset_x);
+ break;
+ case ARG_OFFSET_Y:
+ g_value_set_int (value, src->decoder->offset_y);
+ break;
+ case ARG_WIDTH:
+ g_value_set_int (value, src->decoder->rect_width);
+ break;
+ case ARG_HEIGHT:
+ g_value_set_int (value, src->decoder->rect_height);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -270,7 +310,6 @@ gst_rfb_src_start (GstBaseSrc * bsrc)
return FALSE;
}
- src->decoder = decoder;
src->inter = FALSE;
while (!decoder->inited) {
@@ -322,8 +361,10 @@ gst_rfb_src_create (GstPushSrc * psrc, GstBuffer ** outbuf)
gulong newsize;
GstFlowReturn ret;
- rfb_decoder_send_update_request (decoder, src->inter, 0, 0,
- decoder->width, decoder->height);
+ rfb_decoder_send_update_request (decoder, src->inter, decoder->offset_x,
+ decoder->offset_y,
+ (decoder->rect_width ? decoder->rect_width : decoder->width),
+ (decoder->rect_height ? decoder->rect_height : decoder->height));
// src->inter = TRUE;
src->go = TRUE;
diff --git a/gst/librfb/rfbdecoder.c b/gst/librfb/rfbdecoder.c
index 3d150dbe..4ea3910b 100644
--- a/gst/librfb/rfbdecoder.c
+++ b/gst/librfb/rfbdecoder.c
@@ -62,6 +62,11 @@ rfb_decoder_new (void)
decoder->password = NULL;
+ decoder->offset_x = 0;
+ decoder->offset_y = 0;
+ decoder->rect_width = 0;
+ decoder->rect_height = 0;
+
return decoder;
}
@@ -453,6 +458,37 @@ rfb_decoder_state_wait_for_server_initialisation (RfbDecoder * decoder)
decoder->state = rfb_decoder_state_normal;
decoder->inited = TRUE;
+ /* check if we need cropping */
+
+ if (decoder->offset_x > 0) {
+ if (decoder->offset_x > decoder->width) {
+ GST_WARNING ("Trying to crop more than the width of the server");
+ } else {
+ decoder->width -= decoder->offset_x;
+ }
+ }
+ if (decoder->offset_y > 0) {
+ if (decoder->offset_y > decoder->height) {
+ GST_WARNING ("Trying to crop more than the height of the server");
+ } else {
+ decoder->height -= decoder->offset_y;
+ }
+ }
+ if (decoder->rect_width > 0) {
+ if (decoder->rect_width > decoder->width) {
+ GST_WARNING ("Trying to crop more than the width of the server");
+ } else {
+ decoder->width = decoder->rect_width;
+ }
+ }
+ if (decoder->rect_height > 0) {
+ if (decoder->rect_height > decoder->height) {
+ GST_WARNING ("Trying to crop more than the height of the server");
+ } else {
+ decoder->height = decoder->rect_height;
+ }
+ }
+
return TRUE;
}
@@ -547,8 +583,8 @@ rfb_decoder_state_framebuffer_update_rectangle (RfbDecoder * decoder)
buffer = rfb_decoder_read (decoder, 12);
- x = RFB_GET_UINT16 (buffer + 0);
- y = RFB_GET_UINT16 (buffer + 2);
+ x = RFB_GET_UINT16 (buffer + 0) - decoder->offset_x;
+ y = RFB_GET_UINT16 (buffer + 2) - decoder->offset_y;
w = RFB_GET_UINT16 (buffer + 4);
h = RFB_GET_UINT16 (buffer + 6);
encoding = RFB_GET_UINT32 (buffer + 8);
diff --git a/gst/librfb/rfbdecoder.h b/gst/librfb/rfbdecoder.h
index 9d1778f6..d6fec5f6 100644
--- a/gst/librfb/rfbdecoder.h
+++ b/gst/librfb/rfbdecoder.h
@@ -63,6 +63,12 @@ struct _RfbDecoder
gchar *name;
+ /* information if we don't want to update the whole screen */
+ guint offset_x;
+ guint offset_y;
+ guint rect_width;
+ guint rect_height;
+
gint n_rects;
};