2023-10-19 16:19:09 +02:00
|
|
|
/*
|
|
|
|
* IImage.h, part of VCMI engine
|
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "../../lib/filesystem/ResourcePath.h"
|
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
|
|
|
class PlayerColor;
|
|
|
|
class Rect;
|
|
|
|
class Point;
|
|
|
|
class ColorRGBA;
|
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|
|
|
|
|
|
|
|
struct SDL_Surface;
|
2024-07-24 13:35:30 +00:00
|
|
|
struct SDL_Palette;
|
2023-10-19 16:19:09 +02:00
|
|
|
class ColorFilter;
|
2024-07-25 10:38:48 +00:00
|
|
|
class ISharedImage;
|
2023-10-19 16:19:09 +02:00
|
|
|
|
|
|
|
/// Defines which blit method will be selected when image is used for rendering
|
2024-07-25 10:38:48 +00:00
|
|
|
enum class EImageBlitMode : uint8_t
|
2023-10-19 16:19:09 +02:00
|
|
|
{
|
2024-06-08 07:35:13 +00:00
|
|
|
/// Preferred for images that don't need any background
|
|
|
|
/// Indexed or RGBA: Image can have no transparency and can be only used as background
|
2023-10-19 16:19:09 +02:00
|
|
|
OPAQUE,
|
|
|
|
|
2024-06-08 07:35:13 +00:00
|
|
|
/// Preferred for images that may need transparency
|
|
|
|
/// Indexed: Image can have only a single color as transparency and has no semi-transparent areas
|
|
|
|
/// RGBA: full alpha transparency range, e.g. shadows
|
2023-10-19 16:19:09 +02:00
|
|
|
COLORKEY,
|
|
|
|
|
2024-06-08 07:35:13 +00:00
|
|
|
/// Should be avoided if possible, use only for images that use def's with semi-transparency
|
|
|
|
/// Indexed or RGBA: Image might have full alpha transparency range, e.g. shadows
|
2023-10-19 16:19:09 +02:00
|
|
|
ALPHA
|
|
|
|
};
|
|
|
|
|
2024-07-25 10:38:48 +00:00
|
|
|
/// Base class for images for use in client code.
|
|
|
|
/// This class represents current state of image, with potential transformations applied, such as player coloring
|
2023-10-19 16:19:09 +02:00
|
|
|
class IImage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//draws image on surface "where" at position
|
2024-06-04 11:46:45 +00:00
|
|
|
virtual void draw(SDL_Surface * where, const Point & pos, const Rect * src = nullptr) const = 0;
|
2023-10-19 16:19:09 +02:00
|
|
|
|
2024-07-25 18:22:27 +00:00
|
|
|
virtual void scaleTo(const Point & size) = 0;
|
|
|
|
virtual void scaleInteger(int factor) = 0;
|
2023-10-19 16:19:09 +02:00
|
|
|
|
|
|
|
virtual void exportBitmap(const boost::filesystem::path & path) const = 0;
|
|
|
|
|
|
|
|
//Change palette to specific player
|
2024-06-04 16:09:25 +00:00
|
|
|
virtual void playerColored(PlayerColor player) = 0;
|
2023-10-19 16:19:09 +02:00
|
|
|
|
|
|
|
//test transparency of specific pixel
|
|
|
|
virtual bool isTransparent(const Point & coords) const = 0;
|
|
|
|
|
|
|
|
virtual Point dimensions() const = 0;
|
|
|
|
int width() const;
|
|
|
|
int height() const;
|
|
|
|
|
|
|
|
//only indexed bitmaps, 16 colors maximum
|
|
|
|
virtual void shiftPalette(uint32_t firstColorID, uint32_t colorsToMove, uint32_t distanceToMove) = 0;
|
|
|
|
virtual void adjustPalette(const ColorFilter & shifter, uint32_t colorsToSkipMask) = 0;
|
|
|
|
|
|
|
|
virtual void setAlpha(uint8_t value) = 0;
|
|
|
|
virtual void setBlitMode(EImageBlitMode mode) = 0;
|
|
|
|
|
|
|
|
//only indexed bitmaps with 7 special colors
|
2024-07-25 10:38:48 +00:00
|
|
|
virtual void setOverlayColor(const ColorRGBA & color) = 0;
|
|
|
|
|
|
|
|
virtual void setShadowEnabled(bool on) = 0;
|
|
|
|
virtual void setBodyEnabled(bool on) = 0;
|
|
|
|
virtual void setOverlayEnabled(bool on) = 0;
|
|
|
|
virtual std::shared_ptr<ISharedImage> getSharedImage() const = 0;
|
2023-10-19 16:19:09 +02:00
|
|
|
|
|
|
|
virtual ~IImage() = default;
|
|
|
|
};
|
2024-06-04 11:46:45 +00:00
|
|
|
|
2024-07-25 10:38:48 +00:00
|
|
|
/// Base class for image data, mostly for internal use
|
|
|
|
/// Represents unmodified pixel data, usually loaded from file
|
|
|
|
/// This image can be shared between multiple image handlers (IImage instances)
|
2024-07-24 13:04:45 +00:00
|
|
|
class ISharedImage
|
2024-06-04 11:46:45 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual Point dimensions() const = 0;
|
2024-09-12 16:11:03 +00:00
|
|
|
virtual void exportBitmap(const boost::filesystem::path & path, SDL_Palette * palette) const = 0;
|
2024-06-04 11:46:45 +00:00
|
|
|
virtual bool isTransparent(const Point & coords) const = 0;
|
2024-07-25 10:38:48 +00:00
|
|
|
virtual void draw(SDL_Surface * where, SDL_Palette * palette, const Point & dest, const Rect * src, const ColorRGBA & colorMultiplier, uint8_t alpha, EImageBlitMode mode) const = 0;
|
2024-06-04 11:46:45 +00:00
|
|
|
|
2024-06-08 07:35:13 +00:00
|
|
|
virtual std::shared_ptr<IImage> createImageReference(EImageBlitMode mode) = 0;
|
2024-06-04 11:46:45 +00:00
|
|
|
|
2024-07-24 13:04:45 +00:00
|
|
|
virtual std::shared_ptr<ISharedImage> horizontalFlip() const = 0;
|
|
|
|
virtual std::shared_ptr<ISharedImage> verticalFlip() const = 0;
|
2024-07-25 18:22:27 +00:00
|
|
|
virtual std::shared_ptr<ISharedImage> scaleInteger(int factor, SDL_Palette * palette) const = 0;
|
|
|
|
virtual std::shared_ptr<ISharedImage> scaleTo(const Point & size, SDL_Palette * palette) const = 0;
|
2024-06-05 20:16:12 +00:00
|
|
|
|
|
|
|
|
2024-07-24 13:04:45 +00:00
|
|
|
virtual ~ISharedImage() = default;
|
2024-06-04 11:46:45 +00:00
|
|
|
};
|