Unverified Commit d61b4fae authored by Jonah Williams's avatar Jonah Williams Committed by GitHub

Add ignoringSemantics argument to AbsorbPointer (#19651)

parent b4d3808a
...@@ -2881,8 +2881,11 @@ class RenderAbsorbPointer extends RenderProxyBox { ...@@ -2881,8 +2881,11 @@ class RenderAbsorbPointer extends RenderProxyBox {
/// The [absorbing] argument must not be null. /// The [absorbing] argument must not be null.
RenderAbsorbPointer({ RenderAbsorbPointer({
RenderBox child, RenderBox child,
this.absorbing = true bool absorbing = true,
bool ignoringSemantics,
}) : assert(absorbing != null), }) : assert(absorbing != null),
_absorbing = absorbing,
_ignoringSemantics = ignoringSemantics,
super(child); super(child);
/// Whether this render object absorbs pointers during hit testing. /// Whether this render object absorbs pointers during hit testing.
...@@ -2890,7 +2893,33 @@ class RenderAbsorbPointer extends RenderProxyBox { ...@@ -2890,7 +2893,33 @@ class RenderAbsorbPointer extends RenderProxyBox {
/// Regardless of whether this render object absorbs pointers during hit /// Regardless of whether this render object absorbs pointers during hit
/// testing, it will still consume space during layout and be visible during /// testing, it will still consume space during layout and be visible during
/// painting. /// painting.
bool absorbing; bool get absorbing => _absorbing;
bool _absorbing;
set absorbing(bool value) {
if (_absorbing == value)
return;
_absorbing = value;
if (ignoringSemantics == null)
markNeedsSemanticsUpdate();
}
/// Whether the semantics of this render object is ignored when compiling the semantics tree.
///
/// If null, defaults to value of [absorbing].
///
/// See [SemanticsNode] for additional information about the semantics tree.
bool get ignoringSemantics => _ignoringSemantics;
bool _ignoringSemantics;
set ignoringSemantics(bool value) {
if (value == _ignoringSemantics)
return;
final bool oldEffectiveValue = _effectiveIgnoringSemantics;
_ignoringSemantics = value;
if (oldEffectiveValue != _effectiveIgnoringSemantics)
markNeedsSemanticsUpdate();
}
bool get _effectiveIgnoringSemantics => ignoringSemantics == null ? absorbing : ignoringSemantics;
@override @override
bool hitTest(HitTestResult result, { Offset position }) { bool hitTest(HitTestResult result, { Offset position }) {
...@@ -2899,10 +2928,23 @@ class RenderAbsorbPointer extends RenderProxyBox { ...@@ -2899,10 +2928,23 @@ class RenderAbsorbPointer extends RenderProxyBox {
: super.hitTest(result, position: position); : super.hitTest(result, position: position);
} }
@override
void visitChildrenForSemantics(RenderObjectVisitor visitor) {
if (child != null && !_effectiveIgnoringSemantics)
visitor(child);
}
@override @override
void debugFillProperties(DiagnosticPropertiesBuilder properties) { void debugFillProperties(DiagnosticPropertiesBuilder properties) {
super.debugFillProperties(properties); super.debugFillProperties(properties);
properties.add(new DiagnosticsProperty<bool>('absorbing', absorbing)); properties.add(new DiagnosticsProperty<bool>('absorbing', absorbing));
properties.add(
new DiagnosticsProperty<bool>(
'ignoringSemantics',
_effectiveIgnoringSemantics,
description: ignoringSemantics == null ? 'implicitly $_effectiveIgnoringSemantics' : null,
),
);
} }
} }
......
...@@ -4949,7 +4949,8 @@ class AbsorbPointer extends SingleChildRenderObjectWidget { ...@@ -4949,7 +4949,8 @@ class AbsorbPointer extends SingleChildRenderObjectWidget {
const AbsorbPointer({ const AbsorbPointer({
Key key, Key key,
this.absorbing = true, this.absorbing = true,
Widget child Widget child,
this.ignoringSemantics,
}) : assert(absorbing != null), }) : assert(absorbing != null),
super(key: key, child: child); super(key: key, child: child);
...@@ -4960,12 +4961,34 @@ class AbsorbPointer extends SingleChildRenderObjectWidget { ...@@ -4960,12 +4961,34 @@ class AbsorbPointer extends SingleChildRenderObjectWidget {
/// painting. /// painting.
final bool absorbing; final bool absorbing;
/// Whether the semantics of this render object is ignored when compiling the
/// semantics tree.
///
/// If null, defaults to the value of [absorbing].
///
/// See [SemanticsNode] for additional information about the semantics tree.
final bool ignoringSemantics;
@override @override
RenderAbsorbPointer createRenderObject(BuildContext context) => new RenderAbsorbPointer(absorbing: absorbing); RenderAbsorbPointer createRenderObject(BuildContext context) {
return new RenderAbsorbPointer(
absorbing: absorbing,
ignoringSemantics: ignoringSemantics,
);
}
@override @override
void updateRenderObject(BuildContext context, RenderAbsorbPointer renderObject) { void updateRenderObject(BuildContext context, RenderAbsorbPointer renderObject) {
renderObject.absorbing = absorbing; renderObject
..absorbing = absorbing
..ignoringSemantics = ignoringSemantics;
}
@override
void debugFillProperties(DiagnosticPropertiesBuilder properties) {
super.debugFillProperties(properties);
properties.add(new DiagnosticsProperty<bool>('absorbing', absorbing));
properties.add(new DiagnosticsProperty<bool>('ignoringSemantics', ignoringSemantics, defaultValue: null));
} }
} }
......
...@@ -5,6 +5,8 @@ ...@@ -5,6 +5,8 @@
import 'package:flutter_test/flutter_test.dart'; import 'package:flutter_test/flutter_test.dart';
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
import 'semantics_tester.dart';
void main() { void main() {
testWidgets('AbsorbPointers do not block siblings', (WidgetTester tester) async { testWidgets('AbsorbPointers do not block siblings', (WidgetTester tester) async {
bool tapped = false; bool tapped = false;
...@@ -28,4 +30,41 @@ void main() { ...@@ -28,4 +30,41 @@ void main() {
await tester.tap(find.byType(GestureDetector)); await tester.tap(find.byType(GestureDetector));
expect(tapped, true); expect(tapped, true);
}); });
}
\ No newline at end of file testWidgets('AbsorbPointers semantics', (WidgetTester tester) async {
final SemanticsTester semantics = new SemanticsTester(tester);
await tester.pumpWidget(
new AbsorbPointer(
absorbing: true,
child: new Semantics(
label: 'test',
textDirection: TextDirection.ltr,
),
),
);
expect(semantics, hasSemantics(
new TestSemantics.root(), ignoreId: true, ignoreRect: true, ignoreTransform: true));
await tester.pumpWidget(
new AbsorbPointer(
absorbing: false,
child: new Semantics(
label: 'test',
textDirection: TextDirection.ltr,
),
),
);
expect(semantics, hasSemantics(
new TestSemantics.root(
children: <TestSemantics>[
new TestSemantics.rootChild(
label: 'test',
textDirection: TextDirection.ltr,
),
],
),
ignoreId: true, ignoreRect: true, ignoreTransform: true));
semantics.dispose();
});
}
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