要实现这个效果,可以将 SingleChildScrollView
包装在一个 Stack
中,并将 AppBar
放在 Stack
的顶部。然后,使用 ScrollController
来监听滚动位置,并根据需要显示或隐藏 AppBar
。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
| class MyHomePage extends StatefulWidget { const MyHomePage({Key? key}) : super(key: key);
@override _MyHomePageState createState() => _MyHomePageState(); }
class _MyHomePageState extends State<MyHomePage> { final ScrollController _scrollController = ScrollController(); bool _showAppBar = false;
@override void initState() { super.initState(); _scrollController.addListener(() { if (_scrollController.offset > 100 && !_showAppBar) { setState(() { _showAppBar = true; }); } else if (_scrollController.offset <= 100 && _showAppBar) { setState(() { _showAppBar = false; }); } }); }
@override Widget build(BuildContext context) { return Scaffold( body: Stack( children: [ SingleChildScrollView( controller: _scrollController, child: Column( children: [ ], ), ), Positioned( top: 0, left: 0, right: 0, child: AnimatedOpacity( duration: Duration(milliseconds: 200), opacity: _showAppBar ? 1.0 : 0.0, child: AppBar( title: Text("My App"), ), ), ), ], ), ); }
@override void dispose() { _scrollController.dispose(); super.dispose(); } }
|
在这个例子中,使用 ScrollController
来监听滚动位置,并根据需要显示或隐藏 AppBar
。将 SingleChildScrollView
包装在一个 Stack
中,并将 AppBar
放在 Stack
的顶部。在 AppBar
上使用了 AnimatedOpacity
,以便根据需要平滑地显示或隐藏 AppBar
。