Flutter开发之——事件监听

三 手势事件(GestureDetector)


3.1 构造函数

class GestureDetector extends StatelessWidget {

GestureDetector({

Key? key,

this.child,

this.onTapDown,

this.onTapUp,

this.onTap,

this.onTapCancel,

this.onSecondaryTap,

}

3.2 说明

  • GestureDetector是手势识别组件

  • GestureDetector可以识别单击、双击、长按、拖拽、缩放等手势

3.3 事件

单击事件

单击事件包含

  • onTapDown:按下时回调

  • onTapUp:抬起时回调

  • onTap:点击事件回调

  • onTapCancel:点击取消事件回调

用法

GestureDetector(

onTapDown: (TapDownDetails tapDownDetails) {

print(‘onTapDown’);

},

onTapUp: (TapUpDetails tapUpDetails) {

print(‘onTapUp’);

},

onTap: () {

print(‘onTap’);

},

onTapCancel: () {

print(‘onTapCancel’);

},

child: Center(child: Container(width: 200,height: 200,color: Colors.red,),),

)

按下然后抬起调用顺序

onTapDown-> onTapUp-> onTap

按下后移动的调用顺序

onTapDown-> onTapCancel

双击事件

双击是快速且连续2次在同一个位置点击,双击监听使用onDoubleTap方法,用法如下:

GestureDetector(

onDoubleTap: ()=>print(‘onDoubleTap’),

child: Center(

child: Container(

width: 200,

height: 200,

color: Colors.red,

),

),

)

长按事件

长按事件(LongPress)包含长按开始、移动、抬起、结束事件,说明如下:

  • onLongPressStart:长按开始事件回调

  • onLongPressMoveUpdate:长按移动事件回调

  • onLongPressUp:长按抬起事件回调

  • onLongPressEnd:长按结束事件回调

  • onLongPress:长按事件回调

示例

GestureDetector(

onLongPressStart: (v) => print(‘onLongPressStart’),

onLongPressMoveUpdate: (v) => print(‘onLongPressMoveUpdate’),

onLongPressUp: () => print(‘onLongPressUp’),

onLongPressEnd: (v) => print(‘onLongPressEnd’),

onLongPress: () => print(‘onLongPress’),

child: Center(

child: Container(

width: 200,

height: 200,

color: Colors.red,

),

),

)

水平/垂直拖动事件

垂直/水平拖动事件包括按下、开始、移动更新、结束、取消事件,以垂直为例说明如下

  • onVerticalDragDown:垂直拖动按下事件回调

  • onVerticalDragStart:垂直拖动开始事件回调

  • onVerticalDragUpdate:指针移动更新事件回调

  • onVerticalDragEnd:垂直拖动结束事件回调

  • onVerticalDragCancel:垂直拖动取消事件回调

示例

GestureDetector(

onVerticalDragStart: (v) => print(‘onVerticalDragStart’),

onVerticalDragDown: (v) => print(‘onVerticalDragDown’),

onVerticalDragUpdate: (v) => print(‘onVerticalDragUpdate’),

onVerticalDragCancel: () => print(‘onVerticalDragCancel’),

onVerticalDragEnd: (v) => print(‘onVerticalDragEnd’),

child: Center(

child: Container(

width: 200,

height: 200,

color: Colors.red,

),

),

)

用户垂直方向拖动调用顺序如下

onVerticalDragDown->onVerticalDragStart->onVerticalDragUpdate-> … -> onVerticalDragUpdate-> onVerticalDragEnd。

缩放事件

缩放(Scale)包含缩放开始、更新、结束。说明如下

  • onScaleStart:缩放开始事件回调

  • onScaleUpdate:缩放更新事件回调

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

题外话,我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。

我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在IT学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。但苦于知识传播途径有限,很多程序员朋友无法获得正确的资料得到学习提升,故此将并将重要的Android进阶资料包括自定义view、性能优化、MVC与MVP与MVVM三大框架的区别、NDK技术、阿里面试题精编汇总、常见源码分析等学习资料。

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

Android开发8年,阿里、百度一面惨被吊打!我是否应该转行了?

【Android进阶学习视频】、【全套Android面试秘籍】

希望我能够用我的力量帮助更多迷茫、困惑的朋友们,帮助大家在IT道路上学习和发展

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

droid进阶资料包括自定义view、性能优化、MVC与MVP与MVVM三大框架的区别、NDK技术、阿里面试题精编汇总、常见源码分析等学习资料。

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

[外链图片转存中…(img-uo3LI6LD-1711819451080)]

【Android进阶学习视频】、【全套Android面试秘籍】

希望我能够用我的力量帮助更多迷茫、困惑的朋友们,帮助大家在IT道路上学习和发展

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值