Commit fb512aa6 authored by Adam Barth's avatar Adam Barth

Merge pull request #494 from abarth/integer_scrolling

RenderViewport should use integer device pixels
parents 7b678ff3 75da2a9f
...@@ -1238,15 +1238,24 @@ class RenderViewport extends RenderBox with RenderObjectWithChildMixin<RenderBox ...@@ -1238,15 +1238,24 @@ class RenderViewport extends RenderBox with RenderObjectWithChildMixin<RenderBox
} }
} }
Offset get _scrollOffsetRoundedToIntegerDevicePixels {
double devicePixelRatio = sky.view.devicePixelRatio;
int dxInDevicePixels = (scrollOffset.dx * devicePixelRatio).round();
int dyInDevicePixels = (scrollOffset.dy * devicePixelRatio).round();
return new Offset(dxInDevicePixels / devicePixelRatio,
dyInDevicePixels / devicePixelRatio);
}
void paint(PaintingCanvas canvas, Offset offset) { void paint(PaintingCanvas canvas, Offset offset) {
if (child != null) { if (child != null) {
Offset roundedScrollOffset = _scrollOffsetRoundedToIntegerDevicePixels;
bool _needsClip = offset < Offset.zero || bool _needsClip = offset < Offset.zero ||
!(offset & size).contains(((offset - scrollOffset) & child.size).bottomRight); !(offset & size).contains(((offset - roundedScrollOffset) & child.size).bottomRight);
if (_needsClip) { if (_needsClip) {
canvas.save(); canvas.save();
canvas.clipRect(offset & size); canvas.clipRect(offset & size);
} }
canvas.paintChild(child, (offset - scrollOffset).toPoint()); canvas.paintChild(child, (offset - roundedScrollOffset).toPoint());
if (_needsClip) if (_needsClip)
canvas.restore(); canvas.restore();
} }
...@@ -1256,7 +1265,7 @@ class RenderViewport extends RenderBox with RenderObjectWithChildMixin<RenderBox ...@@ -1256,7 +1265,7 @@ class RenderViewport extends RenderBox with RenderObjectWithChildMixin<RenderBox
if (child != null) { if (child != null) {
assert(child.parentData is BoxParentData); assert(child.parentData is BoxParentData);
Rect childBounds = child.parentData.position & child.size; Rect childBounds = child.parentData.position & child.size;
Point transformedPosition = position + scrollOffset; Point transformedPosition = position + _scrollOffsetRoundedToIntegerDevicePixels;
if (childBounds.contains(transformedPosition)) if (childBounds.contains(transformedPosition))
child.hitTest(result, position: transformedPosition); child.hitTest(result, position: transformedPosition);
} }
......
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