Flutter自定义SliverAppBar

SliverAppBar一般用于CustomScrollView中,有些时候想自定义如下:

class CommonSliverAppBarWidget extends StatelessWidget {
  const CommonSliverAppBarWidget({this.title = '', this.onPressed});

  final Function onPressed;
  final String title;
  @override
  Widget build(BuildContext context) {
    return Container(
      padding: EdgeInsets.only(top:MediaQuery.of(context).padding.top + 10), //这里高度一定上动态的MediaQuery.of(context).padding.top 适配不同屏幕,否则无法兼容
      width: Utils.width,
      child: Stack(
        children: <Widget>[
          Align(
              alignment: Alignment.topLeft,
              child: InkResponse(
                child: Container(
                  padding: EdgeInsets.only(left: 14),
                  child: Icon(
                    Icons.arrow_back,
                    color: appWhite,
                  ),
                ),
                onTap: () {
                  if (onPressed != null) {
                    onPressed();
                  }else {
                    Navigator.of(context).pop();
                  }
                },
              )),
          Align(
            alignment: Alignment.center,
            child: Padding(
              padding: EdgeInsets.symmetric(horizontal: 1),
              child: Text(
                title ?? "",
                style: TextStyle(
                    color: appWhite,
                    fontSize: 18,
                    fontWeight: fontWeightSemibold,
                    decoration: TextDecoration.none),
                maxLines: 1,
                overflow: TextOverflow.ellipsis,
              ),
            ),
          ),
        ],
      ),
    );
  }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值