12#include "../macros.hpp"
15hi_export_module(hikogui.widgets.scroll_aperture_widget);
17hi_export
namespace hi {
inline namespace v1 {
39 hi_axiom(loop::main().on_thread());
41 _content_width_cbt = content_width.
subscribe([&](
auto...) {
42 ++global_counter<
"scroll_aperture_widget:content_width:relayout">;
45 _content_height_cbt = content_height.
subscribe([&](
auto...) {
46 ++global_counter<
"scroll_aperture_widget:content_height:relayout">;
49 _aperture_width_cbt = aperture_width.
subscribe([&](
auto...) {
50 ++global_counter<
"scroll_aperture_widget:aperture_width:relayout">;
53 _aperture_height_cbt = aperture_height.
subscribe([&](
auto...) {
54 ++global_counter<
"scroll_aperture_widget:aperture_height:relayout">;
57 _offset_x_cbt = offset_x.
subscribe([&](
auto...) {
58 ++global_counter<
"scroll_aperture_widget:offset_x:relayout">;
61 _offset_y_cbt = offset_y.
subscribe([&](
auto...) {
62 ++global_counter<
"scroll_aperture_widget:offset_y:relayout">;
65 _minimum_cbt =
minimum.subscribe([&](
auto...) {
66 ++global_counter<
"scroll_aperture_widget:minimum:reconstrain">;
74 hi_axiom(loop::main().on_thread());
75 hi_axiom(_content ==
nullptr);
77 auto tmp = std::make_unique<Widget>(
this, std::forward<Args>(
args)...);
83 [[
nodiscard]]
bool x_axis_scrolls()
const noexcept
85 return *content_width > *aperture_width;
88 [[
nodiscard]]
bool y_axis_scrolls()
const noexcept
90 return *content_height > *aperture_height;
102 _content_constraints = _content->update_constraints();
110 _content_constraints.margins.left() + _content_constraints.margins.right(),
111 _content_constraints.margins.top() + _content_constraints.margins.bottom()};
119 aperture_width =
context.width() - _content_constraints.margins.left() - _content_constraints.margins.right();
120 aperture_height =
context.height() - _content_constraints.margins.bottom() - _content_constraints.margins.top();
124 content_width = *aperture_width < _content_constraints.preferred.
width() ? _content_constraints.preferred.
width() :
126 content_height = *aperture_height < _content_constraints.preferred.
height() ?
127 _content_constraints.preferred.
height() :
140 _content_constraints,
142 -*offset_x + _content_constraints.margins.left(),
143 -*offset_y + _content_constraints.margins.bottom(),
146 theme().baseline_adjustment()};
160 [[
nodiscard]] hitbox hitbox_test(point2 position)
const noexcept override
162 hi_axiom(loop::main().on_thread());
165 auto r = _content->hitbox_test_from_parent(position);
167 if (
layout().contains(position)) {
168 r =
std::max(r, hitbox{
id, _layout.elevation});
179 hi_axiom(loop::main().on_thread());
181 if (
event == gui_event_type::mouse_wheel) {
189 ++global_counter<
"scroll_aperture_widget:mouse_wheel:relayout">;
200 auto safe_rectangle = intersect(_layout.rectangle(), _layout.clipping_rectangle);
@ window_relayout
Request that widgets get laid out on the next frame.
@ window_reconstrain
Request that widget get constraint on the next frame.
@ partial
A widget is partially enabled.
@ invisible
The widget is invisible.
DOXYGEN BUG.
Definition algorithm_misc.hpp:20
The HikoGUI namespace.
Definition recursive_iterator.hpp:15
bool compare_store(T &lhs, U &&rhs) noexcept
Compare then store if there was a change.
Definition misc.hpp:53
@ level
The child widget stays at the same elevation and layer.
constexpr Out narrow_cast(In const &rhs) noexcept
Cast numeric values without loss of precision.
Definition cast.hpp:378
Definition callback.hpp:77
Class which represents an axis-aligned rectangle.
Definition aarectangle.hpp:33
A high-level geometric extent.
Definition extent2.hpp:32
constexpr float & width() noexcept
Access the x-as-width element from the extent.
Definition extent2.hpp:107
constexpr float & height() noexcept
Access the y-as-height element from the extent.
Definition extent2.hpp:118
Definition translate2.hpp:18
Draw context for drawing using the HikoGUI shaders.
Definition draw_context_intf.hpp:209
A user interface event.
Definition gui_event.hpp:82
widget_id id
The numeric identifier of a widget.
Definition widget_intf.hpp:30
widget_layout const & layout() const noexcept
Get the current layout for this widget.
Definition widget_intf.hpp:206
widget_intf * parent
Pointer to the parent widget.
Definition widget_intf.hpp:35
virtual void scroll_to_show(hi::aarectangle rectangle) noexcept=0
Scroll to show the given rectangle on the window.
The layout of a widget.
Definition widget_layout.hpp:56
2D constraints.
Definition box_constraints.hpp:25
Definition box_shape.hpp:18
A observer pointing to the whole or part of a observed_base.
Definition observer_intf.hpp:32
callback< void(value_type)> subscribe(Func &&func, callback_flags flags=callback_flags::synchronous) noexcept
Subscribe a callback to this observer.
Definition observer_intf.hpp:456
Definition not_null.hpp:22
A scroll aperture widget.
Definition scroll_aperture_widget.hpp:26
An interactive graphical object as part of the user-interface.
Definition widget.hpp:37
observer< extent2 > minimum
The minimum size this widget is allowed to be.
Definition widget.hpp:41
void scroll_to_show() noexcept
Scroll to show the important part of the widget.
Definition widget_intf.hpp:312
widget(widget_intf const *parent) noexcept
Definition widget.hpp:49
bool process_event(gui_event const &event) const noexcept override
Send a event to the window.
Definition widget.hpp:124
bool handle_event(gui_event const &event) noexcept override
Handle command.
Definition widget.hpp:144
observer< extent2 > maximum
The maximum size this widget is allowed to be.
Definition widget.hpp:45