Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

use flutter_embedder.h from flutter 3.13.0 #350

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 8 additions & 4 deletions src/flutter-pi.c
Original file line number Diff line number Diff line change
Expand Up @@ -1429,7 +1429,9 @@ static int flutterpi_run(struct flutterpi *flutterpi) {
goto fail_shutdown_engine;
}

COMPILE_ASSERT(sizeof(FlutterEngineDisplay) == 32);
compositor_get_view_geometry(flutterpi->compositor, &geometry);

COMPILE_ASSERT(sizeof(FlutterEngineDisplay) == 48);

engine_result = procs->NotifyDisplayUpdate(
engine,
Expand All @@ -1439,6 +1441,9 @@ static int flutterpi_run(struct flutterpi *flutterpi) {
.display_id = 0,
.single_display = true,
.refresh_rate = compositor_get_refresh_rate(flutterpi->compositor),
.width = geometry.view_size.x,
.height = geometry.view_size.y,
.device_pixel_ratio = geometry.device_pixel_ratio,
},
1
);
Expand All @@ -1451,10 +1456,8 @@ static int flutterpi_run(struct flutterpi *flutterpi) {
goto fail_shutdown_engine;
}

compositor_get_view_geometry(flutterpi->compositor, &geometry);

// just so we get an error if the window metrics event was expanded without us noticing
COMPILE_ASSERT(sizeof(FlutterWindowMetricsEvent) == 64 || sizeof(FlutterWindowMetricsEvent) == 80);
COMPILE_ASSERT(sizeof(FlutterWindowMetricsEvent) == 72 || sizeof(FlutterWindowMetricsEvent) == 88);

// update window size
engine_result = procs->SendWindowMetricsEvent(
Expand All @@ -1470,6 +1473,7 @@ static int flutterpi_run(struct flutterpi *flutterpi) {
.physical_view_inset_right = 0,
.physical_view_inset_bottom = 0,
.physical_view_inset_left = 0,
.display_id = 0,
}
);
if (engine_result != kSuccess) {
Expand Down
2 changes: 1 addition & 1 deletion third_party/flutter_embedder_header/engine.version
Original file line number Diff line number Diff line change
@@ -1 +1 @@
d44b5a94c976fbb65815374f61ab5392a220b084
1ac611c64eadbd93c5f5aba5494b8fc3b35ee952
27 changes: 21 additions & 6 deletions third_party/flutter_embedder_header/include/flutter_embedder.h
Original file line number Diff line number Diff line change
Expand Up @@ -676,9 +676,13 @@ typedef struct {
FlutterMetalCommandQueueHandle present_command_queue;
/// The callback that gets invoked when the engine requests the embedder for a
/// texture to render to.
///
/// Not used if a FlutterCompositor is supplied in FlutterProjectArgs.
FlutterMetalTextureCallback get_next_drawable_callback;
/// The callback presented to the embedder to present a fully populated metal
/// texture to the user.
///
/// Not used if a FlutterCompositor is supplied in FlutterProjectArgs.
FlutterMetalPresentCallback present_drawable_callback;
/// When the embedder specifies that a texture has a frame available, the
/// engine will call this method (on an internal engine managed thread) so
Expand Down Expand Up @@ -805,6 +809,11 @@ typedef struct {
};
} FlutterRendererConfig;

/// Display refers to a graphics hardware system consisting of a framebuffer,
/// typically a monitor or a screen. This ID is unique per display and is
/// stable until the Flutter application restarts.
typedef uint64_t FlutterEngineDisplayId;

typedef struct {
/// The size of this struct. Must be sizeof(FlutterWindowMetricsEvent).
size_t struct_size;
Expand All @@ -826,6 +835,8 @@ typedef struct {
double physical_view_inset_bottom;
/// Left inset of window.
double physical_view_inset_left;
/// The identifier of the display the view is rendering on.
FlutterEngineDisplayId display_id;
} FlutterWindowMetricsEvent;

/// The phase of the pointer event.
Expand Down Expand Up @@ -896,7 +907,6 @@ typedef enum {
kFlutterPointerSignalKindScroll,
kFlutterPointerSignalKindScrollInertiaCancel,
kFlutterPointerSignalKindScale,
kFlutterPointerSignalKindStylusAuxiliaryAction,
} FlutterPointerSignalKind;

typedef struct {
Expand Down Expand Up @@ -1654,11 +1664,6 @@ typedef const FlutterLocale* (*FlutterComputePlatformResolvedLocaleCallback)(
const FlutterLocale** /* supported_locales*/,
size_t /* Number of locales*/);

/// Display refers to a graphics hardware system consisting of a framebuffer,
/// typically a monitor or a screen. This ID is unique per display and is
/// stable until the Flutter application restarts.
typedef uint64_t FlutterEngineDisplayId;

typedef struct {
/// This size of this struct. Must be sizeof(FlutterDisplay).
size_t struct_size;
Expand All @@ -1674,6 +1679,16 @@ typedef struct {
/// This represents the refresh period in frames per second. This value may be
/// zero if the device is not running or unavailable or unknown.
double refresh_rate;

/// The width of the display, in physical pixels.
size_t width;

/// The height of the display, in physical pixels.
size_t height;

/// The pixel ratio of the display, which is used to convert physical pixels
/// to logical pixels.
double device_pixel_ratio;
} FlutterEngineDisplay;

/// The update type parameter that is passed to
Expand Down