summaryrefslogtreecommitdiffstats
path: root/gst/librfb/rfbdecoder.c
diff options
context:
space:
mode:
Diffstat (limited to 'gst/librfb/rfbdecoder.c')
-rw-r--r--gst/librfb/rfbdecoder.c46
1 files changed, 23 insertions, 23 deletions
diff --git a/gst/librfb/rfbdecoder.c b/gst/librfb/rfbdecoder.c
index 1cc43b09..7be4c480 100644
--- a/gst/librfb/rfbdecoder.c
+++ b/gst/librfb/rfbdecoder.c
@@ -641,23 +641,22 @@ rfb_decoder_raw_encoding (RfbDecoder * decoder, gint start_x, gint start_y,
{
gint size;
guint8 *frame, *buffer, *p;
- guint32 raw_line_size, line_size;
+ guint32 raw_line_size;
- size = rect_h * rect_w * decoder->bpp / 8;
+ raw_line_size = rect_w * decoder->bytespp;
+ size = rect_h * raw_line_size;
GST_DEBUG ("Reading %d bytes", size);
buffer = rfb_decoder_read (decoder, size);
- line_size = decoder->rect_width * decoder->bpp / 8;
- raw_line_size = rect_w * decoder->bpp / 8;
frame =
decoder->frame + (((start_y * decoder->rect_width) +
- start_x) * decoder->bpp / 8);
+ start_x) * decoder->bytespp);
p = buffer;
while (rect_h--) {
memcpy (frame, p, raw_line_size);
p += raw_line_size;
- frame += line_size;
+ frame += decoder->line_size;
}
g_free (buffer);
@@ -668,29 +667,30 @@ rfb_decoder_copyrect_encoding (RfbDecoder * decoder, gint start_x, gint start_y,
gint rect_w, gint rect_h)
{
guint16 src_x, src_y;
- guint32 src_offset;
- guint32 dst_offset;
- gint pos_y, max_y, line_width, copyrect_width;
+ gint line_width, copyrect_width;
guint8 *buffer;
+ guint8 *src, *dst;
buffer = rfb_decoder_read (decoder, 4);
- max_y = start_y + rect_h;
- src_x = RFB_GET_UINT16 (buffer);
- src_y = RFB_GET_UINT16 (buffer + 2);
+ /* don't forget the offset */
+ src_x = RFB_GET_UINT16 (buffer) - decoder->offset_x;
+ src_y = RFB_GET_UINT16 (buffer + 2) - decoder->offset_y;
GST_DEBUG ("Copyrect from %d %d", src_x, src_y);
- dst_offset =
- (((start_y - 1) * decoder->rect_width) + start_x) * decoder->bpp / 8;
- src_offset = (((src_y - 1) * decoder->rect_width) + src_x) * decoder->bpp / 8;
- line_width = decoder->rect_width * decoder->bpp / 8;
- copyrect_width = rect_w * decoder->bpp / 8;
-
- for (pos_y = start_y; pos_y < max_y; pos_y++) {
- dst_offset += line_width;
- src_offset += line_width;
- memcpy (decoder->frame + dst_offset, decoder->prev_frame + src_offset,
- copyrect_width);
+ copyrect_width = rect_w * decoder->bytespp;
+ line_width = decoder->line_size;
+ src =
+ decoder->prev_frame + ((src_y * decoder->rect_width) +
+ src_x) * decoder->bytespp;
+ dst =
+ decoder->frame + ((start_y * decoder->rect_width) +
+ start_x) * decoder->bytespp;
+
+ while (rect_h--) {
+ memcpy (dst, src, copyrect_width);
+ src += line_width;
+ dst += line_width;
}
g_free (buffer);