#include <gdk/gdk.h>
#include "flutter/shell/platform/embedder/embedder.h"
#include "flutter/shell/platform/linux/fl_key_event.h"
#include "flutter/shell/platform/linux/public/flutter_linux/fl_engine.h"
Go to the source code of this file.
Typedefs | |
typedef guint(* | FlKeyboardManagerLookupKeyHandler) (const GdkKeymapKey *key, gpointer user_data) |
Functions | |
G_BEGIN_DECLS | G_DECLARE_FINAL_TYPE (FlKeyboardManager, fl_keyboard_manager, FL, KEYBOARD_MANAGER, GObject) |
FlKeyboardManager * | fl_keyboard_manager_new (FlEngine *engine) |
void | fl_keyboard_manager_add_redispatched_event (FlKeyboardManager *manager, FlKeyEvent *event) |
void | fl_keyboard_manager_handle_event (FlKeyboardManager *manager, FlKeyEvent *event, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data) |
gboolean | fl_keyboard_manager_handle_event_finish (FlKeyboardManager *manager, GAsyncResult *result, FlKeyEvent **redispatched_event, GError **error) |
void | fl_keyboard_manager_sync_modifier_if_needed (FlKeyboardManager *manager, guint state, double event_time) |
GHashTable * | fl_keyboard_manager_get_pressed_state (FlKeyboardManager *manager) |
void | fl_keyboard_manager_set_lookup_key_handler (FlKeyboardManager *manager, FlKeyboardManagerLookupKeyHandler lookup_key_handler, gpointer user_data) |
typedef guint(* FlKeyboardManagerLookupKeyHandler) (const GdkKeymapKey *key, gpointer user_data) |
Definition at line 118 of file fl_keyboard_manager.h.
void fl_keyboard_manager_add_redispatched_event | ( | FlKeyboardManager * | manager, |
FlKeyEvent * | event | ||
) |
fl_keyboard_manager_add_redispatched_event: @manager: an #FlKeyboardManager. @event: an event that will be handled by the manager in the future.
Add an event that will be redispatched and handled by the manager in the future. When that event is received it will be ignored.
Definition at line 367 of file fl_keyboard_manager.cc.
GHashTable* fl_keyboard_manager_get_pressed_state | ( | FlKeyboardManager * | manager | ) |
fl_keyboard_manager_get_pressed_state: @manager: the #FlKeyboardManager self.
Returns the keyboard pressed state. The hash table contains one entry per pressed keys, mapping from the logical key to the physical key.*
Definition at line 435 of file fl_keyboard_manager.cc.
References fl_key_embedder_responder_get_pressed_state().
Referenced by get_keyboard_state().
void fl_keyboard_manager_handle_event | ( | FlKeyboardManager * | manager, |
FlKeyEvent * | event, | ||
GCancellable * | cancellable, | ||
GAsyncReadyCallback | callback, | ||
gpointer | user_data | ||
) |
fl_keyboard_manager_handle_event: @manager: an #FlKeyboardManager. @event: the event to be dispatched. It is usually a wrap of a GdkEventKey. This event will be managed and released by #FlKeyboardManager. @cancellable: (allow-none): a #GCancellable or NULL. @callback: (scope async): a #GAsyncReadyCallback to call when the view is added. @user_data: (closure): user data to pass to @callback.
Make the manager process a system key event. This might eventually send messages to the framework, trigger text input effects, or redispatch the event back to the system.
Definition at line 374 of file fl_keyboard_manager.cc.
References event_is_redispatched(), fl_key_channel_responder_handle_event(), fl_key_embedder_responder_handle_event(), fl_key_event_get_group(), fl_key_event_get_keycode(), fl_keyboard_layout_get_logical_key(), guarantee_layout(), handle_event_data_free(), handle_event_data_new(), HandleEventData::handled, responder_handle_channel_event_cb(), responder_handle_embedder_event_cb(), TRUE, and user_data.
Referenced by handle_key_event(), and TEST().
gboolean fl_keyboard_manager_handle_event_finish | ( | FlKeyboardManager * | manager, |
GAsyncResult * | result, | ||
FlKeyEvent ** | redispatched_event, | ||
GError ** | error | ||
) |
fl_keyboard_manager_handle_event_finish: @manager: an #FlKeyboardManager.
Completes request started with fl_keyboard_manager_handle_event().
Returns: TRUE on success.
Definition at line 410 of file fl_keyboard_manager.cc.
References error, HandleEventData::event, and HandleEventData::redispatch.
Referenced by TEST().
FlKeyboardManager* fl_keyboard_manager_new | ( | FlEngine * | engine | ) |
FlKeyboardManager:
Processes keyboard events and cooperate with TextInputManager
.
A keyboard event goes through a few sections, each can choose to handle the event, and only unhandled events can move to the next section:
TextInputManager
) and are handled synchronously.Create a new #FlKeyboardManager.
Returns: a new #FlKeyboardManager.
Definition at line 356 of file fl_keyboard_manager.cc.
References fl_engine_get_binary_messenger(), fl_key_channel_responder_new(), and fl_key_embedder_responder_new().
Referenced by fl_engine_new_full(), setup_keyboard(), and TEST().
void fl_keyboard_manager_set_lookup_key_handler | ( | FlKeyboardManager * | manager, |
FlKeyboardManagerLookupKeyHandler | lookup_key_handler, | ||
gpointer | user_data | ||
) |
fl_keyboard_manager_set_lookup_key_handler: @manager: the #FlKeyboardManager self.
Set the handler for key lookup, for testing purposes only.
Definition at line 441 of file fl_keyboard_manager.cc.
References user_data.
void fl_keyboard_manager_sync_modifier_if_needed | ( | FlKeyboardManager * | manager, |
guint | state, | ||
double | event_time | ||
) |
fl_keyboard_manager_sync_modifier_if_needed: @manager: the #FlKeyboardManager self. @state: the state of the modifiers mask. @event_time: the time attribute of the incoming GDK event.
If needed, synthesize modifier keys up and down event by comparing their current pressing states with the given modifiers mask.
Definition at line 427 of file fl_keyboard_manager.cc.
References fl_key_embedder_responder_sync_modifiers_if_needed(), and state.
Referenced by sync_modifier_if_needed().
G_BEGIN_DECLS G_DECLARE_FINAL_TYPE | ( | FlKeyboardManager | , |
fl_keyboard_manager | , | ||
FL | , | ||
KEYBOARD_MANAGER | , | ||
GObject | |||
) |