Skip to content

Commit

Permalink
Reland "Remove physical geometry" (flutter#47872)
Browse files Browse the repository at this point in the history
Relands flutter#47825 with a doc fix (see second commit).
  • Loading branch information
goderbauer authored Nov 9, 2023
1 parent 0fae75f commit 36d0a23
Show file tree
Hide file tree
Showing 7 changed files with 8 additions and 40 deletions.
2 changes: 1 addition & 1 deletion lib/ui/hooks.dart
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,7 @@ _ViewConfiguration _buildViewConfiguration(
) {
return _ViewConfiguration(
devicePixelRatio: devicePixelRatio,
geometry: Rect.fromLTWH(0.0, 0.0, width, height),
size: Size(width, height),
viewPadding: ViewPadding._(
top: viewPaddingTop,
right: viewPaddingRight,
Expand Down
9 changes: 4 additions & 5 deletions lib/ui/platform_dispatcher.dart
Original file line number Diff line number Diff line change
Expand Up @@ -1462,7 +1462,7 @@ class _PlatformConfiguration {
class _ViewConfiguration {
const _ViewConfiguration({
this.devicePixelRatio = 1.0,
this.geometry = Rect.zero,
this.size = Size.zero,
this.viewInsets = ViewPadding.zero,
this.viewPadding = ViewPadding.zero,
this.systemGestureInsets = ViewPadding.zero,
Expand All @@ -1479,9 +1479,8 @@ class _ViewConfiguration {
/// The pixel density of the output surface.
final double devicePixelRatio;

/// The geometry requested for the view on the screen or within its parent
/// window, in logical pixels.
final Rect geometry;
/// The size requested for the view in logical pixels.
final Size size;

/// The number of physical pixels on each side of the display rectangle into
/// which the view can render, but over which the operating system will likely
Expand Down Expand Up @@ -1551,7 +1550,7 @@ class _ViewConfiguration {

@override
String toString() {
return '$runtimeType[geometry: $geometry]';
return '$runtimeType[size: $size]';
}
}

Expand Down
25 changes: 1 addition & 24 deletions lib/ui/window.dart
Original file line number Diff line number Diff line change
Expand Up @@ -138,25 +138,6 @@ class FlutterView {
/// The value here is equal to the value exposed on [display].
double get devicePixelRatio => _viewConfiguration.devicePixelRatio;

/// The dimensions and location of the rectangle into which the scene rendered
/// in this view will be drawn on the screen, in physical pixels.
///
/// When this changes, [PlatformDispatcher.onMetricsChanged] is called.
///
/// At startup, the size and location of the view may not be known before Dart
/// code runs. If this value is observed early in the application lifecycle,
/// it may report [Rect.zero].
///
/// This value does not take into account any on-screen keyboards or other
/// system UI. The [padding] and [viewInsets] properties provide a view into
/// how much of each side of the view may be obscured by system UI.
///
/// See also:
///
/// * [WidgetsBindingObserver], for a mechanism at the widgets layer to
/// observe when this value changes.
Rect get physicalGeometry => _viewConfiguration.geometry;

/// The dimensions of the rectangle into which the scene rendered in this view
/// will be drawn on the screen, in physical pixels.
///
Expand All @@ -175,15 +156,11 @@ class FlutterView {
/// system UI. The [padding] and [viewInsets] properties provide information
/// about how much of each side of the view may be obscured by system UI.
///
/// This value is the same as the `size` member of [physicalGeometry].
///
/// See also:
///
/// * [physicalGeometry], which reports the location of the view as well as
/// its size.
/// * [WidgetsBindingObserver], for a mechanism at the widgets layer to
/// observe when this value changes.
Size get physicalSize => _viewConfiguration.geometry.size;
Size get physicalSize => _viewConfiguration.size;

/// The number of physical pixels on each side of the display rectangle into
/// which the view can render, but over which the operating system will likely
Expand Down
6 changes: 1 addition & 5 deletions lib/web_ui/lib/src/engine/platform_dispatcher.dart
Original file line number Diff line number Diff line change
Expand Up @@ -1342,7 +1342,6 @@ class ViewConfiguration {
const ViewConfiguration({
this.view,
this.devicePixelRatio = 1.0,
this.geometry = ui.Rect.zero,
this.visible = false,
this.viewInsets = ui.ViewPadding.zero as ViewPadding,
this.viewPadding = ui.ViewPadding.zero as ViewPadding,
Expand All @@ -1355,7 +1354,6 @@ class ViewConfiguration {
ViewConfiguration copyWith({
EngineFlutterView? view,
double? devicePixelRatio,
ui.Rect? geometry,
bool? visible,
ViewPadding? viewInsets,
ViewPadding? viewPadding,
Expand All @@ -1367,7 +1365,6 @@ class ViewConfiguration {
return ViewConfiguration(
view: view ?? this.view,
devicePixelRatio: devicePixelRatio ?? this.devicePixelRatio,
geometry: geometry ?? this.geometry,
visible: visible ?? this.visible,
viewInsets: viewInsets ?? this.viewInsets,
viewPadding: viewPadding ?? this.viewPadding,
Expand All @@ -1380,7 +1377,6 @@ class ViewConfiguration {

final EngineFlutterView? view;
final double devicePixelRatio;
final ui.Rect geometry;
final bool visible;
final ViewPadding viewInsets;
final ViewPadding viewPadding;
Expand All @@ -1391,7 +1387,7 @@ class ViewConfiguration {

@override
String toString() {
return '$runtimeType[view: $view, geometry: $geometry]';
return '$runtimeType[view: $view]';
}
}

Expand Down
3 changes: 0 additions & 3 deletions lib/web_ui/lib/src/engine/window.dart
Original file line number Diff line number Diff line change
Expand Up @@ -79,9 +79,6 @@ base class EngineFlutterView implements ui.FlutterView {
late final PlatformViewMessageHandler platformViewMessageHandler =
PlatformViewMessageHandler(platformViewsContainer: dom.platformViewsHost);

@override
ui.Rect get physicalGeometry => _viewConfiguration.geometry;

@override
ui.Size get physicalSize {
if (_physicalSize == null) {
Expand Down
1 change: 0 additions & 1 deletion lib/web_ui/lib/window.dart
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ abstract class FlutterView {
PlatformDispatcher get platformDispatcher;
int get viewId;
double get devicePixelRatio;
Rect get physicalGeometry;
Size get physicalSize;
ViewPadding get viewInsets;
ViewPadding get viewPadding;
Expand Down
2 changes: 1 addition & 1 deletion shell/common/fixtures/shell_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -530,7 +530,7 @@ List<int> getCurrentViewWidths() {
final List<int> result = <int>[];
for (final FlutterView view in PlatformDispatcher.instance.views) {
result.add(view.viewId);
result.add(view.physicalGeometry.width.round());
result.add(view.physicalSize.width.round());
}
return result;
}
Expand Down

0 comments on commit 36d0a23

Please sign in to comment.