xfreerdp-server: optimize screen region encoding

This commit is contained in:
Marc-André Moreau 2012-01-31 21:05:47 -05:00
parent cfd54a4e38
commit 5ee606cf10

View File

@ -249,7 +249,7 @@ xfInfo* xf_info_init()
xf_xshm_init(xfi); xf_xshm_init(xfi);
xfi->bytesPerPixel = (xfi->use_xshm) ? 4 : 3; xfi->bytesPerPixel = 4;
freerdp_kbd_init(xfi->display, 0); freerdp_kbd_init(xfi->display, 0);
@ -264,10 +264,7 @@ void xf_peer_context_new(freerdp_peer* client, xfPeerContext* context)
context->rfx_context->width = context->info->width; context->rfx_context->width = context->info->width;
context->rfx_context->height = context->info->height; context->rfx_context->height = context->info->height;
if (context->info->use_xshm)
rfx_context_set_pixel_format(context->rfx_context, RFX_PIXEL_FORMAT_BGRA); rfx_context_set_pixel_format(context->rfx_context, RFX_PIXEL_FORMAT_BGRA);
else
rfx_context_set_pixel_format(context->rfx_context, RFX_PIXEL_FORMAT_RGB);
context->s = stream_new(65536); context->s = stream_new(65536);
} }
@ -308,11 +305,28 @@ STREAM* xf_peer_stream_init(xfPeerContext* context)
return context->s; return context->s;
} }
void xf_xdamage_subtract_region(xfPeerContext* xfp, int x, int y, int width, int height)
{
XRectangle region;
xfInfo* xfi = xfp->info;
region.x = x;
region.y = y;
region.width = width;
region.height = height;
#ifdef WITH_XFIXES
pthread_mutex_lock(&(xfp->mutex));
XFixesSetRegion(xfi->display, xfi->xdamage_region, &region, 1);
XDamageSubtract(xfi->display, xfi->xdamage, xfi->xdamage_region, None);
pthread_mutex_unlock(&(xfp->mutex));
#endif
}
void* xf_monitor_graphics(void* param) void* xf_monitor_graphics(void* param)
{ {
xfInfo* xfi; xfInfo* xfi;
XEvent xevent; XEvent xevent;
XRectangle region;
xfPeerContext* xfp; xfPeerContext* xfp;
freerdp_peer* client; freerdp_peer* client;
int pending_events = 0; int pending_events = 0;
@ -350,17 +364,7 @@ void* xf_monitor_graphics(void* param)
width = notify->area.width; width = notify->area.width;
height = notify->area.height; height = notify->area.height;
region.x = x; xf_xdamage_subtract_region(xfp, x, y, width, height);
region.y = y;
region.width = width;
region.height = height;
#ifdef WITH_XFIXES
pthread_mutex_lock(&(xfp->mutex));
XFixesSetRegion(xfi->display, xfi->xdamage_region, &region, 1);
XDamageSubtract(xfi->display, xfi->xdamage, xfi->xdamage_region, None);
pthread_mutex_unlock(&(xfp->mutex));
#endif
event_region = xf_event_region_new(x, y, width, height); event_region = xf_event_region_new(x, y, width, height);
xf_event_push(xfp->event_queue, (xfEvent*) event_region); xf_event_push(xfp->event_queue, (xfEvent*) event_region);
@ -476,17 +480,17 @@ void xf_peer_rfx_update(freerdp_peer* client, int x, int y, int width, int heigh
s = xf_peer_stream_init(xfp); s = xf_peer_stream_init(xfp);
image = xf_snapshot(xfp, x, y, width, height);
if (xfi->use_xshm) if (xfi->use_xshm)
{ {
rect.x = 0; rect.x = x;
rect.y = 0; rect.y = y;
rect.width = width; rect.width = width;
rect.height = height; rect.height = height;
image = xf_snapshot(xfp, x, y, width, height);
rfx_compose_message(xfp->rfx_context, s, &rect, 1, rfx_compose_message(xfp->rfx_context, s, &rect, 1,
(uint8*) image->data, width, height, image->bytes_per_line); (uint8*) image->data, xfi->width, xfi->height, image->bytes_per_line);
cmd->destLeft = x; cmd->destLeft = x;
cmd->destTop = y; cmd->destTop = y;
@ -500,19 +504,18 @@ void xf_peer_rfx_update(freerdp_peer* client, int x, int y, int width, int heigh
rect.width = width; rect.width = width;
rect.height = height; rect.height = height;
freerdp_image_convert((uint8*) image->data, xfp->capture_buffer, image = xf_snapshot(xfp, x, y, width, height);
width, height, 32, 24, xfi->clrconv);
rfx_compose_message(xfp->rfx_context, s, &rect, 1, rfx_compose_message(xfp->rfx_context, s, &rect, 1,
xfp->capture_buffer, width, height, width * xfi->bytesPerPixel); (uint8*) image->data, width, height, width * xfi->bytesPerPixel);
cmd->destLeft = x; cmd->destLeft = x;
cmd->destTop = y; cmd->destTop = y;
cmd->destRight = x + width; cmd->destRight = x + width;
cmd->destBottom = y + height; cmd->destBottom = y + height;
}
XDestroyImage(image); XDestroyImage(image);
}
cmd->bpp = 32; cmd->bpp = 32;
cmd->codecID = client->settings->rfx_codec_id; cmd->codecID = client->settings->rfx_codec_id;