(svn r27756) -Codechange: Add StringTab enum
[openttd.git] / src / blitter / 32bpp_anim.hpp
bloba0a022e49f20cb004682f8c18b63ba6ae99fff82
1 /* $Id$ */
3 /*
4 * This file is part of OpenTTD.
5 * OpenTTD 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, version 2.
6 * OpenTTD 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.
7 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
8 */
10 /** @file 32bpp_anim.hpp A 32 bpp blitter with animation support. */
12 #ifndef BLITTER_32BPP_ANIM_HPP
13 #define BLITTER_32BPP_ANIM_HPP
15 #include "32bpp_optimized.hpp"
17 /** The optimised 32 bpp blitter with palette animation. */
18 class Blitter_32bppAnim : public Blitter_32bppOptimized {
19 protected:
20 uint16 *anim_buf; ///< In this buffer we keep track of the 8bpp indexes so we can do palette animation
21 int anim_buf_width; ///< The width of the animation buffer.
22 int anim_buf_height; ///< The height of the animation buffer.
23 Palette palette; ///< The current palette.
25 public:
26 Blitter_32bppAnim() :
27 anim_buf(NULL),
28 anim_buf_width(0),
29 anim_buf_height(0)
32 ~Blitter_32bppAnim();
34 /* virtual */ void Draw(Blitter::BlitterParams *bp, BlitterMode mode, ZoomLevel zoom);
35 /* virtual */ void DrawColourMappingRect(void *dst, int width, int height, PaletteID pal);
36 /* virtual */ void SetPixel(void *video, int x, int y, uint8 colour);
37 /* virtual */ void DrawRect(void *video, int width, int height, uint8 colour);
38 /* virtual */ void CopyFromBuffer(void *video, const void *src, int width, int height);
39 /* virtual */ void CopyToBuffer(const void *video, void *dst, int width, int height);
40 /* virtual */ void ScrollBuffer(void *video, int &left, int &top, int &width, int &height, int scroll_x, int scroll_y);
41 /* virtual */ int BufferSize(int width, int height);
42 /* virtual */ void PaletteAnimate(const Palette &palette);
43 /* virtual */ Blitter::PaletteAnimation UsePaletteAnimation();
45 /* virtual */ const char *GetName() { return "32bpp-anim"; }
46 /* virtual */ int GetBytesPerPixel() { return 6; }
47 /* virtual */ void PostResize();
49 /**
50 * Look up the colour in the current palette.
52 inline Colour LookupColourInPalette(uint index)
54 return this->palette.palette[index];
57 template <BlitterMode mode> void Draw(const Blitter::BlitterParams *bp, ZoomLevel zoom);
60 /** Factory for the 32bpp blitter with animation. */
61 class FBlitter_32bppAnim : public BlitterFactory {
62 public:
63 FBlitter_32bppAnim() : BlitterFactory("32bpp-anim", "32bpp Animation Blitter (palette animation)") {}
64 /* virtual */ Blitter *CreateInstance() { return new Blitter_32bppAnim(); }
67 #endif /* BLITTER_32BPP_ANIM_HPP */