Commit f6922d57 authored by Matt Sullivan's avatar Matt Sullivan Committed by Flutter GitHub Bot

Fixed incorrect offsetting when applying ShaderMasks (#45654)

parent 275a2f13
...@@ -1011,7 +1011,7 @@ class RenderShaderMask extends RenderProxyBox { ...@@ -1011,7 +1011,7 @@ class RenderShaderMask extends RenderProxyBox {
assert(needsCompositing); assert(needsCompositing);
layer ??= ShaderMaskLayer(); layer ??= ShaderMaskLayer();
layer layer
..shader = _shaderCallback(offset & size) ..shader = _shaderCallback(Offset.zero & size)
..maskRect = offset & size ..maskRect = offset & size
..blendMode = _blendMode; ..blendMode = _blendMode;
context.pushLayer(layer, super.paint, offset); context.pushLayer(layer, super.paint, offset);
......
...@@ -44,6 +44,70 @@ void main() { ...@@ -44,6 +44,70 @@ void main() {
await tester.pumpWidget(widget); await tester.pumpWidget(widget);
// The shader bounds rectangle should reflect the position of the centered SizedBox. // The shader bounds rectangle should reflect the position of the centered SizedBox.
expect(shaderBounds, equals(const Rect.fromLTWH(200.0, 100.0, 400.0, 400.0))); expect(shaderBounds, equals(const Rect.fromLTWH(0.0, 0.0, 400.0, 400.0)));
}, skip: isBrowser);
testWidgets('Bounds rect includes offset visual inspection', (WidgetTester tester) async {
final Widget widgetBottomRight = Container(
width: 400,
height: 400,
color: const Color(0xFFFFFFFF),
child: RepaintBoundary(
child: Align(
alignment: Alignment.bottomRight,
child: ShaderMask(
shaderCallback: (Rect bounds) => const RadialGradient(
center: Alignment.center,
radius: 0.05,
colors: <Color>[Color(0xFFFF0000), Color(0xFF00FF00)],
tileMode: TileMode.mirror,
).createShader(bounds),
child: Container(
width: 100,
height: 100,
color: const Color(0xFFFFFFFF),
),
),
),
),
);
await tester.pumpWidget(widgetBottomRight);
await expectLater(
find.byType(RepaintBoundary),
matchesGoldenFile('shader_mask.bounds.matches_bottom_right.png'),
);
final Widget widgetTopLeft = Container(
width: 400,
height: 400,
color: const Color(0xFFFFFFFF),
child: RepaintBoundary(
child: Align(
alignment: Alignment.topLeft,
child: ShaderMask(
shaderCallback: (Rect bounds) => const RadialGradient(
center: Alignment.center,
radius: 0.05,
colors: <Color>[Color(0xFFFF0000), Color(0xFF00FF00)],
tileMode: TileMode.mirror,
).createShader(bounds),
child: Container(
width: 100,
height: 100,
color: const Color(0xFFFFFFFF),
),
),
),
),
);
await tester.pumpWidget(widgetTopLeft);
await expectLater(
find.byType(RepaintBoundary),
matchesGoldenFile('shader_mask.bounds.matches_top_left.png'),
);
}, skip: isBrowser); }, skip: isBrowser);
} }
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