升级Flutter 3.32.3后pull_to_refresh下拉刷新阻尼过小振荡过大

修复方法自定义调整回弹属性springDescription

dart 复制代码
RefreshConfiguration(
      footerTriggerDistance: 15,
      dragSpeedRatio: 0.9,
      springDescription: const SpringDescription(
        mass: 1.0, //质量越大,惯性越大,运动越慢
        stiffness: 150, //刚度 - 值越大,弹簧越硬,回弹力越强
        damping: 16.0,//值越大,运动越快停止,减少振荡
      ),
      headerBuilder: () => const ClassicHeader(),
      // 配置默认头部指示器,假如你每个页面的头部指示器都一样的话,你需要设置这个
      footerBuilder: () => const ClassicFooter(),
      // 配置默认底部指示器
      enableLoadingWhenNoData: false,
      enableRefreshVibrate: false,
      //下拉刷新振动
      enableLoadMoreVibrate: false,
      //上拉加载振动
      hideFooterWhenNotFull: false,
      // Viewport不满一屏时,禁用上拉加载更多功能
      enableBallisticLoad: true,
      // 可以通过惯性滑动触发加载更多
      shouldFooterFollowWhenNotFull: (state) {
        // If you want load more with noMoreData state ,may be you should return false
        return false;
      },
      child: child!,
    );

我来解释一下 SpringDescription 中这三个属性的含义:

  1. mass (质量):
  • 值设置为 1.0
  • 这个值模拟了物理弹簧系统中物体的质量
  • 质量越大,惯性越大,运动越慢
  • 质量越小,运动越快,响应更灵敏
  1. stiffness (刚度):
  • 值设置为 150
  • 表示弹簧的硬度或弹性系数
  • 值越大,弹簧越硬,回弹力越强
  • 值越小,弹簧越软,回弹力越弱
  1. damping (阻尼):
  • 值设置为 16.0
  • 控制弹簧运动的阻力
  • 值越大,运动越快停止,减少振荡
  • 值越小,运动持续时间更长,振荡更明显

这三个参数共同决定了下拉刷新时的动画效果:

  • 当前配置(mass: 1.0, stiffness: 150, damping: 16.0)会产生一个相对平滑、有适当弹性的下拉刷新效果
  • 下拉时会有一定的弹性感,但不会过度振荡
  • 松手后会有一个自然的回弹动画

这些参数可以根据需要调整来获得不同的动画效果:

  • 想要更快的响应:可以减小 mass 或增加 stiffness
  • 想要更柔和的动画:可以减小 stiffness 或增加 damping
  • 想要更明显的弹性效果:可以减小 damping
相关推荐
芝麻开门-新起点13 小时前
Flutter 项目全流程指南:编译、调试与发布
flutter
星释13 小时前
鸿蒙Flutter三方库适配指南:11.插件发布上线及使用
flutter·华为·harmonyos
jingling55514 小时前
Flutter | 基础环境配置和创建flutter项目
前端·flutter
西西学代码14 小时前
Flutter---DragTarget(颜色拖拽选择器)
前端·javascript·flutter
芝麻开门-新起点15 小时前
Flutter 移动端性能优化指南:内存、电量与 UI 渲染
flutter·ui·性能优化
sugar_hang19 小时前
Flutter路由管理
flutter
程序员老刘19 小时前
Flutter官方拒绝适配鸿蒙的真相:不是技术问题,而是...
flutter·harmonyos·客户端
木易 士心20 小时前
Flutter PC 应用开发指南:从环境搭建到实战避坑
flutter
陈大头铃儿响叮当21 小时前
Android Studio升级后,Flutter运行android设备报错
android·flutter·android studio