/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ #ifndef GUAC_VNC_DISPLAY_H #define GUAC_VNC_DISPLAY_H #include "config.h" #include #include /** * Callback invoked by libVNCServer when it receives a new binary image data. * the VNC server. The image itself will be stored in the designated sub- * rectangle of client->framebuffer. * * @param client * The VNC client associated with the VNC session in which the new image * was received. * * @param x * The X coordinate of the upper-left corner of the destination rectangle * in which the image should be drawn, in pixels. * * @param y * The Y coordinate of the upper-left corner of the destination rectangle * in which the image should be drawn, in pixels. * * @param w * The width of the image, in pixels. * * @param h * The height of the image, in pixels. */ void guac_vnc_update(rfbClient* client, int x, int y, int w, int h); /** * Callback invoked by libVNCServer when it receives a CopyRect message. * CopyRect specified a rectangle of source data within the display and a * set of X/Y coordinates to which that rectangle should be copied. * * @param client * The VNC client associated with the VNC session in which the CopyRect * was received. * * @param src_x * The X coordinate of the upper-left corner of the source rectangle * from which the image data should be copied, in pixels. * * @param src_y * The Y coordinate of the upper-left corner of the source rectangle * from which the image data should be copied, in pixels. * * @param w * The width of the source and destination rectangles, in pixels. * * @param h * The height of the source and destination rectangles, in pixels. * * @param dest_x * The X coordinate of the upper-left corner of the destination rectangle * in which the copied image data should be drawn, in pixels. * * @param dest_y * The Y coordinate of the upper-left corner of the destination rectangle * in which the copied image data should be drawn, in pixels. */ void guac_vnc_copyrect(rfbClient* client, int src_x, int src_y, int w, int h, int dest_x, int dest_y); /** * Sets the pixel format to request of the VNC server. The request will be made * during the connection handshake with the VNC server using the values * specified by this function. Note that the VNC server is not required to * honor this request. * * @param client * The VNC client associated with the VNC session whose desired pixel * format should be set. * * @param color_depth * The desired new color depth, in bits per pixel. Valid values are 8, 16, * 24, and 32. */ void guac_vnc_set_pixel_format(rfbClient* client, int color_depth); /** * Overridden implementation of the rfb_MallocFrameBuffer function invoked by * libVNCServer when the display is being resized (or initially allocated). * * @param client * The VNC client associated with the VNC session whose display needs to be * allocated or reallocated. * * @return * The original value returned by rfb_MallocFrameBuffer(). */ rfbBool guac_vnc_malloc_framebuffer(rfbClient* rfb_client); #endif