|
| | row_column_widget (widget *parent) noexcept |
| | Constructs an empty row/column widget.
|
| |
| template<typename Widget , typename... Args> |
| Widget & | make_widget (Args &&...args) |
| | Add a widget directly to this grid-widget.
|
| |
| void | clear () noexcept |
| | Remove and deallocate all child widgets.
|
| |
|
| widget (widget *parent) noexcept |
| |
|
| widget (widget const &)=delete |
| |
|
| widget (widget &&)=delete |
| |
|
widget & | operator= (widget &&)=delete |
| |
|
widget & | operator= (widget const &)=delete |
| |
|
generator< widget & > | children (bool include_invisible) noexcept |
| |
| virtual hitbox | hitbox_test_from_parent (point2i position) const noexcept |
| | Call hitbox_test from a parent widget.
|
| |
| virtual hitbox | hitbox_test_from_parent (point2i position, hitbox sibling_hitbox) const noexcept |
| | Call hitbox_test from a parent widget.
|
| |
| virtual bool | accepts_keyboard_focus (keyboard_focus_group group) const noexcept |
| | Check if the widget will accept keyboard focus.
|
| |
| void | reset_layout (gfx_surface *new_surface, float new_scale) noexcept |
| | Reset the layout.
|
| |
|
virtual sub_theme_selector_type | sub_theme_selector () const noexcept |
| |
|
virtual bool | process_event (gui_event const &event) const noexcept |
| |
| virtual void | request_redraw () const noexcept |
| | Request the widget to be redrawn on the next frame.
|
| |
| virtual bool | handle_event (gui_event const &event) noexcept |
| | Handle command.
|
| |
| virtual bool | handle_event_recursive (gui_event const &event, std::vector< widget_id > const &reject_list=std::vector< widget_id >{}) noexcept |
| | Handle command recursive.
|
| |
| virtual widget_id | find_next_widget (widget_id current_keyboard_widget, keyboard_focus_group group, keyboard_focus_direction direction) const noexcept |
| | Find the next widget that handles keyboard focus.
|
| |
|
widget_id | find_first_widget (keyboard_focus_group group) const noexcept |
| |
|
widget_id | find_last_widget (keyboard_focus_group group) const noexcept |
| |
|
bool | is_first (keyboard_focus_group group) const noexcept |
| |
|
bool | is_last (keyboard_focus_group group) const noexcept |
| |
| virtual void | scroll_to_show (hi::aarectanglei rectangle) noexcept |
| | Scroll to show the given rectangle on the window.
|
| |
| std::vector< widget_id > | parent_chain () const noexcept |
| | Get a list of parents of a given widget.
|
| |
| virtual bool | is_tab_button () const noexcept |
| | Check if this widget is a tab-button.
|
| |
|
template<forward_of< void()> Callback> |
| callback_token | subscribe (Callback &&callback, callback_flags flags=callback_flags::synchronous) const noexcept |
| |
|
awaiter_type | operator co_await () const noexcept |
| |
template<fixed_string Prefix,
axis Axis>
class hi::v1::row_column_widget< Prefix, Axis >
A row/column widget lays out child widgets along a row or column.
Columns are laid out from left to right, and rows from top to bottom.
The row/column widget will calculate the size of the row or column based on the minimum, preferred and maximum size of each child widget contained in them. Margins are also taken into account in the spacing between the child-widgets.
When laid out, each child is sized to where it will occupy the full width of a column, or full height of the row; and divide the length of the column or row with the other children.
- Template Parameters
-
| Axis | the axis to lay out child widgets. Either axis::horizontal or axis::vertical. |
template<fixed_string Prefix,
axis Axis>
template<typename Widget , typename... Args>
Add a widget directly to this grid-widget.
In a column-widget the newly added widget is added below previously added child-widgets.
In a row-widget the newly added widget is added to the right of previously added child-widgets.
- Template Parameters
-
| Widget | The type of the widget to be constructed. |
- Parameters
-
| args | The arguments passed to the constructor of the widget. |
- Returns
- A reference to the widget that was created.