2023-10-19 16:19:09 +02:00
|
|
|
/*
|
|
|
|
* Canvas.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 "../gui/TextAlignment.h"
|
|
|
|
#include "../../lib/Rect.h"
|
|
|
|
#include "../../lib/Color.h"
|
|
|
|
|
|
|
|
struct SDL_Surface;
|
|
|
|
class IImage;
|
2024-09-23 15:43:11 +00:00
|
|
|
enum EFonts : int8_t;
|
2023-10-19 16:19:09 +02:00
|
|
|
|
2024-07-22 11:00:45 +00:00
|
|
|
enum class CanvasScalingPolicy
|
|
|
|
{
|
|
|
|
AUTO, // automatically scale canvas operations by global scaling factor
|
|
|
|
IGNORE // disable any scaling processing. Scaling factor will be set to 1
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2023-10-19 16:19:09 +02:00
|
|
|
/// Class that represents surface for drawing on
|
|
|
|
class Canvas
|
|
|
|
{
|
2024-07-22 11:00:45 +00:00
|
|
|
/// Upscaler awareness. Must be first member for initialization
|
|
|
|
CanvasScalingPolicy scalingPolicy;
|
|
|
|
|
2023-10-19 16:19:09 +02:00
|
|
|
/// Target surface
|
|
|
|
SDL_Surface * surface;
|
|
|
|
|
|
|
|
/// Current rendering area, all rendering operations will be moved into selected area
|
|
|
|
Rect renderArea;
|
|
|
|
|
|
|
|
/// constructs canvas using existing surface. Caller maintains ownership on the surface
|
2024-07-22 11:00:45 +00:00
|
|
|
explicit Canvas(SDL_Surface * surface, CanvasScalingPolicy scalingPolicy);
|
2023-10-19 16:19:09 +02:00
|
|
|
|
2024-06-24 03:23:26 +02:00
|
|
|
/// copy constructor
|
2023-10-19 16:19:09 +02:00
|
|
|
Canvas(const Canvas & other);
|
|
|
|
|
2024-07-21 21:11:02 +00:00
|
|
|
Point transformPos(const Point & input);
|
|
|
|
Point transformSize(const Point & input);
|
|
|
|
|
2023-10-19 16:19:09 +02:00
|
|
|
public:
|
|
|
|
Canvas & operator = (const Canvas & other) = delete;
|
|
|
|
Canvas & operator = (Canvas && other) = delete;
|
|
|
|
|
2024-06-24 03:23:26 +02:00
|
|
|
/// move constructor
|
2023-10-19 16:19:09 +02:00
|
|
|
Canvas(Canvas && other);
|
|
|
|
|
|
|
|
/// creates canvas that only covers specified subsection of a surface
|
|
|
|
Canvas(const Canvas & other, const Rect & clipRect);
|
|
|
|
|
|
|
|
/// constructs canvas of specified size
|
2024-07-22 11:00:45 +00:00
|
|
|
explicit Canvas(const Point & size, CanvasScalingPolicy scalingPolicy);
|
2023-10-19 16:19:09 +02:00
|
|
|
|
|
|
|
/// constructs canvas using existing surface. Caller maintains ownership on the surface
|
|
|
|
/// Compatibility method. AVOID USAGE. To be removed once SDL abstraction layer is finished.
|
2024-07-22 11:00:45 +00:00
|
|
|
static Canvas createFromSurface(SDL_Surface * surface, CanvasScalingPolicy scalingPolicy);
|
2023-10-19 16:19:09 +02:00
|
|
|
|
|
|
|
~Canvas();
|
|
|
|
|
|
|
|
/// if set to true, drawing this canvas onto another canvas will use alpha channel information
|
|
|
|
void applyTransparency(bool on);
|
|
|
|
|
|
|
|
/// applies grayscale filter onto current image
|
|
|
|
void applyGrayscale();
|
|
|
|
|
|
|
|
/// renders image onto this canvas at specified position
|
|
|
|
void draw(const std::shared_ptr<IImage>& image, const Point & pos);
|
|
|
|
|
|
|
|
/// renders section of image bounded by sourceRect at specified position
|
|
|
|
void draw(const std::shared_ptr<IImage>& image, const Point & pos, const Rect & sourceRect);
|
|
|
|
|
|
|
|
/// renders another canvas onto this canvas
|
|
|
|
void draw(const Canvas &image, const Point & pos);
|
|
|
|
|
|
|
|
/// renders another canvas onto this canvas with transparency
|
|
|
|
void drawTransparent(const Canvas & image, const Point & pos, double transparency);
|
|
|
|
|
|
|
|
/// renders another canvas onto this canvas with scaling
|
|
|
|
void drawScaled(const Canvas &image, const Point & pos, const Point & targetSize);
|
|
|
|
|
|
|
|
/// renders single pixels with specified color
|
|
|
|
void drawPoint(const Point & dest, const ColorRGBA & color);
|
|
|
|
|
|
|
|
/// renders continuous, 1-pixel wide line with color gradient
|
|
|
|
void drawLine(const Point & from, const Point & dest, const ColorRGBA & colorFrom, const ColorRGBA & colorDest);
|
|
|
|
|
|
|
|
/// renders rectangular, solid-color border in specified location
|
|
|
|
void drawBorder(const Rect & target, const ColorRGBA & color, int width = 1);
|
|
|
|
|
|
|
|
/// renders rectangular, dashed border in specified location
|
|
|
|
void drawBorderDashed(const Rect & target, const ColorRGBA & color);
|
|
|
|
|
|
|
|
/// renders single line of text with specified parameters
|
|
|
|
void drawText(const Point & position, const EFonts & font, const ColorRGBA & colorDest, ETextAlignment alignment, const std::string & text );
|
|
|
|
|
|
|
|
/// renders multiple lines of text with specified parameters
|
|
|
|
void drawText(const Point & position, const EFonts & font, const ColorRGBA & colorDest, ETextAlignment alignment, const std::vector<std::string> & text );
|
|
|
|
|
|
|
|
/// fills selected area with solid color
|
|
|
|
void drawColor(const Rect & target, const ColorRGBA & color);
|
|
|
|
|
|
|
|
/// fills selected area with blended color
|
|
|
|
void drawColorBlended(const Rect & target, const ColorRGBA & color);
|
|
|
|
|
2024-01-18 00:47:18 +01:00
|
|
|
/// fills canvas with texture
|
|
|
|
void fillTexture(const std::shared_ptr<IImage>& image);
|
|
|
|
|
2024-07-21 21:11:02 +00:00
|
|
|
int getScalingFactor() const;
|
|
|
|
|
2023-10-19 16:19:09 +02:00
|
|
|
/// Compatibility method. AVOID USAGE. To be removed once SDL abstraction layer is finished.
|
|
|
|
SDL_Surface * getInternalSurface();
|
2023-10-22 18:36:41 +03:00
|
|
|
|
|
|
|
/// get the render area
|
|
|
|
Rect getRenderArea() const;
|
2023-10-19 16:19:09 +02:00
|
|
|
};
|