Unverified Commit d957c8f0 authored by Chris Bracken's avatar Chris Bracken Committed by GitHub

Add EdgeInsets, MediaQuery support for view insets (#13272)

* Add MediaQuery support for view insets

Also updates EdgeInsets documentation to reflect WindowPadding's use for
both padding and view insets.

See engine commits:
  flutter/engine#4403
  flutter/engine#4406
parent f5ef16df
...@@ -354,9 +354,9 @@ class EdgeInsets extends EdgeInsetsGeometry { ...@@ -354,9 +354,9 @@ class EdgeInsets extends EdgeInsetsGeometry {
/// Creates insets that match the given window padding. /// Creates insets that match the given window padding.
/// ///
/// If you need the current system padding in the context of a widget, /// If you need the current system padding or view insets in the context of a
/// consider using [MediaQuery.of] to obtain the current padding rather than /// widget, consider using [MediaQuery.of] to obtain these values rather than
/// using the value from [dart:ui.window], so that you get notified when it /// using the value from [dart:ui.window], so that you get notified of
/// changes. /// changes.
EdgeInsets.fromWindowPadding(ui.WindowPadding padding, double devicePixelRatio) EdgeInsets.fromWindowPadding(ui.WindowPadding padding, double devicePixelRatio)
: left = padding.left / devicePixelRatio, : left = padding.left / devicePixelRatio,
......
...@@ -41,6 +41,7 @@ class MediaQueryData { ...@@ -41,6 +41,7 @@ class MediaQueryData {
this.devicePixelRatio: 1.0, this.devicePixelRatio: 1.0,
this.textScaleFactor: 1.0, this.textScaleFactor: 1.0,
this.padding: EdgeInsets.zero, this.padding: EdgeInsets.zero,
this.viewInsets: EdgeInsets.zero,
this.alwaysUse24HourFormat: false, this.alwaysUse24HourFormat: false,
}); });
...@@ -55,6 +56,7 @@ class MediaQueryData { ...@@ -55,6 +56,7 @@ class MediaQueryData {
devicePixelRatio = window.devicePixelRatio, devicePixelRatio = window.devicePixelRatio,
textScaleFactor = window.textScaleFactor, textScaleFactor = window.textScaleFactor,
padding = new EdgeInsets.fromWindowPadding(window.padding, window.devicePixelRatio), padding = new EdgeInsets.fromWindowPadding(window.padding, window.devicePixelRatio),
viewInsets = new EdgeInsets.fromWindowPadding(window.viewInsets, window.devicePixelRatio),
alwaysUse24HourFormat = window.alwaysUse24HourFormat; alwaysUse24HourFormat = window.alwaysUse24HourFormat;
/// The size of the media in logical pixel (e.g, the size of the screen). /// The size of the media in logical pixel (e.g, the size of the screen).
...@@ -76,7 +78,17 @@ class MediaQueryData { ...@@ -76,7 +78,17 @@ class MediaQueryData {
/// the specified font size. /// the specified font size.
final double textScaleFactor; final double textScaleFactor;
/// The padding around the edges of the media (e.g., the screen). /// The number of physical pixels on each side of the display rectangle into
/// which the application can render, but over which the operating system
/// will likely place system UI, such as the keyboard, that fully obscures
/// any content.
final EdgeInsets viewInsets;
/// The number of physical pixels on each side of the display rectangle into
/// which the application can render, but which may be partially obscured by
/// system UI (such as the system notification area), or or physical
/// intrusions in the display (e.g. overscan regions on television screens or
/// phone sensor housings).
final EdgeInsets padding; final EdgeInsets padding;
/// Whether to use 24-hour format when formatting time. /// Whether to use 24-hour format when formatting time.
...@@ -104,12 +116,14 @@ class MediaQueryData { ...@@ -104,12 +116,14 @@ class MediaQueryData {
double devicePixelRatio, double devicePixelRatio,
double textScaleFactor, double textScaleFactor,
EdgeInsets padding, EdgeInsets padding,
EdgeInsets viewInsets,
}) { }) {
return new MediaQueryData( return new MediaQueryData(
size: size ?? this.size, size: size ?? this.size,
devicePixelRatio: devicePixelRatio ?? this.devicePixelRatio, devicePixelRatio: devicePixelRatio ?? this.devicePixelRatio,
textScaleFactor: textScaleFactor ?? this.textScaleFactor, textScaleFactor: textScaleFactor ?? this.textScaleFactor,
padding: padding ?? this.padding, padding: padding ?? this.padding,
viewInsets: viewInsets ?? this.viewInsets,
); );
} }
...@@ -144,6 +158,12 @@ class MediaQueryData { ...@@ -144,6 +158,12 @@ class MediaQueryData {
right: removeRight ? 0.0 : null, right: removeRight ? 0.0 : null,
bottom: removeBottom ? 0.0 : null, bottom: removeBottom ? 0.0 : null,
), ),
viewInsets: viewInsets.copyWith(
left: removeLeft ? 0.0 : null,
top: removeTop ? 0.0 : null,
right: removeRight ? 0.0 : null,
bottom: removeBottom ? 0.0 : null,
),
); );
} }
...@@ -155,16 +175,17 @@ class MediaQueryData { ...@@ -155,16 +175,17 @@ class MediaQueryData {
return typedOther.size == size return typedOther.size == size
&& typedOther.devicePixelRatio == devicePixelRatio && typedOther.devicePixelRatio == devicePixelRatio
&& typedOther.textScaleFactor == textScaleFactor && typedOther.textScaleFactor == textScaleFactor
&& typedOther.padding == padding; && typedOther.padding == padding
&& typedOther.viewInsets == viewInsets;
} }
@override @override
int get hashCode => hashValues(size, devicePixelRatio, textScaleFactor, padding); int get hashCode => hashValues(size, devicePixelRatio, textScaleFactor, padding, viewInsets);
@override @override
String toString() { String toString() {
return '$runtimeType(size: $size, devicePixelRatio: $devicePixelRatio, ' return '$runtimeType(size: $size, devicePixelRatio: $devicePixelRatio, '
'textScaleFactor: $textScaleFactor, padding: $padding)'; 'textScaleFactor: $textScaleFactor, padding: $padding, viewInsets: $viewInsets)';
} }
} }
......
...@@ -44,4 +44,30 @@ void main() { ...@@ -44,4 +44,30 @@ void main() {
expect(data.hashCode, equals(data.copyWith().hashCode)); expect(data.hashCode, equals(data.copyWith().hashCode));
expect(data.size, equals(ui.window.physicalSize / ui.window.devicePixelRatio)); expect(data.size, equals(ui.window.physicalSize / ui.window.devicePixelRatio));
}); });
testWidgets('MediaQueryData.copyWith defaults to source', (WidgetTester tester) async {
final MediaQueryData data = new MediaQueryData.fromWindow(ui.window);
final MediaQueryData copied = data.copyWith();
expect(copied.size, data.size);
expect(copied.devicePixelRatio, data.devicePixelRatio);
expect(copied.textScaleFactor, data.textScaleFactor);
expect(copied.padding, data.padding);
expect(copied.viewInsets, data.viewInsets);
});
testWidgets('MediaQuery.copyWith copies specified values', (WidgetTester tester) async {
final MediaQueryData data = new MediaQueryData.fromWindow(ui.window);
final MediaQueryData copied = data.copyWith(
size: const Size(3.14, 2.72),
devicePixelRatio: 1.41,
textScaleFactor: 1.62,
padding: const EdgeInsets.all(9.10938),
viewInsets: const EdgeInsets.all(1.67262),
);
expect(copied.size, const Size(3.14, 2.72));
expect(copied.devicePixelRatio, 1.41);
expect(copied.textScaleFactor, 1.62);
expect(copied.padding, const EdgeInsets.all(9.10938));
expect(copied.viewInsets, const EdgeInsets.all(1.67262));
});
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment