Commit 2781a086 authored by Adam Barth's avatar Adam Barth

Tooltips show up in the wrong place (#3574)

We had a math-o.

Fixes #3563
parent adac9275
...@@ -246,7 +246,7 @@ class _TooltipPositionDelegate extends SingleChildLayoutDelegate { ...@@ -246,7 +246,7 @@ class _TooltipPositionDelegate extends SingleChildLayoutDelegate {
} else if (normalizedTargetX > size.width - screenEdgeMargin.right - childSize.width / 2.0) { } else if (normalizedTargetX > size.width - screenEdgeMargin.right - childSize.width / 2.0) {
x = size.width - screenEdgeMargin.right - childSize.width; x = size.width - screenEdgeMargin.right - childSize.width;
} else { } else {
x = normalizedTargetX + childSize.width / 2.0; x = normalizedTargetX - childSize.width / 2.0;
} }
return new Offset(x, y); return new Offset(x, y);
} }
......
...@@ -8,7 +8,7 @@ import 'package:flutter/widgets.dart'; ...@@ -8,7 +8,7 @@ import 'package:flutter/widgets.dart';
import 'package:flutter_test/flutter_test.dart'; import 'package:flutter_test/flutter_test.dart';
import 'package:test/test.dart'; import 'package:test/test.dart';
import 'test_semantics.dart'; import '../widget/test_semantics.dart';
// This file uses "as dynamic" in a few places to defeat the static // This file uses "as dynamic" in a few places to defeat the static
// analysis. In general you want to avoid using this style in your // analysis. In general you want to avoid using this style in your
...@@ -26,6 +26,59 @@ import 'test_semantics.dart'; ...@@ -26,6 +26,59 @@ import 'test_semantics.dart';
// production code. // production code.
void main() { void main() {
test('Does tooltip end up in the right place - center', () {
testElementTree((ElementTreeTester tester) {
GlobalKey key = new GlobalKey();
tester.pumpWidget(
new Overlay(
initialEntries: <OverlayEntry>[
new OverlayEntry(
builder: (BuildContext context) {
return new Stack(
children: <Widget>[
new Positioned(
left: 300.0,
top: 0.0,
child: new Tooltip(
key: key,
message: 'TIP',
height: 20.0,
padding: const EdgeInsets.all(5.0),
verticalOffset: 20.0,
screenEdgeMargin: const EdgeInsets.all(10.0),
preferBelow: false,
fadeDuration: const Duration(seconds: 1),
showDuration: const Duration(seconds: 2),
child: new Container(
width: 0.0,
height: 0.0
)
)
),
]
);
}
),
]
)
);
(key.currentState as dynamic).showTooltip(); // before using "as dynamic" in your code, see note top of file
tester.pump(const Duration(seconds: 2)); // faded in, show timer started (and at 0.0)
/********************* 800x600 screen
* o * y=0
* | * }- 20.0 vertical offset, of which 10.0 is in the screen edge margin
* +----+ * \- (5.0 padding in height)
* | | * |- 20 height
* +----+ * /- (5.0 padding in height)
* *
*********************/
RenderBox tip = tester.findText('TIP').renderObject.parent.parent.parent.parent.parent;
expect(tip.localToGlobal(tip.size.topLeft(Point.origin)), equals(const Point(284.0, 20.0)));
});
});
test('Does tooltip end up in the right place - top left', () { test('Does tooltip end up in the right place - top left', () {
testElementTree((ElementTreeTester tester) { testElementTree((ElementTreeTester tester) {
GlobalKey key = new GlobalKey(); GlobalKey key = new GlobalKey();
......
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