blob: 6e23ad33648f29165f6c7eeb3ca68f58bb4178f9 [file] [log] [blame]
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +00001/* Copyright (C) 2002-2005 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#include <rdr/OutStream.h>
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000019#include <rfb/encodings.h>
20#include <rfb/SMsgWriter.h>
Pierre Ossman668468b2014-01-31 12:37:32 +010021#include <rfb/SConnection.h>
Pierre Ossman0c9bd4b2014-07-09 16:44:11 +020022#include <rfb/PixelFormat.h>
23#include <rfb/PixelBuffer.h>
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000024#include <rfb/RREEncoder.h>
25
26using namespace rfb;
27
28#define BPP 8
29#include <rfb/rreEncode.h>
30#undef BPP
31#define BPP 16
32#include <rfb/rreEncode.h>
33#undef BPP
34#define BPP 32
35#include <rfb/rreEncode.h>
36#undef BPP
37
Pierre Ossman668468b2014-01-31 12:37:32 +010038RREEncoder::RREEncoder(SConnection* conn) : RawEncoder(conn)
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000039{
40}
41
42RREEncoder::~RREEncoder()
43{
44}
45
Pierre Ossman0c9bd4b2014-07-09 16:44:11 +020046void RREEncoder::writeRect(const Rect& r, PixelBuffer* pb)
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000047{
48 int w = r.width();
49 int h = r.height();
Pierre Ossman668468b2014-01-31 12:37:32 +010050 rdr::U8* imageBuf = conn->writer()->getImageBuf(w*h);
Pierre Ossman0c9bd4b2014-07-09 16:44:11 +020051 pb->getImage(conn->cp.pf(), imageBuf, r);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000052
53 mos.clear();
54
55 int nSubrects = -1;
Pierre Ossman668468b2014-01-31 12:37:32 +010056 switch (conn->cp.pf().bpp) {
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000057 case 8: nSubrects = rreEncode8(imageBuf, w, h, &mos); break;
58 case 16: nSubrects = rreEncode16(imageBuf, w, h, &mos); break;
59 case 32: nSubrects = rreEncode32(imageBuf, w, h, &mos); break;
60 }
61
62 if (nSubrects < 0) {
Pierre Ossman0c9bd4b2014-07-09 16:44:11 +020063 RawEncoder::writeRect(r, pb);
Pierre Ossman717c07b2014-01-21 14:45:10 +010064 return;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000065 }
66
Pierre Ossman668468b2014-01-31 12:37:32 +010067 conn->writer()->startRect(r, encodingRRE);
68 rdr::OutStream* os = conn->getOutStream();
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000069 os->writeU32(nSubrects);
70 os->writeBytes(mos.data(), mos.length());
Pierre Ossman668468b2014-01-31 12:37:32 +010071 conn->writer()->endRect();
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000072}