
Now a RenderBox is considered hit if one of its children are hit or it itself decides that it's hit. In particular, empty space inside a flex won't be hit because none of the children are located there and a RenderFlex doesn't consider itself hittable. Fixes #53 Fixes #1221
37 lines
1.1 KiB
Dart
37 lines
1.1 KiB
Dart
import 'package:flutter/rendering.dart';
|
|
import 'package:test/test.dart';
|
|
|
|
import 'rendering_tester.dart';
|
|
|
|
void main() {
|
|
test('Should be able to hit with negative scroll offset', () {
|
|
RenderBox green = new RenderDecoratedBox(
|
|
decoration: new BoxDecoration(
|
|
backgroundColor: const Color(0xFF00FF00)
|
|
));
|
|
|
|
RenderBox size = new RenderConstrainedBox(
|
|
additionalConstraints: new BoxConstraints.tight(const Size(100.0, 100.0)),
|
|
child: green);
|
|
|
|
RenderBox red = new RenderDecoratedBox(
|
|
decoration: new BoxDecoration(
|
|
backgroundColor: const Color(0xFFFF0000)
|
|
),
|
|
child: size);
|
|
|
|
RenderViewport viewport = new RenderViewport(child: red, scrollOffset: new Offset(0.0, -10.0));
|
|
layout(viewport);
|
|
|
|
HitTestResult result;
|
|
|
|
result = new HitTestResult();
|
|
renderView.hitTest(result, position: new Point(15.0, 0.0));
|
|
expect(result.path.first.target.runtimeType, equals(TestRenderView));
|
|
|
|
result = new HitTestResult();
|
|
renderView.hitTest(result, position: new Point(15.0, 15.0));
|
|
expect(result.path.first.target, equals(green));
|
|
});
|
|
}
|