16 #define GETTEXT_DOMAIN "wesnoth-lib" 
   67 #define LOG_HEADER "distributor mouse motion [" << owner_.id() << "]: "
 
   70     : mouse_focus_(nullptr)
 
   71     , mouse_captured_(false)
 
   74     , hover_widget_(nullptr)
 
   75     , hover_position_(0, 0)
 
   77     , signal_handler_sdl_mouse_motion_entered_(false)
 
   82             std::placeholders::_2,
 
   83             std::placeholders::_3,
 
   84             std::placeholders::_5),
 
   90             std::placeholders::_2,
 
   91             std::placeholders::_3,
 
   92             std::placeholders::_5,
 
   93             std::placeholders::_6),
 
   99             std::placeholders::_2,
 
  100             std::placeholders::_3,
 
  101             std::placeholders::_5
 
  107             std::placeholders::_2,
 
  108             std::placeholders::_3,
 
  109             std::placeholders::_5
 
  115             std::placeholders::_2,
 
  116             std::placeholders::_3,
 
  117             std::placeholders::_5
 
  123             std::placeholders::_2,
 
  124             std::placeholders::_3,
 
  125             std::placeholders::_5
 
  131             std::placeholders::_2,
 
  132             std::placeholders::_3,
 
  133             std::placeholders::_5),
 
  165             mouse_over = mouse_over->
parent();
 
  331               << 
"' at address " << 
widget << 
".";
 
  333     using namespace std::chrono_literals;
 
  365 #define LOG_HEADER "distributor mouse button " << I << " [" << owner_.id() << "]: "
 
  379 constexpr std::array mouse_data{
 
  424 template<std::
size_t I>
 
  427     , last_click_stamp_()
 
  428     , last_clicked_widget_(nullptr)
 
  431     , signal_handler_sdl_button_down_entered_(false)
 
  432     , signal_handler_sdl_button_up_entered_(false)
 
  434     static_assert(I < mouse_data.size(), 
"Out-of-bounds mouse_button template index");
 
  439             std::placeholders::_2,
 
  440             std::placeholders::_3,
 
  441             std::placeholders::_5),
 
  447             std::placeholders::_2,
 
  448             std::placeholders::_3,
 
  449             std::placeholders::_5),
 
  453 template<std::
size_t I>
 
  456     last_click_stamp_ = {};
 
  457     last_clicked_widget_ = 
nullptr;
 
  460     is_down_ = button_state & SDL_BUTTON(I + 1);
 
  463 template<std::
size_t I>
 
  467     if(signal_handler_sdl_button_down_entered_) {
 
  475 #ifdef GUI2_SHOW_UNHANDLED_EVENT_WARNINGS 
  476         WRN_GUI_E << 
LOG_HEADER << 
event << 
". The mouse button is already down, we missed an event.";
 
  482     if(mouse_captured_) {
 
  483         assert(mouse_focus_);
 
  484         focus_ = mouse_focus_;
 
  486         if(!owner_.fire(mouse_data[I].sdl_button_down_event, *focus_, 
coordinate)) {
 
  496         if(mouse_over != mouse_focus_) {
 
  497 #ifdef GUI2_SHOW_UNHANDLED_EVENT_WARNINGS 
  499                       << 
"and mouse not captured, we missed events.";
 
  501             mouse_focus_ = mouse_over;
 
  506         if(!owner_.fire(mouse_data[I].sdl_button_down_event, *focus_, 
coordinate)) {
 
  514 template<std::
size_t I>
 
  518     if(signal_handler_sdl_button_up_entered_) {
 
  526 #ifdef GUI2_SHOW_UNHANDLED_EVENT_WARNINGS 
  527         WRN_GUI_E << 
LOG_HEADER << 
event << 
". The mouse button is already up, we missed an event.";
 
  535         if(!owner_.fire(mouse_data[I].sdl_button_up_event, *focus_, 
coordinate)) {
 
  546     if(mouse_captured_) {
 
  548             = SDL_BUTTON_LMASK | SDL_BUTTON_MMASK | SDL_BUTTON_RMASK | SDL_BUTTON_X1MASK | SDL_BUTTON_X2MASK;
 
  551             mouse_captured_ = 
false;
 
  554         if(mouse_focus_ == mouse_over) {
 
  555             mouse_button_click(mouse_focus_);
 
  556         } 
else if(!mouse_captured_) {
 
  560                 mouse_enter(mouse_over);
 
  563     } 
else if(focus_ && focus_ == mouse_over) {
 
  564         mouse_button_click(focus_);
 
  571 template<std::
size_t I>
 
  574     auto stamp = std::chrono::steady_clock::now();
 
  579         last_click_stamp_ = {};
 
  580         last_clicked_widget_ = 
nullptr;
 
  585         last_click_stamp_ = stamp;
 
  586         last_clicked_widget_ = 
widget;
 
  593 #define LOG_HEADER "distributor mouse motion [" << owner_.id() << "]: "
 
  606     , keyboard_focus_(nullptr)
 
  607     , keyboard_focus_chain_()
 
  609     if(SDL_WasInit(SDL_INIT_TIMER) == 0) {
 
  610         if(SDL_InitSubSystem(SDL_INIT_TIMER) == -1) {
 
  618             std::placeholders::_5,
 
  619             std::placeholders::_6,
 
  620             std::placeholders::_7
 
  626             std::placeholders::_5,
 
  627             std::placeholders::_6,
 
  628             std::placeholders::_7
 
  634             std::placeholders::_5,
 
  635             std::placeholders::_6,
 
  636             std::placeholders::_7
 
  642             std::placeholders::_1,
 
  643             std::placeholders::_2
 
  654             std::placeholders::_5,
 
  655             std::placeholders::_6,
 
  656             std::placeholders::_7
 
  662             std::placeholders::_5,
 
  663             std::placeholders::_6,
 
  664             std::placeholders::_7
 
  670             std::placeholders::_5,
 
  671             std::placeholders::_6,
 
  672             std::placeholders::_7
 
  678             std::placeholders::_1,
 
  679             std::placeholders::_2
 
  733 template<
typename Fcn, 
typename P1, 
typename P2, 
typename P3>
 
  753             if(tb->is_composing()) {
 
  782         if(control != 
nullptr && !control->
get_active()) {
 
  795     signal_handler_keyboard_internal<signal_keyboard>(
event::SDL_KEY_DOWN, key, modifier, unicode);
 
Base class for event handling.
void connect_signal(const F &func, const queue_position position=back_child)
Adds a callback to the appropriate queue based on event type.
queue_position
The position where to add a new callback in the signal handler.
bool fire(const ui_event event, widget &target)
Fires an event which has no extra parameters.
void disconnect_signal(const F &func, const queue_position position=back_child)
Removes a callback from the appropriate queue based on event type.
widget * keyboard_focus_
The widget that holds the keyboard focus_.
void keyboard_add_to_chain(widget *widget)
Adds the widget to the keyboard chain.
void keyboard_capture(widget *widget)
Captures the keyboard input.
std::vector< widget * > keyboard_focus_chain_
Fall back keyboard focus_ items.
void signal_handler_keyboard_internal(event::ui_event evt, P1 &&p1, P2 &&p2, P3 &&p3)
void keyboard_remove_from_chain(widget *widget)
Remove the widget from the keyboard chain.
void signal_handler_sdl_text_editing(const std::string &unicode, int32_t start, int32_t len)
void signal_handler_sdl_key_down(const SDL_Keycode key, const SDL_Keymod modifier, const std::string &unicode)
Set of functions that handle certain events and sends them to the proper widget.
void initialize_state()
Initializes the state of the keyboard and mouse.
distributor(widget &owner, const dispatcher::queue_position queue_position)
widget * keyboard_focus() const
Return the widget currently capturing keyboard input.
void signal_handler_notify_removal(dispatcher &widget, const ui_event event)
void signal_handler_sdl_text_input(const std::string &unicode, int32_t start, int32_t len)
bool mouse_captured_
Did the current widget capture the focus_?
void mouse_hover(widget *mouse_over, const point &coordinate)
Called when the mouse moves over a widget.
widget * hover_widget_
The widget which should get the hover event.
void signal_handler_sdl_mouse_motion(const event::ui_event event, bool &handled, const point &coordinate)
mouse_motion(widget &owner, const dispatcher::queue_position queue_position)
void mouse_enter(widget *mouse_over)
Called when the mouse enters a widget.
bool hover_shown_
Has the hover been shown for the widget?
void signal_handler_sdl_touch_motion(const event::ui_event event, bool &handled, const point &coordinate, const point &distance)
void capture_mouse(const bool capture=true)
Captures the mouse input.
void signal_handler_show_helptip(const event::ui_event event, bool &handled, const point &coordinate)
void mouse_leave()
Called when the mouse leaves the current widget.
void signal_handler_sdl_wheel(const event::ui_event event, bool &handled, const point &coordinate)
point hover_position_
The anchor point of the hover event.
void stop_hover_timer()
Stops the current hover timer.
void start_hover_timer(widget *widget, const point &coordinate)
Starts the hover timer.
std::size_t hover_timer_
The timer for the hover event.
widget * mouse_focus_
The widget that currently has the mouse focus_.
widget & owner_
The widget that owns us.
void show_tooltip()
Called when the mouse wants the widget to show its tooltip.
bool signal_handler_sdl_mouse_motion_entered_
Small helper to keep a resource (boolean) locked.
resource_locker(bool &locked)
bool wants_mouse_hover() const
Abstract base class for text items.
const ui_event button_click_event
const ui_event button_double_click_event
const ui_event sdl_button_up_event
const ui_event button_up_event
const ui_event sdl_button_down_event
const ui_event button_down_event
Contains the event distributor.
Define the common log macros for the gui toolkit.
void point(int x, int y)
Draw a single point.
EXIT_STATUS start(bool clear_id, const std::string &filename, bool take_screenshot, const std::string &screenshot_filename)
Main interface for launching the editor from the title screen.
ui_event
The event sent to the dispatcher.
@ SDL_FORWARD_BUTTON_DOWN
@ FORWARD_BUTTON_DOUBLE_CLICK
@ MIDDLE_BUTTON_DOUBLE_CLICK
@ SDL_TEXT_INPUT
An SDL text input (commit) event.
@ SDL_TEXT_EDITING
An SDL text editing (IME) event.
@ LEFT_BUTTON_DOUBLE_CLICK
@ BACK_BUTTON_DOUBLE_CLICK
@ RIGHT_BUTTON_DOUBLE_CLICK
void init_mouse_location()
Initializes the location of the mouse.
std::chrono::milliseconds double_click_time
The interval between two clicks to be detected as double click.
std::size_t add_timer(const std::chrono::milliseconds &interval, const std::function< void(std::size_t id)> &callback, const bool repeat)
Adds a new timer.
point get_mouse_position()
Returns the current mouse position.
bool remove_timer(const std::size_t id)
Removes a timer.
uint32_t get_mouse_button_mask()
Returns the current mouse button mask.
map_location coordinate
Contains an x and y coordinate used for starting positions in maps.
bool contains(const Container &container, const Value &value)
Returns true iff value is found in container.
auto * find(Container &container, const Value &value)
Convenience wrapper for using find on a container without needing to comare to end()
This file contains the settings handling of the widget library.
Contains the gui2 timer routines.