当前位置: 首页 > news >正文

SliverPersistentHeader组件 实现Flutter吸顶效果

效果:

20230723-212152-73_Trim

代码:

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';class StickHeaderPage extends StatefulWidget {State<StatefulWidget> createState() {// TODO: implement createStatereturn _StickHeaderPageState();}}class _StickHeaderPageState extends State<StickHeaderPage> {Widget build(BuildContext context) {// TODO: implement buildreturn Scaffold(appBar: AppBar(title: const Text("Sticky Header"),),body: CustomScrollView(slivers: [_topWidget(),_stickyHeader(),_listView(),],physics: const BouncingScrollPhysics(),),);}Widget _topWidget() {return SliverToBoxAdapter(child: Container(child: Image.network("https://2sc2.autoimg.cn/escimg/g27/M04/5D/0B/f_900x675_0_q87_autohomecar__ChxkmWMVdMCAJZdZAAFU8OPC7Xs588.jpg",),),);}Widget _stickyHeader() {return SliverPersistentHeader(pinned: true,floating: true,delegate: _StickyHeaderDelegate(minHeight: 50,maxHeight: 50,child: Container(height: 100,color: Colors.blue,alignment: Alignment.centerLeft,child: const Text("Sticky Header", style: TextStyle(fontSize: 20),),),),);}Widget _listView() {return SliverList(delegate:SliverChildBuilderDelegate( (context, index) {return Container(height: 50,color: index % 2 == 0 ? Colors.white : Colors.black12,width: double.infinity,alignment: Alignment.center,child: Text("Item $index"),);},childCount: 50,));}}class _StickyHeaderDelegate extends SliverPersistentHeaderDelegate {_StickyHeaderDelegate({required this.minHeight,required this.maxHeight,required this.child,});final double minHeight;final double maxHeight;final Widget child;Widget build(BuildContext context, double shrinkOffset, bool overlapsContent) {// TODO: implement buildreturn SizedBox.expand(child: child,);}// TODO: implement maxExtentdouble get maxExtent => maxHeight;// TODO: implement minExtentdouble get minExtent => minHeight;bool shouldRebuild(covariant _StickyHeaderDelegate oldDelegate) {// TODO: implement shouldRebuildreturn (maxHeight != oldDelegate.maxHeight ||minHeight != oldDelegate.minHeight ||child != oldDelegate.child);}

本文参考自:https://www.jianshu.com/p/b5292ef7c38c

http://www.lryc.cn/news/98657.html

相关文章:

  • Nginx性能优化配置
  • 杭州多校2023“钉耙编程”中国大学生算法设计超级联赛(4)
  • 音视频入门之音频采集、编码、播放
  • 在 Linux 系统中,如何发起POST/GET请求
  • 文心一言大数据模型-文心千帆大模型平台
  • django学习笔记(1)
  • postgresql主从搭建
  • 将Parasoft和ChatGPT相结合会如何?
  • Go text/template详解:使用指南与最佳实践
  • Stable Diffusion在各种显卡上的加速方式测试,最高可以提速211.2%
  • Java读取外链图片忽略ssl验证转为base64
  • 系统架构设计师 10:软件架构的演化和维护
  • Windows 11 绕过 TPM 方法总结,通用免 TPM 镜像下载 (2023 年 7 月更新)
  • EXCEL,如何比较2个表里的数据差异(使用数据透视表)
  • 字节抖音小程序,使用 uniapp 调起内置支付
  • django模板继承和组件了解
  • 首屏优化,给以图片为背景的元素增加相似背景,优化用户体验,background-image 绘制规则
  • 【用户体验分析报告】 按需加载组件,导致组件渲染卡顿,影响交互体验?组件拆包预加载方案来了!
  • idea 关闭页面右侧预览框/预览条
  • CSS3 Flexbox
  • 东南大学轴承故障诊断(Python代码,CNN模型,适合复合故障诊断研究)
  • ubuntu--Motrix
  • PHP 3des加解密新旧方法可对接加密
  • 【朴素贝叶斯-新闻主题分类】
  • 安卓面试问题记录
  • php-golang-jsonrpc2.0 rpc-codec/jsonrpc2和tivoka/tivoka实践
  • 听力词汇笔记(6级)
  • 【JVM】详细解析java创建对象的具体流程
  • kafka怎么用代码读取数据
  • 网关与路由器的区别