flutter 之真手势冲突处理

看过好多说flutter手势冲突的文章,但大多都是说的都是官方组件之间的联动。但是作为一个Android 开发者,我理解的手势冲突更应该是去处理父父子子的关系。可以动态的决定这个事件是父处理还是子处理。

flutter 滑动组件一般都可以设置ScrollPhysics,我们通过重写ScrollPhysics的applyPhysicsToUserOffset方法来进行事件的分发。当组件有手势滑动的时候,会先回调这个方法,这个方法的返回值决定这次手势真正处理的数值,比如返回0,这个组件就不会滑动。

scala 复制代码
class _ChildScrollPhysics extends ScrollPhysics {
  final ScrollController controller;
  const _ChildScrollPhysics(this.controller, {super.parent});


  @override
  double applyPhysicsToUserOffset(ScrollMetrics position, double offset) {
    var isReach =  (
        (position.pixels <= position.minScrollExtent && offset > 0 ) || // 到达顶部
            (position.pixels >= position.maxScrollExtent && offset < 0)   // 到达底部
    );
    if(isReach){
      controller.jumpTo(controller.position.pixels - offset);
      return 0;
    }else {
      return a;
    }
  }

  @override
  _ChildScrollPhysics applyTo(ScrollPhysics? ancestor) {
    return _ChildScrollPhysics(controller,parent: buildParent(ancestor));
  }

}
less 复制代码
var contoller = ScrollController();
class ScrollPhysicsTestPage extends StatelessWidget {
  const ScrollPhysicsTestPage({super.key});

  @override
  Widget build(BuildContext context) {

    return Material(
      color: Colors.white,
      child: ListView.builder(
          controller: contoller,
          physics: ClampingScrollPhysics(),
          itemBuilder: (context,index){
            if(index == 3){
              return SizedBox(
                height: 300,
                child: ListView.builder(
                  padding: EdgeInsets.zero,
                  physics:   _ChildScrollPhysics(contoller),
                  itemBuilder: (context,index){
                    return Container(height: 100,color: Colors.blue,
                        margin: const EdgeInsets.only(bottom: 20));
                  },
                  itemCount: 10,
                ),
              );
            }
            return Container(height: 100,color: Colors.red,
                margin: const EdgeInsets.only(bottom: 20)
            );
          }),
    );
  }
}

_ChildScrollPhysics 中的controll 是父节点的controller。

arduino 复制代码
 var isReach =  (
     (position.pixels <= position.minScrollExtent && offset > 0 ) || // 到达顶部
         (position.pixels >= position.maxScrollExtent && offset < 0)   // 到达底部
 );

这部分代码是判断子节点是否滑动到边界。

kotlin 复制代码
if(isReach){
      controller.jumpTo(controller.position.pixels - offset);
      return 0;
    }else {
      return a;
    }

如果到了边界交给父节点的controller 去处理。没有到边界自己全权处理。

相关推荐
做人不要太理性18 分钟前
CANN Runtime 运行时组件深度解析:任务调度机制、存储管理策略与维测体系构建逻辑
android·运维·魔珐星云
我命由我1234535 分钟前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime
ZH154558913135 分钟前
Flutter for OpenHarmony Python学习助手实战:自动化脚本开发的实现
python·学习·flutter
朗迹 - 张伟1 小时前
Tauri2 导出 Android 详细教程
android
lpruoyu2 小时前
【Android第一行代码学习笔记】Android架构_四大组件_权限_持久化_通知_异步_服务
android·笔记·学习
晚烛2 小时前
CANN + 物理信息神经网络(PINNs):求解偏微分方程的新范式
javascript·人工智能·flutter·html·零售
一起养小猫2 小时前
Flutter for OpenHarmony 实战:扫雷游戏完整开发指南
flutter·harmonyos
独自破碎E3 小时前
【BISHI15】小红的夹吃棋
android·java·开发语言
晚烛3 小时前
CANN 赋能智慧医疗:构建合规、高效、可靠的医学影像 AI 推理系统
人工智能·flutter·零售
晚霞的不甘3 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d