blob: eb17a529070f2fdb19c85e983b6783f6c0058747 [file] [log] [blame]
Constantin Kaplinsky47ed8d32004-10-08 09:43:57 +00001/* Copyright (C) 2002-2004 RealVNC Ltd. All Rights Reserved.
2 *
3 * This is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation; either version 2 of the License, or
6 * (at your option) any later version.
7 *
8 * This software is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this software; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
16 * USA.
17 */
18
19/////////////////////////////////////////////////////////////////////////////
20
21// SDesktop is an interface implemented by back-ends, on which callbacks are
22// made by the VNCServer as appropriate for pointer and keyboard events, etc.
23// SDesktop objects are always created before the VNCServer - the SDesktop
24// will be passed a pointer to the VNCServer in the start() call. If a more
25// implementation-specific pointer to the VNCServer is required then this
26// can be provided to the SDesktop via an implementation-specific method.
27//
28// An SDesktop usually has an associated PixelBuffer which it tells the
29// VNCServer via the VNCServer's setPixelBuffer() method. It can do this at
30// any time, but the PixelBuffer MUST be valid by the time the call to start()
31// returns. The PixelBuffer may be set to null again if desired when stop() is
32// called. Note that start() and stop() are guaranteed to be called
33// alternately; there should never be two calls to start() without an
34// intervening stop() and vice-versa.
35//
36
37#ifndef __RFB_SDESKTOP_H__
38#define __RFB_SDESKTOP_H__
39
40#include <rfb/PixelBuffer.h>
41#include <rfb/VNCServer.h>
42#include <rfb/Exception.h>
43
44namespace rfb {
45
46 class VNCServer;
47
48 class SDesktop {
49 public:
50 // start() is called by the server when the first client authenticates
51 // successfully, and can be used to begin any expensive tasks which are not
52 // needed when there are no clients. A valid PixelBuffer must have been
53 // set via the VNCServer's setPixelBuffer() method by the time this call
54 // returns.
55
56 virtual void start(VNCServer* vs) {}
57
58 // stop() is called by the server when there are no longer any
59 // authenticated clients, and therefore the desktop can cease any
60 // expensive tasks. No further calls to the VNCServer passed to start()
61 // can be made once stop has returned.
62
63 virtual void stop() {}
64
65 // pointerEvent(), keyEvent() and clientCutText() are called in response to
66 // the relevant RFB protocol messages from clients.
67
68 virtual void pointerEvent(const Point& pos, rdr::U8 buttonmask) {}
69 virtual void keyEvent(rdr::U32 key, bool down) {}
70 virtual void clientCutText(const char* str, int len) {}
71
72 // framebufferUpdateRequest() is called to let the desktop know that at
73 // least one client has become ready for an update. Desktops can check
74 // whether there are clients ready at any time by calling the VNCServer's
75 // clientsReadyForUpdate() method.
76
77 virtual void framebufferUpdateRequest() {}
78
79 // getFbSize() returns the current dimensions of the framebuffer.
80 // This can be called even while the SDesktop is not start()ed.
81
82 virtual Point getFbSize() = 0;
83
84 protected:
85 virtual ~SDesktop() {}
86 };
87
88 // -=- SStaticDesktop
89 // Trivial implementation of the SDesktop interface, which provides
90 // dummy input handlers and event processing routine, and exports
91 // a plain black desktop of the specified format.
92 class SStaticDesktop : public SDesktop {
93 public:
94 SStaticDesktop(const Point& size) : server(0), buffer(0) {
95 PixelFormat pf;
96 buffer = new ManagedPixelBuffer(pf, size.x, size.y);
97 if (buffer) memset(buffer->data, 0, (pf.bpp/8) * (size.x*size.y));
98 }
99 SStaticDesktop(const Point& size, const PixelFormat& pf) : buffer(0) {
100 buffer = new ManagedPixelBuffer(pf, size.x, size.y);
101 if (buffer) memset(buffer->data, 0, (pf.bpp/8) * (size.x*size.y));
102 }
103 virtual ~SStaticDesktop() {
104 if (buffer) delete buffer;
105 }
106
107 virtual void start(VNCServer* vs) {
108 server = vs;
109 server->setPixelBuffer(buffer);
110 }
111 virtual void stop() {
112 server->setPixelBuffer(0);
113 server = 0;
114 }
115
116 protected:
117 VNCServer* server;
118 ManagedPixelBuffer* buffer;
119 };
120
121};
122
123#endif // __RFB_SDESKTOP_H__