1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
#include "titanic/support/direct_draw_surface.h"
namespace Titanic {
DirectDrawSurface::DirectDrawSurface() : _surface(nullptr),
_disposeAfterUse(DisposeAfterUse::YES) {
}
DirectDrawSurface::~DirectDrawSurface() {
free();
}
void DirectDrawSurface::create(Graphics::ManagedSurface *surface) {
free();
_surface = surface;
_disposeAfterUse = DisposeAfterUse::NO;
}
void DirectDrawSurface::create(int w, int h, int bpp) {
assert(bpp == 16 || bpp == 32);
Graphics::PixelFormat pixelFormat = (bpp == 32) ?
Graphics::PixelFormat(4, 8, 8, 8, 8, 24, 16, 8, 0) :
Graphics::PixelFormat(2, 5, 6, 5, 0, 11, 5, 0, 0);
_surface = new Graphics::ManagedSurface(w, h, pixelFormat);
_disposeAfterUse = DisposeAfterUse::YES;
}
void DirectDrawSurface::free() {
if (_disposeAfterUse == DisposeAfterUse::YES)
delete _surface;
_surface = nullptr;
_disposeAfterUse = DisposeAfterUse::NO;
}
Graphics::ManagedSurface *DirectDrawSurface::lock(const Rect *bounds, int flags) {
assert(!_surface->empty());
return _surface;
}
void DirectDrawSurface::unlock() {
assert(_surface->w != 0 && _surface->h != 0);
}
void DirectDrawSurface::fill(const Rect *bounds, uint32 color) {
Rect tempBounds;
assert(_surface);
if (bounds) {
// Bounds are provided, clip them to the bounds of this surface
tempBounds = *bounds;
tempBounds.clip(Rect(0, 0, _surface->w, _surface->h));
} else {
// No bounds provided, so use the entire surface
tempBounds = Rect(0, 0, _surface->w, _surface->h);
}
// Fill the area
_surface->fillRect(tempBounds, color);
}
void DirectDrawSurface::fillRect(Rect *rect, byte r, byte g, byte b) {
uint color = _surface->format.RGBToColor(r, g, b);
Rect tempRect = rect ? *rect : Rect(0, 0, getWidth(), getHeight());
_surface->fillRect(tempRect, color);
}
void DirectDrawSurface::blit(const Rect &destRect, DirectDrawSurface *srcSurface, Rect &srcRect) {
assert(srcSurface);
if (!destRect.isEmpty())
_surface->transBlitFrom(*srcSurface->_surface, srcRect, destRect, (uint)-1);
}
void DirectDrawSurface::blit(const Point &destPos, DirectDrawSurface *srcSurface, Rect *bounds) {
if (bounds)
_surface->blitFrom(*srcSurface->_surface, *bounds, destPos);
else
_surface->blitFrom(*srcSurface->_surface, destPos);
}
} // End of namespace Titanic
|