Touch事件--对GestureDetector的理解

2024-04-11 22:18

本文主要是介绍Touch事件--对GestureDetector的理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作用

简单来说,GestureDetector对View触摸事件的封装。它是触摸事件的帮助类。

我们知道通过重新复写View/ViewGroup的dispatchTouchEvent方法,可以定义View对触摸事件的处理。但是,如果我们根据这些事件完成对一个View的双击、滑动(fling)等触摸操作,还是比较困难的。因为我们要写很多关于算法类的东西。而使用GestureDetector,就会省事很多,我们可以只处理我们关心的事件。例如:doubleClick,press等。而不用识别用户的TouchEvent。

用法

1. 构造GestureDetector。GestureDetector构造函数一定要传OnGestureListener传监听器,他包装了down、press、longPress、sigleTapUp、scroll、fling等事件。另外我们也可以在GestureDetector设置 setOnDoubleTapListener对双击事件的监听,通过setContextClickListener设置对单击事件的监听。推荐使用GestureDetector.SimpleOnGestureListener适配器实现。可减少代码的编写。

注意:当我们对一些手势关心时(需要处理的手势),要在返回值设为true.

2. 将事件交给GestureDetector处理。我们可以通过自定义View,或者给View设置onTouchListener实现。是通过将event事件传递给gestureDet.onTouchEvent(event);实现的。

        view.setOnTouchListener(new View.OnTouchListener() {@Overridepublic boolean onTouch(View v, MotionEvent event) {gestureDet.onTouchEvent(event);return true;}});

完整代码

package com.tiandh.tdhtest01;import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
import android.widget.Button;
import android.widget.LinearLayout;import com.tiandh.tdhtest01.view.MoveRelativeLayout;/*** Created by Administrator on 2017/5/15 0015.*/public class TestScroller extends AppCompatActivity implements View.OnClickListener {private Button buttonSelf;private LinearLayout llScroller;private MoveRelativeLayout viewParent;private View moveView;@Overrideprotected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_test_scroller);buttonSelf = (Button) findViewById(R.id.bt_scroll_self);llScroller = (LinearLayout) findViewById(R.id.ll_scroller);findViewById(R.id.bt_scroll_self).setOnClickListener(this);findViewById(R.id.bt_scroll_parent).setOnClickListener(this);initGestureTest();}private GestureDetector.OnGestureListener gestureListener = new GestureDetector.SimpleOnGestureListener() {@Overridepublic boolean onDown(MotionEvent e) {Log.i("tag", "onDown--");return true;}@Overridepublic void onShowPress(MotionEvent e) {Log.i("tag", "onPress--");return true;}@Overridepublic boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {Log.i("tag", "e1.getX=" + e1.getX() + ", e1.getY=" + e1.getY() + ", e2.getX=" + e2.getX() + ", e2.getY=" + e2.getY());viewParent.scrollTo((int) -e2.getX(), (int) -e2.getY());return true;}@Overridepublic void onLongPress(MotionEvent e) {Log.i("tag", "onLongPress--");return true;}@Overridepublic boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {Log.i("tag", "onFling e1.getX=" + e1.getX() + ", e2.getX=" + e2.getX() + ", vx=" + velocityX + ", vy=" + velocityY);viewParent.fling((int) -e2.getX(), (int) -e2.getY(), (int) -velocityX, (int) -velocityY);return true;}};private void initGestureTest() {viewParent = (MoveRelativeLayout) findViewById(R.id.rl_content);final GestureDetector gestureDet = new GestureDetector(this, gestureListener);viewParent.setOnTouchListener(new View.OnTouchListener() {@Overridepublic boolean onTouch(View v, MotionEvent event) {return gestureDet.onTouchEvent(event);}});moveView = findViewById(R.id.view_move);}int i;@Overridepublic void onClick(View v) {//注意view的scrollTo,scrollBy是view里面内容滑动switch (v.getId()) {case R.id.bt_scroll_self:if (i++ % 2 == 1) {buttonSelf.scrollTo(60, 0);} else {buttonSelf.scrollTo(0, 0);}break;case R.id.bt_scroll_parent:if (i++ % 2 == 1) {llScroller.scrollTo(60, 0);} else {llScroller.scrollTo(0, 0);}break;}}
}

MoveRelativeLayout.java

package com.tiandh.tdhtest01.view;import android.content.Context;
import android.os.Handler;
import android.util.AttributeSet;
import android.util.Log;
import android.widget.RelativeLayout;
import android.widget.Scroller;/*** Created by Administrator on 2017/5/15 0015.*/public class MoveRelativeLayout extends RelativeLayout {private Scroller scroller;private Handler mHander;public MoveRelativeLayout(Context context) {this(context, null);}public MoveRelativeLayout(Context context, AttributeSet attrs) {this(context, attrs, 0);}public MoveRelativeLayout(Context context, AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);scroller = new Scroller(context);mHander = new Handler();}public void fling( int startX, int startY, int velocityX, int velocityY  ) {scroller.fling(startX, startY, velocityX, velocityY, -getWidth(), getWidth(), -getHeight(), getHeight());startFling();}private void startFling() {Log.i("tag", "srcoller X="+getScrollX());if(scroller.computeScrollOffset()){scrollTo(scroller.getCurrX(), scroller.getCurrY());mHander.postDelayed(new Runnable() {@Overridepublic void run() {startFling();}}, 50);}}
}

activity_test_scroller.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/ll_scroller"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><Buttonandroid:id="@+id/bt_scroll_self"android:layout_width="180dp"android:layout_height="40dp"android:layout_marginLeft="40dp"android:layout_marginTop="40dp"android:text="滑动Button按钮" /><Buttonandroid:id="@+id/bt_scroll_parent"android:layout_width="180dp"android:layout_height="40dp"android:layout_marginLeft="40dp"android:text="滑动Layout按钮" /><com.tiandh.tdhtest01.view.MoveRelativeLayoutandroid:id="@+id/rl_content"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"android:background="#33333333"><Viewandroid:id="@+id/view_move"android:layout_width="30dp"android:layout_height="30dp"android:background="#aaff00" /></com.tiandh.tdhtest01.view.MoveRelativeLayout></LinearLayout>



这篇关于Touch事件--对GestureDetector的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/895333

相关文章

深入理解Apache Airflow 调度器(最新推荐)

《深入理解ApacheAirflow调度器(最新推荐)》ApacheAirflow调度器是数据管道管理系统的关键组件,负责编排dag中任务的执行,通过理解调度器的角色和工作方式,正确配置调度器,并... 目录什么是Airflow 调度器?Airflow 调度器工作机制配置Airflow调度器调优及优化建议最

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

Python中的异步:async 和 await以及操作中的事件循环、回调和异常

《Python中的异步:async和await以及操作中的事件循环、回调和异常》在现代编程中,异步操作在处理I/O密集型任务时,可以显著提高程序的性能和响应速度,Python提供了asyn... 目录引言什么是异步操作?python 中的异步编程基础async 和 await 关键字asyncio 模块理论

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝