Flutter CustomScrollView 自定义滚动效果

一个自定义滚动效果的滚动视图。

CustomScrollView允许您创建各种滚动效果,比如列表、网格和展开头。例如,要创建一个滚动视图,其中包含一个扩展的应用程序栏,然后是一个列表和一个网格,请使用:SliverAppBar(展开头)、SliverList(列表)和SliverGrid(网格)。

若要控制滚动视图的初始滚动偏移,请为 控制器提供其ScrollController.initialScrollOffset属性集。

参数详解

属性说明
scrollDirection方向,默认Axis.vertical(垂直滚动)
reverse数据方向,默认false(正序)
controller控制器
primary 
physics 
shrinkWrap默认false
anchor默认0.0
cacheExtent 
sliversconst <Widget>[]
semanticChildCount 
dragStartBehavior默认DragStartBehavior.start

代码示例

CustomScrollView(
        slivers: <Widget>[
          const SliverAppBar(
            pinned: true,
            expandedHeight: 250.0,
            flexibleSpace: FlexibleSpaceBar(
              title: Text('Demo'),
            ),
          ),


          SliverGrid(
            gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent(
              maxCrossAxisExtent: 200.0,
              mainAxisSpacing: 10.0,
              crossAxisSpacing: 10.0,
              childAspectRatio: 3.0,//子控件宽高比 
            ),
            delegate: SliverChildBuilderDelegate(
              (BuildContext context, int index) {
                return Card(
                    child: Container(
                      alignment: Alignment.centerLeft,
                      padding: EdgeInsets.all(10),
                      child: Text('data $index'),
                    ),
                  );
              },
              childCount: 20,
            ),
          ),


          SliverList(
            delegate: SliverChildListDelegate(
              //返回组件集合
              List.generate(20, (int index){
                //返回 组件
                return GestureDetector(
                  onTap: () {
                    print("点击$index");
                  },
                  child: Card(
                    child: Container(
                      alignment: Alignment.centerLeft,
                      padding: EdgeInsets.all(10),
                      child: Text('data $index'),
                    ),
                  ),
                );
              }),
            ),
          ),


        ],
      ),

效果图

完整代码

查看完整代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

马志武

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值