Unverified Commit 169b49fb authored by Jonah Williams's avatar Jonah Williams Committed by GitHub

Revert "[framework] make transform with filterQuality a rpb (#116792)" (#117095)

This reverts commit e331dcda.
parent 409a39da
...@@ -2430,7 +2430,7 @@ class RenderTransform extends RenderProxyBox { ...@@ -2430,7 +2430,7 @@ class RenderTransform extends RenderProxyBox {
return; return;
} }
_origin = value; _origin = value;
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
...@@ -2452,7 +2452,7 @@ class RenderTransform extends RenderProxyBox { ...@@ -2452,7 +2452,7 @@ class RenderTransform extends RenderProxyBox {
return; return;
} }
_alignment = value; _alignment = value;
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
...@@ -2467,13 +2467,10 @@ class RenderTransform extends RenderProxyBox { ...@@ -2467,13 +2467,10 @@ class RenderTransform extends RenderProxyBox {
return; return;
} }
_textDirection = value; _textDirection = value;
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
@override
bool get isRepaintBoundary => alwaysNeedsCompositing;
@override @override
bool get alwaysNeedsCompositing => child != null && _filterQuality != null; bool get alwaysNeedsCompositing => child != null && _filterQuality != null;
...@@ -2498,7 +2495,7 @@ class RenderTransform extends RenderProxyBox { ...@@ -2498,7 +2495,7 @@ class RenderTransform extends RenderProxyBox {
return; return;
} }
_transform = Matrix4.copy(value); _transform = Matrix4.copy(value);
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
...@@ -2516,48 +2513,48 @@ class RenderTransform extends RenderProxyBox { ...@@ -2516,48 +2513,48 @@ class RenderTransform extends RenderProxyBox {
if (didNeedCompositing != alwaysNeedsCompositing) { if (didNeedCompositing != alwaysNeedsCompositing) {
markNeedsCompositingBitsUpdate(); markNeedsCompositingBitsUpdate();
} }
markNeedsCompositedLayerUpdate(); markNeedsPaint();
} }
/// Sets the transform to the identity matrix. /// Sets the transform to the identity matrix.
void setIdentity() { void setIdentity() {
_transform!.setIdentity(); _transform!.setIdentity();
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
/// Concatenates a rotation about the x axis into the transform. /// Concatenates a rotation about the x axis into the transform.
void rotateX(double radians) { void rotateX(double radians) {
_transform!.rotateX(radians); _transform!.rotateX(radians);
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
/// Concatenates a rotation about the y axis into the transform. /// Concatenates a rotation about the y axis into the transform.
void rotateY(double radians) { void rotateY(double radians) {
_transform!.rotateY(radians); _transform!.rotateY(radians);
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
/// Concatenates a rotation about the z axis into the transform. /// Concatenates a rotation about the z axis into the transform.
void rotateZ(double radians) { void rotateZ(double radians) {
_transform!.rotateZ(radians); _transform!.rotateZ(radians);
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
/// Concatenates a translation by (x, y, z) into the transform. /// Concatenates a translation by (x, y, z) into the transform.
void translate(double x, [ double y = 0.0, double z = 0.0 ]) { void translate(double x, [ double y = 0.0, double z = 0.0 ]) {
_transform!.translate(x, y, z); _transform!.translate(x, y, z);
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
/// Concatenates a scale into the transform. /// Concatenates a scale into the transform.
void scale(double x, [ double? y, double? z ]) { void scale(double x, [ double? y, double? z ]) {
_transform!.scale(x, y, z); _transform!.scale(x, y, z);
markNeedsCompositedLayerUpdate(); markNeedsPaint();
markNeedsSemanticsUpdate(); markNeedsSemanticsUpdate();
} }
...@@ -2606,32 +2603,13 @@ class RenderTransform extends RenderProxyBox { ...@@ -2606,32 +2603,13 @@ class RenderTransform extends RenderProxyBox {
); );
} }
@override
OffsetLayer updateCompositedLayer({required covariant ImageFilterLayer? oldLayer}) {
final ImageFilterLayer layer = oldLayer ?? ImageFilterLayer();
layer.imageFilter = ui.ImageFilter.matrix(
_effectiveTransform!.storage,
filterQuality: filterQuality!
);
return layer;
}
@override @override
void paint(PaintingContext context, Offset offset) { void paint(PaintingContext context, Offset offset) {
if (child == null) { if (child != null) {
return;
}
if (isRepaintBoundary) {
return super.paint(context, offset);
}
final Matrix4 transform = _effectiveTransform!; final Matrix4 transform = _effectiveTransform!;
if (filterQuality == null) {
final Offset? childOffset = MatrixUtils.getAsTranslation(transform); final Offset? childOffset = MatrixUtils.getAsTranslation(transform);
if (childOffset != null) { if (childOffset == null) {
super.paint(context, offset + childOffset);
layer = null;
return;
}
// if the matrix is singular the children would be compressed to a line or // if the matrix is singular the children would be compressed to a line or
// single point, instead short-circuit and paint nothing. // single point, instead short-circuit and paint nothing.
final double det = transform.determinant(); final double det = transform.determinant();
...@@ -2646,6 +2624,30 @@ class RenderTransform extends RenderProxyBox { ...@@ -2646,6 +2624,30 @@ class RenderTransform extends RenderProxyBox {
super.paint, super.paint,
oldLayer: layer is TransformLayer ? layer as TransformLayer? : null, oldLayer: layer is TransformLayer ? layer as TransformLayer? : null,
); );
} else {
super.paint(context, offset + childOffset);
layer = null;
}
} else {
final Matrix4 effectiveTransform = Matrix4.translationValues(offset.dx, offset.dy, 0.0)
..multiply(transform)..translate(-offset.dx, -offset.dy);
final ui.ImageFilter filter = ui.ImageFilter.matrix(
effectiveTransform.storage,
filterQuality: filterQuality!,
);
if (layer is ImageFilterLayer) {
final ImageFilterLayer filterLayer = layer! as ImageFilterLayer;
filterLayer.imageFilter = filter;
} else {
layer = ImageFilterLayer(imageFilter: filter);
}
context.pushLayer(layer!, super.paint, offset);
assert(() {
layer!.debugCreator = debugCreator;
return true;
}());
}
}
} }
@override @override
......
...@@ -35,35 +35,6 @@ void main() { ...@@ -35,35 +35,6 @@ void main() {
expect(RenderTestObject.paintCount, 1); expect(RenderTestObject.paintCount, 1);
}); });
testWidgets('Transform with FilterQuality avoids repainting child as it animates', (WidgetTester tester) async {
RenderTestObject.paintCount = 0;
await tester.pumpWidget(
Container(
color: Colors.red,
child: Transform.translate(
offset: const Offset(5.0, 10.0),
filterQuality: FilterQuality.low,
child: const TestWidget(),
),
)
);
expect(RenderTestObject.paintCount, 1);
await tester.pumpWidget(
Container(
color: Colors.red,
child: Transform.translate(
offset: const Offset(25.0, 0.0),
filterQuality: FilterQuality.low,
child: const TestWidget(),
),
)
);
expect(RenderTestObject.paintCount, 1);
});
} }
class TestWidget extends SingleChildRenderObjectWidget { class TestWidget extends SingleChildRenderObjectWidget {
......
...@@ -616,7 +616,7 @@ void main() { ...@@ -616,7 +616,7 @@ void main() {
moreOrLessEquals(0.7071067811865476), moreOrLessEquals(0.7071067811865475), 0.0, 0.0, moreOrLessEquals(0.7071067811865476), moreOrLessEquals(0.7071067811865475), 0.0, 0.0,
moreOrLessEquals(-0.7071067811865475), moreOrLessEquals(0.7071067811865476), 0.0, 0.0, moreOrLessEquals(-0.7071067811865475), moreOrLessEquals(0.7071067811865476), 0.0, 0.0,
0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0,
moreOrLessEquals(50), moreOrLessEquals(-20.710678118654755), 0.0, 1.0, moreOrLessEquals(329.28932188134524), moreOrLessEquals(-194.97474683058329), 0.0, 1.0,
]); ]);
}); });
......
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