The Battle for Wesnoth  1.19.8+dev
canvas_private.hpp
Go to the documentation of this file.
1 /*
2  Copyright (C) 2007 - 2024
3  by Mark de Wever <koraq@xs4all.nl>
4  Part of the Battle for Wesnoth Project https://www.wesnoth.org/
5 
6  This program is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2 of the License, or
9  (at your option) any later version.
10  This program is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY.
12 
13  See the COPYING file for more details.
14 */
15 
16 #include "gui/core/canvas.hpp"
18 
19 namespace gui2
20 {
21 
22 class line_shape : public canvas::shape
23 {
24 public:
25  /**
26  * Constructor.
27  *
28  * @param cfg The config object to define the line.
29  */
30  explicit line_shape(const config& cfg);
31 
32  void draw(wfl::map_formula_callable& variables) override;
33 
34 private:
35  typed_formula<unsigned> x1_; /**< The start x coordinate of the line. */
36  typed_formula<unsigned> y1_; /**< The start y coordinate of the line. */
37  typed_formula<unsigned> x2_; /**< The end x coordinate of the line. */
38  typed_formula<unsigned> y2_; /**< The end y coordinate of the line. */
39 
40  /** The color of the line. */
42 
43  /**
44  * The thickness of the line.
45  *
46  * if the value is odd the x and y are the middle of the line.
47  * if the value is even the x and y are the middle of a line
48  * with width - 1. (0 is special case, does nothing.)
49  */
50  unsigned thickness_;
51 };
52 
54 {
55 protected:
56  /**
57  * Constructor.
58  *
59  * @param cfg The config object to define the rectangle.
60  */
61  explicit rect_bounded_shape(const config& cfg)
62  : shape(cfg)
63  , x_(cfg["x"])
64  , y_(cfg["y"])
65  , w_(cfg["w"])
66  , h_(cfg["h"])
67  {
68  }
69 
70  typed_formula<int> x_; /**< The x coordinate of the rectangle. */
71  typed_formula<int> y_; /**< The y coordinate of the rectangle. */
72  typed_formula<int> w_; /**< The width of the rectangle. */
73  typed_formula<int> h_; /**< The height of the rectangle. */
74 };
75 
77 {
78 public:
79  /**
80  * Constructor.
81  *
82  * @param cfg The config object to define the rectangle.
83  */
84  explicit rectangle_shape(const config& cfg);
85 
86  void draw(wfl::map_formula_callable& variables) override;
87 
88 private:
89  /**
90  * Border thickness.
91  *
92  * If 0 the fill color is used for the entire widget.
93  */
95 
96  /**
97  * The border color of the rectangle.
98  *
99  * If the color is fully transparent the border isn't drawn.
100  */
102 
103  /**
104  * The border color of the rectangle.
105  *
106  * If the color is fully transparent the rectangle won't be filled.
107  */
109 };
110 
112 {
113 public:
114  /**
115  * Constructor.
116  *
117  * @param cfg The config object to define the round rectangle.
118  */
119  explicit round_rectangle_shape(const config& cfg);
120 
121  void draw(wfl::map_formula_callable& variables) override;
122 
123 private:
124  typed_formula<int> r_; /**< The radius of the corners. */
125 
126  /**
127  * Border thickness.
128  *
129  * If 0 the fill color is used for the entire widget.
130  */
132 
133  /**
134  * The border color of the rounded rectangle.
135  *
136  * If the color is fully transparent the border isn't drawn.
137  */
139 
140  /**
141  * The border color of the rounded rectangle.
142  *
143  * If the color is fully transparent the rounded rectangle won't be filled.
144  */
146 };
147 
149 {
150 public:
151  /**
152  * Constructor.
153  *
154  * @param cfg The config object to define the circle.
155  */
156  explicit circle_shape(const config& cfg);
157 
158  void draw( wfl::map_formula_callable& variables) override;
159 
160 private:
161  typed_formula<unsigned> x_; /**< The center x coordinate of the circle. */
162  typed_formula<unsigned> y_; /**< The center y coordinate of the circle. */
163 
164  /** The radius of the circle. */
166 
167  /** The border color of the circle. */
169 
170  /** The fill color of the circle. */
172 
173  /** The border thickness of the circle. */
174  unsigned int border_thickness_;
175 };
176 
178 {
179 public:
180  /**
181  * Constructor.
182  *
183  * @param cfg The config object to define the image.
184  * @param functions WFL functions to execute.
185  */
186  image_shape(const config& cfg, wfl::action_function_symbol_table& functions);
187 
188  void draw(wfl::map_formula_callable& variables) override;
189 
190 private:
191  typed_formula<unsigned> x_; /**< The x coordinate of the image. */
192  typed_formula<unsigned> y_; /**< The y coordinate of the image. */
193  typed_formula<unsigned> w_; /**< The width of the image. */
194  typed_formula<unsigned> h_; /**< The height of the image. */
195 
196  /**
197  * Name of the image.
198  *
199  * This value is only used when the image name is a formula. If it isn't a
200  * formula the image will be loaded in the constructor. If it's a formula it
201  * will be loaded every draw cycles. This allows 'changing' images.
202  */
204 
205  /**
206  * Determines the way an image will be resized.
207  *
208  * If the image is smaller is needed it needs to resized, how is determined
209  * by the value of this enum.
210  */
211  enum class resize_mode {
212  scale,
213  scale_sharp,
214  stretch,
215  tile,
216  tile_center,
217  tile_highres,
218  };
219 
220  /** Converts a string to a resize mode. */
221  resize_mode get_resize_mode(const std::string& resize_mode);
222 
223  /** The resize mode for an image. */
225 
226  /** Mirror the image over the vertical axis. */
228 
229  // TODO: use a typed_formula?
231 
232  static void dimension_validation(unsigned value, const std::string& name, const std::string& key);
233 };
234 
236 {
237 public:
238  /**
239  * Constructor.
240  *
241  * @param cfg The config object to define the text.
242  * @param functions WFL functions to execute.
243  */
244  explicit text_shape(const config& cfg, wfl::action_function_symbol_table& functions);
245 
246  void draw(wfl::map_formula_callable& variables) override;
247 
248 private:
249  /** the source config */
251 
252  /** The text font family. */
254 
255  /** The font size of the text. */
257 
258  /** The style of the text. */
260 
261  /** The alignment of the text. */
263 
264  /** The color of the text. */
266 
267  /** The text to draw. */
269 
270  /** The text markup switch of the text. */
272 
273  /** The link aware switch of the text. */
275 
276  /** The link color of the text. */
278 
279  /** The maximum width for the text. */
281 
282  /** The number of characters per line. */
284 
285  /** The maximum height for the text. */
287 
288  /** Start and end offsets for highlight */
289  std::string highlight_start_;
290  std::string highlight_end_;
291 
292  /** The color to be used for highlighting */
294 
295  /** Generic start and end offsets for various attributes */
296  std::string attr_start_;
297  std::string attr_end_;
298 
299  /**
300  * The attribute type
301  * Possible values :
302  * color/foreground, bgcolor/background, font_size/size,
303  * bold, italic, underline
304  * The first three require extra data
305  * the color for the first two, and font size for the last
306  */
307  std::string attr_name_;
308 
309  /** extra data for the attribute, if any */
310  std::string attr_data_;
311 
312  /** Whether to apply a text outline. */
314 
315  /** Any extra WFL actions to execute. */
317 };
318 
319 }
This file contains the canvas object which is the part where the widgets draw (temporally) images on.
A config object defines a single node in a WML file, with access to child nodes.
Definition: config.hpp:158
Abstract base class for all other shapes.
Definition: canvas.hpp:54
shape(const config &cfg)
Definition: canvas.hpp:56
typed_formula< color_t > border_color_
The border color of the circle.
typed_formula< unsigned > x_
The center x coordinate of the circle.
typed_formula< unsigned > radius_
The radius of the circle.
unsigned int border_thickness_
The border thickness of the circle.
circle_shape(const config &cfg)
Constructor.
Definition: canvas.cpp:200
typed_formula< color_t > fill_color_
The fill color of the circle.
typed_formula< unsigned > y_
The center y coordinate of the circle.
void draw(wfl::map_formula_callable &variables) override
Draws the canvas.
Definition: canvas.cpp:215
typed_formula< std::string > image_name_
Name of the image.
resize_mode
Determines the way an image will be resized.
typed_formula< unsigned > w_
The width of the image.
resize_mode get_resize_mode(const std::string &resize_mode)
Converts a string to a resize mode.
Definition: canvas.cpp:366
typed_formula< unsigned > x_
The x coordinate of the image.
static void dimension_validation(unsigned value, const std::string &name, const std::string &key)
Definition: canvas.cpp:259
typed_formula< unsigned > y_
The y coordinate of the image.
typed_formula< unsigned > h_
The height of the image.
resize_mode resize_mode_
The resize mode for an image.
wfl::formula actions_formula_
typed_formula< bool > mirror_
Mirror the image over the vertical axis.
void draw(wfl::map_formula_callable &variables) override
Draws the canvas.
Definition: canvas.cpp:268
image_shape(const config &cfg, wfl::action_function_symbol_table &functions)
Constructor.
Definition: canvas.cpp:242
typed_formula< color_t > color_
The color of the line.
typed_formula< unsigned > x1_
The start x coordinate of the line.
typed_formula< unsigned > y1_
The start y coordinate of the line.
unsigned thickness_
The thickness of the line.
typed_formula< unsigned > x2_
The end x coordinate of the line.
line_shape(const config &cfg)
Constructor.
Definition: canvas.cpp:51
typed_formula< unsigned > y2_
The end y coordinate of the line.
void draw(wfl::map_formula_callable &variables) override
Draws the canvas.
Definition: canvas.cpp:66
typed_formula< int > x_
The x coordinate of the rectangle.
typed_formula< int > w_
The width of the rectangle.
typed_formula< int > y_
The y coordinate of the rectangle.
rect_bounded_shape(const config &cfg)
Constructor.
typed_formula< int > h_
The height of the rectangle.
rectangle_shape(const config &cfg)
Constructor.
Definition: canvas.cpp:88
int border_thickness_
Border thickness.
typed_formula< color_t > fill_color_
The border color of the rectangle.
void draw(wfl::map_formula_callable &variables) override
Draws the canvas.
Definition: canvas.cpp:105
typed_formula< color_t > border_color_
The border color of the rectangle.
typed_formula< color_t > border_color_
The border color of the rounded rectangle.
void draw(wfl::map_formula_callable &variables) override
Draws the canvas.
Definition: canvas.cpp:153
typed_formula< int > r_
The radius of the corners.
round_rectangle_shape(const config &cfg)
Constructor.
Definition: canvas.cpp:135
int border_thickness_
Border thickness.
typed_formula< color_t > fill_color_
The border color of the rounded rectangle.
font::pango_text::FONT_STYLE font_style_
The style of the text.
std::string highlight_end_
std::string attr_name_
The attribute type Possible values : color/foreground, bgcolor/background, font_size/size,...
typed_formula< bool > outline_
Whether to apply a text outline.
typed_formula< color_t > color_
The color of the text.
typed_formula< int > maximum_height_
The maximum height for the text.
std::string attr_start_
Generic start and end offsets for various attributes.
std::string attr_data_
extra data for the attribute, if any
typed_formula< bool > link_aware_
The link aware switch of the text.
typed_formula< PangoAlignment > text_alignment_
The alignment of the text.
config cfg_
the source config
typed_formula< color_t > highlight_color_
The color to be used for highlighting.
std::string highlight_start_
Start and end offsets for highlight.
font::family_class font_family_
The text font family.
typed_formula< color_t > link_color_
The link color of the text.
typed_formula< int > maximum_width_
The maximum width for the text.
void draw(wfl::map_formula_callable &variables) override
Draws the canvas.
Definition: canvas.cpp:427
text_shape(const config &cfg, wfl::action_function_symbol_table &functions)
Constructor.
Definition: canvas.cpp:396
typed_formula< unsigned > font_size_
The font size of the text.
unsigned characters_per_line_
The number of characters per line.
wfl::formula actions_formula_
Any extra WFL actions to execute.
typed_formula< t_string > text_
The text to draw.
typed_formula< bool > text_markup_
The text markup switch of the text.
std::string attr_end_
family_class
Font classes for get_font_families().
Generic file dialog.