Commit d348f28d authored by Ian Hickson's avatar Ian Hickson

Use the same logic in flushPaint as flushLayout (#3353)

If two repaint boundaries mark themselves dirty, but the second one is a
child of the first, then the second one will get repainted by the first
and then when we come to paint it directly, we get confused because it
isn't dirty any more.

We ran into this in layout before. Apply the same fix. Also, apply the
same fix to composition while we're at it.
parent 347831bf
...@@ -742,7 +742,7 @@ class PipelineOwner { ...@@ -742,7 +742,7 @@ class PipelineOwner {
Timeline.startSync('Compositing Bits'); Timeline.startSync('Compositing Bits');
_nodesNeedingCompositingBitsUpdate.sort((RenderObject a, RenderObject b) => a.depth - b.depth); _nodesNeedingCompositingBitsUpdate.sort((RenderObject a, RenderObject b) => a.depth - b.depth);
for (RenderObject node in _nodesNeedingCompositingBitsUpdate) { for (RenderObject node in _nodesNeedingCompositingBitsUpdate) {
if (node.owner == this) if (node._needsCompositingBitsUpdate && node.owner == this)
node._updateCompositingBits(); node._updateCompositingBits();
} }
_nodesNeedingCompositingBitsUpdate.clear(); _nodesNeedingCompositingBitsUpdate.clear();
...@@ -767,8 +767,7 @@ class PipelineOwner { ...@@ -767,8 +767,7 @@ class PipelineOwner {
_nodesNeedingPaint = <RenderObject>[]; _nodesNeedingPaint = <RenderObject>[];
// Sort the dirty nodes in reverse order (deepest first). // Sort the dirty nodes in reverse order (deepest first).
for (RenderObject node in dirtyNodes..sort((RenderObject a, RenderObject b) => b.depth - a.depth)) { for (RenderObject node in dirtyNodes..sort((RenderObject a, RenderObject b) => b.depth - a.depth)) {
assert(node._needsPaint); if (node._needsPaint && node.owner == this)
if (node.owner == this)
PaintingContext.repaintCompositedChild(node); PaintingContext.repaintCompositedChild(node);
}; };
assert(_nodesNeedingPaint.length == 0); assert(_nodesNeedingPaint.length == 0);
......
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'package:flutter/rendering.dart';
import 'package:test/test.dart';
import 'rendering_tester.dart';
void main() {
test("nested repaint boundaries - smoke test", () {
RenderOpacity a, b, c;
a = new RenderOpacity(
opacity: 1.0,
child: new RenderRepaintBoundary(
child: b = new RenderOpacity(
opacity: 1.0,
child: new RenderRepaintBoundary(
child: c = new RenderOpacity(
opacity: 1.0
)
)
)
)
);
layout(a, phase: EnginePhase.flushSemantics);
c.opacity = 0.9;
layout(a, phase: EnginePhase.flushSemantics);
a.opacity = 0.8;
c.opacity = 0.8;
layout(a, phase: EnginePhase.flushSemantics);
a.opacity = 0.7;
b.opacity = 0.7;
c.opacity = 0.7;
layout(a, phase: EnginePhase.flushSemantics);
});
}
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