12#include "../macros.hpp"
14namespace hi {
inline namespace v1 {
22 using super = abstract_button_widget;
23 using delegate_type =
typename super::delegate_type;
28 button_widget_attribute
auto&&...attributes) noexcept :
32 set_attributes<0>(hi_forward(attributes)...);
46 hilet extra_size =
extent2{theme().margin<
float>() * 2.0f, theme().margin<
float>() * 2.0f};
48 auto constraints = _label_constraints + extra_size;
49 constraints.margins = 0;
52 void set_layout(
widget_layout const& context)
noexcept override
55 hilet label_rectangle =
56 aarectangle{theme().margin<
float>(), 0.0f, context.width() - theme().margin<
float>() * 2.0f, context.height()};
57 _on_label_shape = _off_label_shape = _other_label_shape =
58 box_shape{_label_constraints, label_rectangle, theme().baseline_adjustment()};
65 draw_toolbar_button(context);
69 [[nodiscard]]
bool accepts_keyboard_focus(keyboard_focus_group group)
const noexcept override
77 void draw_toolbar_button(
draw_context const& context)
noexcept
79 hilet border_color = *
focus ? focus_color() : color::transparent();
Defines abstract_button_widget.
@ rectangle
The gui_event has rectangle data.
Definition gui_event_variant.hpp:42
@ partial
A widget is partially enabled.
Definition widget_mode.hpp:68
@ invisible
The widget is invisible.
Definition widget_mode.hpp:36
geometry/margins.hpp
Definition lookahead_iterator.hpp:5
The HikoGUI API version 1.
Definition lookahead_iterator.hpp:6
@ inside
The border is drawn inside the edge of a quad.
Definition draw_context.hpp:34
bool compare_store(T &lhs, U &&rhs) noexcept
Compare then store if there was a change.
Definition misc.hpp:56
Class which represents an axis-aligned rectangle.
Definition aarectangle.hpp:29
A high-level geometric extent.
Definition extent2.hpp:29
Draw context for drawing using the HikoGUI shaders.
Definition draw_context.hpp:208
widget_intf * parent
Pointer to the parent widget.
Definition widget_intf.hpp:28
virtual box_constraints update_constraints() noexcept=0
Update the constraints of the widget.
The layout of a widget.
Definition widget_layout.hpp:38
2D constraints.
Definition box_constraints.hpp:25
Definition box_shape.hpp:18
std::shared_ptr< delegate_type > delegate
The delegate that controls the button widget.
Definition abstract_button_widget.hpp:40
observer< alignment > alignment
The alignment of the button and on/off/other label.
Definition abstract_button_widget.hpp:56
A momentary button used as a child in the toolbar.
Definition toolbar_button_widget.hpp:20
An interactive graphical object as part of the user-interface.
Definition widget.hpp:37
widget_layout const & layout() const noexcept override
Get the current layout for this widget.
Definition widget.hpp:169
void set_layout(widget_layout const &context) noexcept override
Update the internal layout of the widget.
Definition widget.hpp:164
void draw(draw_context const &context) noexcept override
Draw the widget.
Definition widget.hpp:174
box_constraints update_constraints() noexcept override
Update the constraints of the widget.
Definition widget.hpp:158
observer< widget_mode > mode
The widget mode.
Definition widget.hpp:42
observer< bool > focus
The widget has keyboard focus.
Definition widget.hpp:50