2007-06-11 11:50:49 +00:00
|
|
|
/* $Id$ */
|
|
|
|
|
2009-08-21 20:21:05 +00:00
|
|
|
/*
|
|
|
|
* This file is part of OpenTTD.
|
|
|
|
* 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.
|
|
|
|
* 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.
|
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
2008-05-06 15:11:33 +00:00
|
|
|
/** @file spriteloader.hpp Base for loading sprites. */
|
2007-06-11 11:50:49 +00:00
|
|
|
|
|
|
|
#ifndef SPRITELOADER_HPP
|
|
|
|
#define SPRITELOADER_HPP
|
|
|
|
|
2009-02-23 17:54:02 +00:00
|
|
|
#include "../core/alloc_type.hpp"
|
|
|
|
|
2007-06-11 11:50:49 +00:00
|
|
|
class SpriteLoader {
|
|
|
|
public:
|
|
|
|
struct CommonPixel {
|
|
|
|
uint8 r; ///< Red-channel
|
|
|
|
uint8 g; ///< Green-channel
|
|
|
|
uint8 b; ///< Blue-channel
|
|
|
|
uint8 a; ///< Alpha-channel
|
|
|
|
uint8 m; ///< Remap-channel
|
|
|
|
};
|
|
|
|
|
2009-02-23 10:50:25 +00:00
|
|
|
/**
|
|
|
|
* Structure for passing information from the sprite loader to the blitter.
|
|
|
|
* You can only use this struct once at a time when using AllocateData to
|
|
|
|
* allocate the memory as that will always return the same memory address.
|
|
|
|
* This to prevent thousands of malloc + frees just to load a sprite.
|
|
|
|
*/
|
2007-06-11 11:50:49 +00:00
|
|
|
struct Sprite {
|
|
|
|
uint16 height; ///< Height of the sprite
|
|
|
|
uint16 width; ///< Width of the sprite
|
|
|
|
int16 x_offs; ///< The x-offset of where the sprite will be drawn
|
|
|
|
int16 y_offs; ///< The y-offset of where the sprite will be drawn
|
|
|
|
SpriteLoader::CommonPixel *data; ///< The sprite itself
|
2009-02-23 10:50:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocate the sprite data of this sprite.
|
|
|
|
* @param size the minimum size of the data field.
|
|
|
|
*/
|
2009-02-23 17:54:02 +00:00
|
|
|
void AllocateData(size_t size) { this->data = Sprite::buffer.ZeroAllocate(size); }
|
2009-02-23 10:50:25 +00:00
|
|
|
private:
|
|
|
|
/** Allocated memory to pass sprite data around */
|
2009-02-23 17:54:02 +00:00
|
|
|
static ReusableBuffer<SpriteLoader::CommonPixel> buffer;
|
2007-06-11 11:50:49 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load a sprite from the disk and return a sprite struct which is the same for all loaders.
|
|
|
|
*/
|
2008-09-02 15:20:38 +00:00
|
|
|
virtual bool LoadSprite(SpriteLoader::Sprite *sprite, uint8 file_slot, size_t file_pos, SpriteType sprite_type) = 0;
|
2007-06-11 11:50:49 +00:00
|
|
|
|
|
|
|
virtual ~SpriteLoader() { }
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* SPRITELOADER_HPP */
|