-
-
Notifications
You must be signed in to change notification settings - Fork 991
/
drawing.hpp
149 lines (110 loc) · 3.43 KB
/
drawing.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
/*
Copyright (C) 2010 - 2017 by Mark de Wever <koraq@xs4all.nl>
Part of the Battle for Wesnoth Project http://www.wesnoth.org/
This program 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; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY.
See the COPYING file for more details.
*/
#pragma once
#include "gui/widgets/styled_widget.hpp"
#include "gui/core/widget_definition.hpp"
#include "gui/core/window_builder.hpp"
class config;
namespace gui2
{
namespace implementation
{
struct builder_drawing;
}
// ------------ WIDGET -----------{
/**
* A widget to draw upon.
*
* This widget has a fixed size like the spacer, but allows the user to
* manual draw items. The widget is display only.
*/
class drawing : public styled_widget
{
public:
explicit drawing(const implementation::builder_drawing& builder);
canvas& get_drawing_canvas()
{
return get_canvas(0);
}
void set_drawing_data(const ::config& cfg)
{
get_drawing_canvas().set_cfg(cfg);
}
void append_drawing_data(const ::config& cfg)
{
get_drawing_canvas().append_cfg(cfg);
}
/***** ***** ***** ***** layout functions ***** ***** ***** *****/
/** See @ref widget::request_reduce_width. */
virtual void request_reduce_width(const unsigned maximum_width) override;
/** See @ref widget::request_reduce_height. */
virtual void request_reduce_height(const unsigned maximum_height) override;
private:
/** See @ref widget::calculate_best_size. */
virtual point calculate_best_size() const override;
public:
/***** ***** ***** ***** Inherited ***** ***** ***** *****/
/** See @ref styled_widget::set_active. */
virtual void set_active(const bool active) override;
/** See @ref styled_widget::get_active. */
virtual bool get_active() const override;
/** See @ref styled_widget::get_state. */
virtual unsigned get_state() const override;
/** See @ref widget::disable_click_dismiss. */
bool disable_click_dismiss() const override;
/***** ***** ***** setters / getters for members ***** ****** *****/
void set_best_size(const point& best_size)
{
best_size_ = best_size;
}
private:
/**
* Possible states of the widget.
*
* Note the order of the states must be the same as defined in
* settings.hpp.
*/
enum state_t {
ENABLED,
};
/** When we're used as a fixed size item, this holds the best size. */
point best_size_;
/** Inherited from styled_widget, implemented by REGISTER_WIDGET. */
virtual const std::string& get_control_type() const override;
};
// }---------- DEFINITION ---------{
struct drawing_definition : public styled_widget_definition
{
explicit drawing_definition(const config& cfg);
struct resolution : public resolution_definition
{
explicit resolution(const config& cfg);
};
};
// }---------- BUILDER -----------{
namespace implementation
{
struct builder_drawing : public builder_styled_widget
{
explicit builder_drawing(const config& cfg);
using builder_styled_widget::build;
widget* build() const;
/** The width of the widget. */
typed_formula<unsigned> width;
/** The height of the widget. */
typed_formula<unsigned> height;
/** Config containing what to draw on the widgets canvas. */
config draw;
};
} // namespace implementation
// }------------ END --------------
} // namespace gui2