Unverified Commit 692d7ade authored by Taha Tesser's avatar Taha Tesser Committed by GitHub

Fix `FlexibleSpaceBar` does compositing with near zero opacity. (#136255)

fixes [`flexible_space_bar.dart': Failed assertion: line 475 pos 12: 'needsCompositing': is not true.` is thrown when scrolling down in the list and then up](https://github.com/flutter/flutter/issues/135698)
parent 94f74838
...@@ -468,7 +468,7 @@ class _RenderFlexibleSpaceHeaderOpacity extends RenderOpacity { ...@@ -468,7 +468,7 @@ class _RenderFlexibleSpaceHeaderOpacity extends RenderOpacity {
if (child == null) { if (child == null) {
return; return;
} }
if (opacity == 0) { if ((opacity * 255).roundToDouble() <= 0) {
layer = null; layer = null;
return; return;
} }
......
...@@ -909,6 +909,46 @@ void main() { ...@@ -909,6 +909,46 @@ void main() {
await tester.pumpAndSettle(); await tester.pumpAndSettle();
expect(tester.getTopLeft(find.byType(Text)).dx, 72.0); expect(tester.getTopLeft(find.byType(Text)).dx, 72.0);
}); });
// This is a regression test for https://github.com/flutter/flutter/issues/135698.
testWidgetsWithLeakTracking('_FlexibleSpaceHeaderOpacity with near zero opacity avoids compositing', (WidgetTester tester) async {
await tester.pumpWidget(
MaterialApp(
home: Material(
child: NestedScrollView(
headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {
return <Widget>[
SliverOverlapAbsorber(
handle: NestedScrollView.sliverOverlapAbsorberHandleFor(context),
sliver: const SliverAppBar(
pinned: true,
expandedHeight: 200.0,
collapsedHeight: 56.0,
flexibleSpace: FlexibleSpaceBar(background: SizedBox()),
),
),
];
},
body: const SingleChildScrollView(
child: Column(
children: <Widget>[
Placeholder(fallbackHeight: 300.0),
],
),
),
),
),
),
);
// Drag the scroll view to the top to collapse the sliver app bar.
// Ensure collapsed height - current extent is near zero for the
// FlexibleSpaceBar to avoid compositing.
await tester.drag(find.byType(SingleChildScrollView), const Offset(0, -(200.0 - 56.08787892026129)));
await tester.pumpAndSettle();
expect(tester.takeException(), isNull);
}, variant: TargetPlatformVariant.mobile());
} }
class TestDelegate extends SliverPersistentHeaderDelegate { class TestDelegate extends SliverPersistentHeaderDelegate {
......
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