diff --git a/packages/flutter/lib/src/rendering/layer.dart b/packages/flutter/lib/src/rendering/layer.dart index 315c51db1f198..5ad0e2e7fca5f 100644 --- a/packages/flutter/lib/src/rendering/layer.dart +++ b/packages/flutter/lib/src/rendering/layer.dart @@ -1228,8 +1228,7 @@ class TransformLayer extends OffsetLayer { /// The [transform] and [offset] properties must be non-null before the /// compositing phase of the pipeline. TransformLayer({ Matrix4 transform, Offset offset = Offset.zero }) - : assert(transform.storage.every((double value) => value.isFinite)), - _transform = transform, + : _transform = transform, super(offset: offset); /// The matrix to apply. diff --git a/packages/flutter/lib/src/rendering/proxy_box.dart b/packages/flutter/lib/src/rendering/proxy_box.dart index d529bf1fddd8c..434d6233250d6 100644 --- a/packages/flutter/lib/src/rendering/proxy_box.dart +++ b/packages/flutter/lib/src/rendering/proxy_box.dart @@ -2280,11 +2280,9 @@ class RenderFittedBox extends RenderProxyBox { final Rect sourceRect = _resolvedAlignment.inscribe(sizes.source, Offset.zero & childSize); final Rect destinationRect = _resolvedAlignment.inscribe(sizes.destination, Offset.zero & size); _hasVisualOverflow = sourceRect.width < childSize.width || sourceRect.height < childSize.height; - assert(scaleX.isFinite && scaleY.isFinite); _transform = Matrix4.translationValues(destinationRect.left, destinationRect.top, 0.0) ..scale(scaleX, scaleY, 1.0) ..translate(-sourceRect.left, -sourceRect.top); - assert(_transform.storage.every((double value) => value.isFinite)); } } @@ -2298,7 +2296,7 @@ class RenderFittedBox extends RenderProxyBox { @override void paint(PaintingContext context, Offset offset) { - if (size.isEmpty || child.size.isEmpty) + if (size.isEmpty) return; _updatePaintData(); if (child != null) { diff --git a/packages/flutter/test/rendering/proxy_box_test.dart b/packages/flutter/test/rendering/proxy_box_test.dart index cfb0b61ab5b0a..ddba02f808965 100644 --- a/packages/flutter/test/rendering/proxy_box_test.dart +++ b/packages/flutter/test/rendering/proxy_box_test.dart @@ -15,12 +15,11 @@ import '../flutter_test_alternative.dart'; import 'rendering_tester.dart'; void main() { - test('RenderFittedBox does not paint with empty sizes', () { + test('RenderFittedBox paint', () { bool painted; - RenderFittedBox makeFittedBox(Size size) { + RenderFittedBox makeFittedBox() { return RenderFittedBox( child: RenderCustomPaint( - preferredSize: size, painter: TestCallbackPainter(onPaint: () { painted = true; }), @@ -28,19 +27,13 @@ void main() { ); } - // The RenderFittedBox paints if both its size and its child's size are nonempty. painted = false; - layout(makeFittedBox(Size(1, 1)), phase: EnginePhase.paint); + layout(makeFittedBox(), phase: EnginePhase.paint); expect(painted, equals(true)); - // The RenderFittedBox should not paint if its child is empty-sized. - painted = false; - layout(makeFittedBox(Size.zero), phase: EnginePhase.paint); - expect(painted, equals(false)); - // The RenderFittedBox should not paint if it is empty. painted = false; - layout(makeFittedBox(Size(1, 1)), constraints: BoxConstraints.tight(Size.zero), phase: EnginePhase.paint); + layout(makeFittedBox(), constraints: BoxConstraints.tight(Size.zero), phase: EnginePhase.paint); expect(painted, equals(false)); });