#include <glib-object.h>#include "flutter/shell/platform/embedder/embedder.h"#include "flutter/shell/platform/linux/fl_renderer.h"#include "flutter/shell/platform/linux/fl_task_runner.h"#include "flutter/shell/platform/linux/public/flutter_linux/fl_dart_project.h"#include "flutter/shell/platform/linux/public/flutter_linux/fl_engine.h"Go to the source code of this file.
Typedefs | |
| typedef gboolean(* | FlEnginePlatformMessageHandler) (FlEngine *engine, const gchar *channel, GBytes *message, const FlutterPlatformMessageResponseHandle *response_handle, gpointer user_data) |
| typedef void(* | FlEngineUpdateSemanticsHandler) (FlEngine *engine, const FlutterSemanticsUpdate2 *update, gpointer user_data) |
| typedef void(* | FlEngineOnPreEngineRestartHandler) (FlEngine *engine, gpointer user_data) |
Enumerations | |
| enum | FlEngineError { FL_ENGINE_ERROR_FAILED } |
Functions | |
| GQuark | fl_engine_error_quark (void) G_GNUC_CONST |
| FlEngine * | fl_engine_new (FlDartProject *project, FlRenderer *renderer) |
| FlutterEngineProcTable * | fl_engine_get_embedder_api (FlEngine *engine) |
| void | fl_engine_set_platform_message_handler (FlEngine *engine, FlEnginePlatformMessageHandler handler, gpointer user_data, GDestroyNotify destroy_notify) |
| void | fl_engine_set_update_semantics_handler (FlEngine *engine, FlEngineUpdateSemanticsHandler handler, gpointer user_data, GDestroyNotify destroy_notify) |
| void | fl_engine_set_on_pre_engine_restart_handler (FlEngine *engine, FlEngineOnPreEngineRestartHandler handler, gpointer user_data, GDestroyNotify destroy_notify) |
| gboolean | fl_engine_start (FlEngine *engine, GError **error) |
| void | fl_engine_send_window_metrics_event (FlEngine *engine, size_t width, size_t height, double pixel_ratio) |
| void | fl_engine_send_window_state_event (FlEngine *engine, gboolean visible, gboolean focused) |
| void | fl_engine_send_mouse_pointer_event (FlEngine *engine, FlutterPointerPhase phase, size_t timestamp, double x, double y, FlutterPointerDeviceKind device_kind, double scroll_delta_x, double scroll_delta_y, int64_t buttons) |
| void | fl_engine_send_pointer_pan_zoom_event (FlEngine *self, size_t timestamp, double x, double y, FlutterPointerPhase phase, double pan_x, double pan_y, double scale, double rotation) |
| void | fl_engine_send_key_event (FlEngine *engine, const FlutterKeyEvent *event, FlutterKeyEventCallback callback, void *user_data) |
| void | fl_engine_dispatch_semantics_action (FlEngine *engine, uint64_t id, FlutterSemanticsAction action, GBytes *data) |
| gboolean | fl_engine_send_platform_message_response (FlEngine *engine, const FlutterPlatformMessageResponseHandle *handle, GBytes *response, GError **error) |
| void | fl_engine_send_platform_message (FlEngine *engine, const gchar *channel, GBytes *message, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data) |
| GBytes * | fl_engine_send_platform_message_finish (FlEngine *engine, GAsyncResult *result, GError **error) |
| FlTaskRunner * | fl_engine_get_task_runner (FlEngine *engine) |
| void | fl_engine_execute_task (FlEngine *engine, FlutterTask *task) |
| gboolean | fl_engine_mark_texture_frame_available (FlEngine *engine, int64_t texture_id) |
| gboolean | fl_engine_register_external_texture (FlEngine *engine, int64_t texture_id) |
| gboolean | fl_engine_unregister_external_texture (FlEngine *engine, int64_t texture_id) |
| void | fl_engine_update_accessibility_features (FlEngine *engine, int32_t flags) |
| GPtrArray * | fl_engine_get_switches (FlEngine *engine) |
| typedef void(* FlEngineOnPreEngineRestartHandler) (FlEngine *engine, gpointer user_data) |
FlEngineOnPreEngineRestartHandler: @engine: an #FlEngine. @user_data: (closure): data provided when registering this handler.
Function called right before the engine is restarted.
Definition at line 70 of file fl_engine_private.h.
| typedef gboolean(* FlEnginePlatformMessageHandler) (FlEngine *engine, const gchar *channel, GBytes *message, const FlutterPlatformMessageResponseHandle *response_handle, gpointer user_data) |
FlEnginePlatformMessageHandler: @engine: an #FlEngine. @channel: channel message received on. @message: message content received from Dart. @response_handle: a handle to respond to the message with. @user_data: (closure): data provided when registering this handler.
Function called when platform messages are received.
Returns: TRUE if message has been accepted.
Definition at line 43 of file fl_engine_private.h.
| typedef void(* FlEngineUpdateSemanticsHandler) (FlEngine *engine, const FlutterSemanticsUpdate2 *update, gpointer user_data) |
FlEngineUpdateSemanticsHandler: @engine: an #FlEngine. @node: semantic node information. @user_data: (closure): data provided when registering this handler.
Function called when semantics node updates are received.
Definition at line 58 of file fl_engine_private.h.
| enum FlEngineError |
FlEngineError: Errors for #FlEngine objects to set on failures.
| Enumerator | |
|---|---|
| FL_ENGINE_ERROR_FAILED | |
Definition at line 23 of file fl_engine_private.h.
| void fl_engine_dispatch_semantics_action | ( | FlEngine * | engine, |
| uint64_t | id, | ||
| FlutterSemanticsAction | action, | ||
| GBytes * | data | ||
| ) |
fl_engine_dispatch_semantics_action: @engine: an #FlEngine. @id: the semantics action identifier. @action: the action being dispatched. @data: (allow-none): data associated with the action.
Definition at line 873 of file fl_engine.cc.
Referenced by fl_accessible_node_perform_action_impl(), and TEST().
| GQuark fl_engine_error_quark | ( | void | ) |
Referenced by fl_engine_send_platform_message(), fl_engine_send_platform_message_response(), and fl_engine_start().
| void fl_engine_execute_task | ( | FlEngine * | engine, |
| FlutterTask * | task | ||
| ) |
fl_engine_execute_task: @engine: an #FlEngine. @task: a #FlutterTask to execute.
Executes given Flutter task.
Definition at line 926 of file fl_engine.cc.
Referenced by fl_task_runner_process_expired_tasks_locked().
| FlutterEngineProcTable* fl_engine_get_embedder_api | ( | FlEngine * | engine | ) |
fl_engine_get_embedder_api: @engine: an #FlEngine.
Gets the embedder API proc table, allowing modificiations for unit testing.
Returns: a mutable pointer to the embedder API proc table.
Definition at line 599 of file fl_engine.cc.
Referenced by TEST().
| GPtrArray* fl_engine_get_switches | ( | FlEngine * | engine | ) |
fl_engine_get_switches: @project: an #FlEngine.
Determines the switches that should be passed to the Flutter engine.
Returns: an array of switches to pass to the Flutter engine.
Definition at line 948 of file fl_engine.cc.
References flutter::GetSwitchesFromEnvironment().
Referenced by fl_engine_start(), and TEST().
| FlTaskRunner* fl_engine_get_task_runner | ( | FlEngine * | engine | ) |
fl_engine_get_task_runner: @engine: an #FlEngine.
Returns: task runner responsible for scheduling Flutter tasks.
Definition at line 921 of file fl_engine.cc.
Referenced by fl_renderer_unblock_main_thread(), and fl_renderer_wait_for_frame().
| gboolean fl_engine_mark_texture_frame_available | ( | FlEngine * | engine, |
| int64_t | texture_id | ||
| ) |
fl_engine_mark_texture_frame_available: @engine: an #FlEngine. @texture_id: the identifier of the texture whose frame has been updated.
Tells the Flutter engine that a new texture frame is available for the given texture.
Returns: TRUE on success.
Definition at line 894 of file fl_engine.cc.
References texture_id.
Referenced by mark_texture_frame_available().
| FlEngine* fl_engine_new | ( | FlDartProject * | project, |
| FlRenderer * | renderer | ||
| ) |
fl_engine_new: @project: an #FlDartProject. @renderer: an #FlRenderer.
Creates new Flutter engine.
Returns: a new #FlEngine.
Definition at line 455 of file fl_engine.cc.
References fl_binary_messenger_new().
Referenced by create_context_cb(), fl_engine_new_headless(), and make_mock_engine().
| gboolean fl_engine_register_external_texture | ( | FlEngine * | engine, |
| int64_t | texture_id | ||
| ) |
fl_engine_register_external_texture: @engine: an #FlEngine. @texture_id: the identifier of the texture that is available.
Tells the Flutter engine that a new external texture is available.
Returns: TRUE on success.
Definition at line 901 of file fl_engine.cc.
References texture_id.
Referenced by register_texture().
| void fl_engine_send_key_event | ( | FlEngine * | engine, |
| const FlutterKeyEvent * | event, | ||
| FlutterKeyEventCallback | callback, | ||
| void * | user_data | ||
| ) |
fl_engine_send_key_event:
Definition at line 860 of file fl_engine.cc.
References callback, event, and user_data.
Referenced by fl_view_keyboard_delegate_iface_init().
| void fl_engine_send_mouse_pointer_event | ( | FlEngine * | engine, |
| FlutterPointerPhase | phase, | ||
| size_t | timestamp, | ||
| double | x, | ||
| double | y, | ||
| FlutterPointerDeviceKind | device_kind, | ||
| double | scroll_delta_x, | ||
| double | scroll_delta_y, | ||
| int64_t | buttons | ||
| ) |
fl_engine_send_mouse_pointer_event: @engine: an #FlEngine. @phase: mouse phase. @timestamp: time when event occurred in microseconds. @x: x location of mouse cursor. @y: y location of mouse cursor. @device_kind: kind of pointing device. @scroll_delta_x: x offset of scroll. @scroll_delta_y: y offset of scroll. @buttons: buttons that are pressed.
Sends a mouse pointer event to the engine.
Definition at line 790 of file fl_engine.cc.
References kMousePointerDeviceId.
Referenced by check_pointer_inside(), fl_view_scrolling_delegate_iface_init(), leave_notify_event_cb(), motion_notify_event_cb(), send_pointer_button_event(), and TEST().
| void fl_engine_send_platform_message | ( | FlEngine * | engine, |
| const gchar * | channel, | ||
| GBytes * | message, | ||
| GCancellable * | cancellable, | ||
| GAsyncReadyCallback | callback, | ||
| gpointer | user_data | ||
| ) |
fl_engine_send_platform_message: @engine: an #FlEngine. @channel: channel to send to. @message: (allow-none): message buffer to send or NULL for an empty message @cancellable: (allow-none): a #GCancellable or NULL. @callback: (scope async): a #GAsyncReadyCallback to call when the request is satisfied. @user_data: (closure): user data to pass to @callback.
Asynchronously sends a platform message.
Definition at line 688 of file fl_engine.cc.
References callback, FL_ENGINE_ERROR_FAILED, fl_engine_error_quark(), fl_engine_platform_message_response_cb(), result, and user_data.
Referenced by send_on_channel(), and TEST().
| GBytes* fl_engine_send_platform_message_finish | ( | FlEngine * | engine, |
| GAsyncResult * | result, | ||
| GError ** | error | ||
| ) |
fl_engine_send_platform_message_finish: @engine: an #FlEngine.
Completes request started with fl_engine_send_platform_message().
Returns: message response on success or NULL on error.
Definition at line 747 of file fl_engine.cc.
Referenced by send_on_channel_finish().
| gboolean fl_engine_send_platform_message_response | ( | FlEngine * | engine, |
| const FlutterPlatformMessageResponseHandle * | handle, | ||
| GBytes * | response, | ||
| GError ** | error | ||
| ) |
fl_engine_send_platform_message_response: @engine: an #FlEngine. @handle: handle that was provided in FlEnginePlatformMessageHandler. @response: (allow-none): response to send or NULL for an empty response. @error: (allow-none): #GError location to store the error occurring, or NULL to ignore.
Responds to a platform message.
Returns: TRUE on success.
Definition at line 656 of file fl_engine.cc.
References error, FL_ENGINE_ERROR_FAILED, fl_engine_error_quark(), result, and TRUE.
Referenced by fl_engine_platform_message_cb(), send_response(), and TEST().
| void fl_engine_send_pointer_pan_zoom_event | ( | FlEngine * | self, |
| size_t | timestamp, | ||
| double | x, | ||
| double | y, | ||
| FlutterPointerPhase | phase, | ||
| double | pan_x, | ||
| double | pan_y, | ||
| double | scale, | ||
| double | rotation | ||
| ) |
Definition at line 826 of file fl_engine.cc.
References kPointerPanZoomDeviceId.
Referenced by fl_view_scrolling_delegate_iface_init(), and TEST().
| void fl_engine_send_window_metrics_event | ( | FlEngine * | engine, |
| size_t | width, | ||
| size_t | height, | ||
| double | pixel_ratio | ||
| ) |
fl_engine_send_window_metrics_event: @engine: an #FlEngine. @width: width of the window in pixels. @height: height of the window in pixels. @pixel_ratio: scale factor for window.
Sends a window metrics event to the engine.
Definition at line 768 of file fl_engine.cc.
References event, height, and width.
Referenced by handle_geometry_changed(), and TEST().
| void fl_engine_send_window_state_event | ( | FlEngine * | engine, |
| gboolean | visible, | ||
| gboolean | focused | ||
| ) |
fl_engine_send_window_state_event: @engine: an #FlEngine. @visible: whether the window is currently visible or not. @focused: whether the window is currently focused or not.
Sends a window state event to the engine.
Definition at line 756 of file fl_engine.cc.
References flutter::kHidden, flutter::kInactive, flutter::kResumed, and set_app_lifecycle_state().
Referenced by TEST(), and window_state_event_cb().
| void fl_engine_set_on_pre_engine_restart_handler | ( | FlEngine * | engine, |
| FlEngineOnPreEngineRestartHandler | handler, | ||
| gpointer | user_data, | ||
| GDestroyNotify | destroy_notify | ||
| ) |
fl_engine_set_on_pre_engine_restart_handler: @engine: an #FlEngine. @handler: function to call when the engine is restarted. @user_data: (closure): user data to pass to @handler. @destroy_notify: (allow-none): a function which gets called to free @user_data, or NULL.
Registers the function called right before the engine is restarted.
Definition at line 638 of file fl_engine.cc.
References user_data.
Referenced by create_context_cb(), fl_view_dispose(), and TEST().
| void fl_engine_set_platform_message_handler | ( | FlEngine * | engine, |
| FlEnginePlatformMessageHandler | handler, | ||
| gpointer | user_data, | ||
| GDestroyNotify | destroy_notify | ||
| ) |
fl_engine_set_platform_message_handler: @engine: an #FlEngine. @handler: function to call when a platform message is received. @user_data: (closure): user data to pass to @handler. @destroy_notify: (allow-none): a function which gets called to free @user_data, or NULL.
Registers the function called when a platform message is received. Call fl_engine_send_platform_message_response() with the response to this message. Ownership of #FlutterPlatformMessageResponseHandle is transferred to the caller, and the message must be responded to avoid memory leaks.
Definition at line 603 of file fl_engine.cc.
References user_data.
Referenced by fl_binary_messenger_new().
| void fl_engine_set_update_semantics_handler | ( | FlEngine * | engine, |
| FlEngineUpdateSemanticsHandler | handler, | ||
| gpointer | user_data, | ||
| GDestroyNotify | destroy_notify | ||
| ) |
fl_engine_set_update_semantics_handler: @engine: an #FlEngine. @handler: function to call when a semantics update is received. @user_data: (closure): user data to pass to @handler. @destroy_notify: (allow-none): a function which gets called to free @user_data, or NULL.
Registers the function called when a semantics update is received.
Definition at line 621 of file fl_engine.cc.
References user_data.
Referenced by create_context_cb(), and fl_view_dispose().
| gboolean fl_engine_start | ( | FlEngine * | engine, |
| GError ** | error | ||
| ) |
fl_engine_start: @engine: an #FlEngine. @error: (allow-none): #GError location to store the error occurring, or NULL to ignore.
Starts the Flutter engine.
Returns: TRUE on success.
Definition at line 471 of file fl_engine.cc.
References args, compositor_collect_backing_store_callback(), compositor_create_backing_store_callback(), compositor_present_layers_callback(), error, fl_dart_project_get_aot_library_path(), fl_dart_project_get_assets_path(), fl_dart_project_get_dart_entrypoint_arguments(), fl_dart_project_get_icu_data_path(), FL_ENGINE_ERROR_FAILED, fl_engine_error_quark(), fl_engine_get_switches(), fl_engine_gl_clear_current(), fl_engine_gl_external_texture_frame_callback(), fl_engine_gl_get_fbo(), fl_engine_gl_make_current(), fl_engine_gl_make_resource_current(), fl_engine_gl_present(), fl_engine_gl_proc_resolver(), fl_engine_on_pre_engine_restart_cb(), fl_engine_platform_message_cb(), fl_engine_post_task(), fl_engine_runs_task_on_current_thread(), fl_engine_update_semantics_cb(), fl_renderer_get_refresh_rate(), fl_settings_new(), fl_settings_plugin_new(), fl_settings_plugin_start(), fl_task_runner_new(), kPlatformTaskRunnerIdentifier, result, setup_locales(), and TRUE.
Referenced by make_mock_engine(), realize_cb(), and TEST().
| gboolean fl_engine_unregister_external_texture | ( | FlEngine * | engine, |
| int64_t | texture_id | ||
| ) |
fl_engine_unregister_external_texture: @engine: an #FlEngine. @texture_id: the identifier of the texture that is not available anymore.
Tells the Flutter engine that an existing external texture is not available anymore.
Returns: TRUE on success.
Definition at line 908 of file fl_engine.cc.
References texture_id.
Referenced by unregister_texture().
| void fl_engine_update_accessibility_features | ( | FlEngine * | engine, |
| int32_t | flags | ||
| ) |
fl_engine_update_accessibility_features: @engine: an #FlEngine. @flags: the features to enable in the accessibility tree.
Tells the Flutter engine to update the flags on the accessibility tree.
Definition at line 937 of file fl_engine.cc.
References flags.
Referenced by update_settings().