SliverAppBar 介绍及使用

Posted meng5619

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SliverAppBar 介绍及使用相关的知识,希望对你有一定的参考价值。

 

 

 


SliverAppBar控件可以实现页面头部区域展开、折叠的效果,类似于android中的CollapsingToolbarLayout。
先看下SliverAppBar实现的效果,效果图如下:

 


SliverAppBar控件需要和CustomScrollView搭配使用,SliverAppBar要通常放在slivers的第一位,后面接其他sliver控件。

CustomScrollView(
slivers: <Widget>[
SliverAppBar(

),
//其他sliver控件
],
)

 

SliverAppBar和其他slivers控件的结构如下:

SliverAppBar中有一个非常重要的参数flexibleSpace,flexibleSpace是SliverAppBar中展开和折叠区域,flexibleSpace与expandedHeight一起使用,
expandedHeight表示flexibleSpace的高度,

SliverAppBar(
expandedHeight: 200.0,
flexibleSpace: FlexibleSpaceBar(

),
),

SliverAppBar其他常用属性说明如下:

属性 说明
leading 左侧控件,通常情况下为"返回"图标
title 标题,通常为Text控件
actions 右侧控件
flexibleSpace 展开和折叠区域
bottom 底部控件
elevation 阴影
expandedHeight 展开区域的高度
floating 设置为true时,向下滑动时,即使当前CustomScrollView不在顶部,SliverAppBar也会跟着一起向下出现
pinned 设置为true时,当SliverAppBar内容滑出屏幕时,将始终渲染一个固定在顶部的收起状态
snap 设置为true时,当手指放开时,SliverAppBar会根据当前的位置进行调整,始终保持展开或收起的状态,此效果在floating=true时生效

 

实现文章开头效果的整体代码如下:

class SliverAppBarDemo extends StatelessWidget {
@override
Widget build(BuildContext context) {
return CustomScrollView(
slivers: <Widget>[
SliverAppBar(
pinned: true,
expandedHeight: 200.0,
flexibleSpace: FlexibleSpaceBar(
title: Text(\'复仇者联盟\'),
background: Image.network(
\'http://img.haote.com/upload/20180918/2018091815372344164.jpg\',
fit: BoxFit.fitHeight,
),
),
),
SliverFixedExtentList(
itemExtent: 80.0,
delegate: SliverChildBuilderDelegate(
(BuildContext context, int index) {
return Card(
child: Container(
alignment: Alignment.center,
color: Colors.primaries[(index % 18)],
child: Text(\'\'),
),
);
},
),
),
],
);
}
}

 如果此文章对您有所帮助,欢迎扫码关注订阅号,您的点赞、转发、评论、打赏是我继续分享的最大动力。

 

 

 

 

以上是关于SliverAppBar 介绍及使用的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 NestedScrollView 滚动以在 SliverAppBar 上使用堆栈圆形头像?

Flutter:使用 ListView.builder 消失的 SliverAppBar

如何将卡片小部件放在 SliverAppBar 中?

带有 SliverAppBar 的 ScrollablePositionedList 无法正常工作

使 SliverAppBar 具有图像作为背景而不是颜色

Flutter,如何将 SliverAppbar 上的领先和动作移动到底部