blob: be921f951a5f6bbedf120f9ed5801f9507b548b6 [file] [log] [blame]
Constantin Kaplinsky729598c2006-05-25 05:12:25 +00001/* Copyright (C) 2006 TightVNC Team. 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 * TightVNC distribution homepage on the Web: http://www.tightvnc.com/
19 *
20 */
21
22// -=- ScaledDIBSectionBuffer.cxx
23
24#include <math.h>
25
26#include <rfb_win32/ScaledDIBSectionBuffer.h>
27
28using namespace rfb;
29using namespace win32;
30
31ScaledDIBSectionBuffer::ScaledDIBSectionBuffer(HWND window)
32 : src_buffer(0), scaling(false), DIBSectionBuffer(window) {
33 scaled_data = data;
34}
35
36ScaledDIBSectionBuffer::~ScaledDIBSectionBuffer() {
37 if (src_buffer) delete src_buffer;
38}
39
40void ScaledDIBSectionBuffer::setScale(int scale_) {
41 if (scale_ == getScale()) return;
42
Constantin Kaplinsky729598c2006-05-25 05:12:25 +000043 if (scale_ != 100) {
44 scaling = true;
Constantin Kaplinsky1ae2eb02006-05-26 05:24:24 +000045 if (!src_buffer) {
46 src_buffer = new ManagedPixelBuffer(format, src_width, src_height);
47 src_data = &(src_buffer->data);
george82e89d47f2006-05-27 12:31:08 +000048 memcpy(src_buffer->data, data, area() * (getPF().bpp/8));
Constantin Kaplinsky1ae2eb02006-05-26 05:24:24 +000049 }
Constantin Kaplinsky729598c2006-05-25 05:12:25 +000050 } else {
51 scaling = false;
52 }
53 ScaledPixelBuffer::setScale(scale_);
Constantin Kaplinsky1ae2eb02006-05-26 05:24:24 +000054 recreateScaledBuffer();
george82e89d47f2006-05-27 12:31:08 +000055 if (scaling) {
56 scaleRect(Rect(0, 0, src_width, src_height));
57 } else {
58 memcpy(data, src_buffer->data, src_buffer->area() * (src_buffer->getPF().bpp/8));
59 if (src_buffer) {
60 delete src_buffer;
61 src_buffer = 0;
62 src_data = 0;
63 }
64 }
Constantin Kaplinsky729598c2006-05-25 05:12:25 +000065}
66
Constantin Kaplinsky1ae2eb02006-05-26 05:24:24 +000067void ScaledDIBSectionBuffer::setPF(const PixelFormat &pf_) {
68 if (scaling) {
69 ScaledPixelBuffer::setPF(pf_);
70 src_buffer->setPF(pf_);
71 }
72 DIBSectionBuffer::setPF(pf_);
Constantin Kaplinsky729598c2006-05-25 05:12:25 +000073 scaled_data = data;
74}
75
76void ScaledDIBSectionBuffer::setSize(int src_width_, int src_height_) {
77 src_width = src_width_;
78 src_height = src_height_;
79 if (scaling) {
80 src_buffer->setSize(src_width, src_height);
81 }
82 calculateScaledBufferSize();
83 recreateScaledBuffer();
84 scaled_data = data;
85}
86
87void ScaledDIBSectionBuffer::recreateScaledBuffer() {
88 width_ = scaled_width;
89 height_ = scaled_height;
90 DIBSectionBuffer::recreateBuffer();
91 scaled_data = data;
92}
93
94void ScaledDIBSectionBuffer::fillRect(const Rect &dest, Pixel pix) {
95 if (scaling) {
96 src_buffer->fillRect(dest, pix);
97 scaleRect(dest);
98 } else {
99 DIBSectionBuffer::fillRect(dest, pix);
100 }
101}
102
103void ScaledDIBSectionBuffer::imageRect(const Rect &dest, const void* pixels, int stride) {
104 if (scaling) {
105 src_buffer->imageRect(dest, pixels, stride);
106 scaleRect(dest);
107 } else {
108 DIBSectionBuffer::imageRect(dest, pixels, stride);
109 }
110}
111
112void ScaledDIBSectionBuffer::copyRect(const Rect &dest, const Point &move_by_delta) {
113 if (scaling) {
114 src_buffer->copyRect(dest, move_by_delta);
115 scaleRect(dest);
116 } else {
117 DIBSectionBuffer::copyRect(dest, move_by_delta);
118 }
119}
120
121void ScaledDIBSectionBuffer::maskRect(const Rect& r, const void* pixels, const void* mask_) {
122 if (scaling) {
123 src_buffer->maskRect(r, pixels, mask_);
124 scaleRect(r);
125 } else {
126 DIBSectionBuffer::maskRect(r, pixels, mask_);
127 }
128}
129
130void ScaledDIBSectionBuffer::maskRect(const Rect& r, Pixel pixel, const void* mask_) {
131 if (scaling) {
132 src_buffer->maskRect(r, pixel, mask_);
133 scaleRect(r);
134 } else {
135 DIBSectionBuffer::maskRect(r, pixel, mask_);
136 }
137}