Android|Android Flutter实现有趣的页面滚动效果
目录
- CustomScrollView 简介
- 改造原代码
- 让导航栏更有趣
- 改造后的代码
- 其他效果
- 总结
ListView
将几个 GridView
组合在一起实现了不同可滑动组件的粘合,但是这里必须要设置禁止 GridView
的滑动,防止多个滑动组件的冲突。这种方式写起来不太方便,事实上 Flutter 提供了 CustomScrollView
来粘合多个滑动组件,并且可以实现更有趣的滑动效果。CustomScrollView 简介
CustomScrollView
的常用属性如下:slivers
:最重要的属性,由多个SliverXX组件组成的数组,包括如SliverList
(对应ListView
),SliverGrid
(对应GridView
)等,如果普通组件无法直接使用,而需要使用SliverToBoxAdapter
包裹。- reverse:是否反向滚动,如果为 true,则反方向滚动。
- scrollDirection:滚动方向,可以是横向或纵向。
改造原代码 页面结构需要重新调整,将原先的 GridView 改成 SliverGrid,然后顶部区域需要使用
SliverToBoxAdapter
进行包裹。每个区域的标题栏也需要单独使用SliverToBoxAdapter
包裹起来。SliverToBoxAdapter
使用很简单,只需要将原有的组件设置为其 child
属性即可。Widget _headerGridButtons() {double height = 144; List
GridView
我们之前使用的是 Grid.count()
方法,这里只需要更换为 SliverGrid.count()
即可,参数基本相同,只是我们可以将之前禁止滑动的代码删除了。//在 SliverGrid 中无需下面两行代码禁止滑动shrinkWrap: true,physics: NeverScrollableScrollPhysics(),
让导航栏更有趣 【Android|Android Flutter实现有趣的页面滚动效果】在 Flutter 中提供了一个
SliverAppBar
专门用于 CustomScrollView
,该导航栏基本属性和 AppBar 类似,但有些其他的属性:floating
:浮动,即便是滚动视图不在顶部,SliverAppBar
也会跟随滚动出现。snap
:手指放开时会根据当前状态决定是否展开或收起。如果为false
,则导航栏会停留在上次滑动位置。pinned
:滚动到顶部后,导航栏是否可见,默认是false
。若为false
,则滚动出顶部后导航栏将消失。expandedHeight
:导航栏展开后的高度。flexibleSpace
:扩展弹性空间,即导航栏滑动时的收起或展开组件,可以有背景图片和导航栏文字,当滑动到顶部后只显示文字导航栏,当下滑后,会逐步显示背景内容,从而实现动态导航栏的效果。
SliverAppBar _getAppBar(String title) {return SliverAppBar(pinned: true,expandedHeight: 200,brightness: Brightness.dark,flexibleSpace: FlexibleSpaceBar(title: Text(title),background: Image.network('https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=688497718,308119011&fm=26&gp=0.jpg',fit: BoxFit.cover,),),); }
改造后的代码 改造后需要使用
Container
包裹,以设置背景颜色,多个 Sliver
组件依次排列就可以完成拼接后一起滚动,相比使用 ListView
来说会更简便,且效果更好。@overrideWidget build(BuildContext context) {return Container(color: Colors.white,child: CustomScrollView(slivers: [_getAppBar('个人中心'),_headerGridButtons(),_getMenuTitle('金融理财'),_gridButtons(GridMockData.financeGrids()),_getMenuTitle('生活服务'),_gridButtons(GridMockData.serviceGrids()),_getMenuTitle('购物消费'),_gridButtons(GridMockData.thirdpartyGrids()),],),); }
其他效果 除了上述的效果外,Flutter 还提供了
SliverPersistentHeader
悬停头部组件用于显示悬停的表头。具体可以参考对应文档,这在需要展示顶部的功能切换栏或者表格表头的时候很有用。总结 本篇介绍了
CustomScrollView
的基本用法以及 SliverAppBar
的使用,通过 SliverAppBar
可以让导航栏的滑动更有趣。在实际开发过程中,推荐在有多个滑动组件组合的时候优先使用 CustomScrollView
。以上就是Android Flutter实现有趣的页面滚动效果的详细内容,更多关于Android Flutter页面滚动效果的资料请关注脚本之家其它相关文章!
推荐阅读
- Android利用Hero实现列表与详情页无缝切换动画
- C语言实现模拟银行系统
- Android开发一行代码解决安卓重复点击
- IO流篇 -- 基于io流实现文件夹拷贝(拷贝子文件夹及子文件夹内文件)
- 如何快速集成Android版Serverless认证服务-手机号码篇
- 简单实现程序DLL劫持
- 低代码如何实现链接一切应用,实现办公自动化
- Spring MVC实现文件上传
- QT|QT---创建对话框3(形状可变对话框的实现)
- Qt探索之旅|Qt实现思维导图功能(二)