Android OnTouchEvent, onClick, onLongClick调用机制

在Android开发中,我们经常会对一个View设置onClick,onLongClick,onTouch事件,有时还会同时设置这三个事件,那么在同时设置这三个时候,执行顺序是什么样呢?

首先,官方文档上面对onLongClick()和onTouch()的描述如下:

onLongClick() - This returns a boolean to indicate whether you have consumed the event and it should not be carried further. That is, return true to indicate that you have handled the event and it should stop here; return false if you have not handled it and/or the event should continue to any other on-click listeners.

大致意思就是:onLongClick()方法会返回一个boolean值,如果是true,表示已经处理了此事件,不需要继续传递;如果是false,表示没有处理,事件会继续到其他的监听事件。

onTouch() - This returns a boolean to indicate whether your listener consumes this event. The important thing is that this event can have multiple actions that follow each other. So, if you return false when the down action event is received, you indicate that you have not consumed the event and are also not interested in subsequent actions from this event. Thus, you will not be called for any other actions within the event, such as a finger gesture, or the eventual up action event.

大致意思是:onTouch()方法,会包含多个行为,ACITON_DOWN,ACTION_MOVE,ACTION_UP。如果返回值时true,就表示会处理这个事件,就不会再调用onClick或者onLongClick,如果返回false,则会继续调用onLongClick。

写个简单的测试程序:

package com.qwei.demo;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnLongClickListener;
import android.view.View.OnTouchListener;
import android.widget.TextView;

public class MainActivity extends Activity
{
    private final static String TAG = MainActivity.class.getName();
	private TextView clickMe,showLog;
    private String log;
    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        clickMe = (TextView) findViewById(R.id.click_me);
        showLog = (TextView) findViewById(R.id.show_log);

        clickMe.setOnLongClickListener(new OnLongClickListener() {  

			@Override
			public boolean onLongClick(View arg0) {
				// TODO Auto-generated method stub
				 Log.d("TAG", "onLongClick is called.............");
	                log = log +"onLongClick is called.............\n";
	                showLog.setText(log);
				return false;
			}
        });
        clickMe.setOnClickListener(new OnClickListener() {  

            @Override
            public void onClick(View v) {
                Log.d("TAG", "onClick is called.............");
                log = log +"onClick is called.............\n";
                showLog.setText(log);
            }
        }); 

        clickMe.setOnTouchListener(new OnTouchListener() {  

            @Override
            public boolean onTouch(View arg0, MotionEvent arg1) {
                //Log.d("TAG", "onTouch is called.............");
                switch (arg1.getAction()) {
                case MotionEvent.ACTION_DOWN:
                    Log.d("TAG", "ACTION_DOWN.............");
                    log = log +"oACTION_DOWN............\n";
                    showLog.setText(log);
                    break;
                case MotionEvent.ACTION_MOVE:
                    Log.d("TAG", "ACTION_MOVE.............");
                    log = log +"ACTION_MOVE.............\n";
                    showLog.setText(log);
                    break;
                case MotionEvent.ACTION_CANCEL:
                    Log.d("TAG", "ACTION_CANCEL.............");
                    log = log +"ACTION_CANCEL............\n";
                    showLog.setText(log);
                    break;
                case MotionEvent.ACTION_UP:
                    Log.d("TAG", "ACTION_UP.............");
                    log = log +"ACTION_UP............\n";
                    showLog.setText(log);
                    break;
                default:
                    break;
                }
                return false;
            }
        });
    }
}

当onTouch返回false,onLongClick也返回false,长按view时,会调用onTouch,一段时间之后调用onLongClick,抬起手指的时候调用onClick,如下图所示:

<img src="http://img.blog.csdn.net/20150510163553660?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVsbG8wMzcw/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" width="423" height="641" alt="" />

当onTouch返回false,onLongClick也返回true,长按view时,会调用onTouch,一段时间之后调用onLongClick,抬起手指的时候不会调用onClick,如下图:


当onTouch返回true,长按view时,会调用onTouch,onLongClick和onClick都不会被调用,如下图:

时间: 2024-10-10 20:49:37

Android OnTouchEvent, onClick, onLongClick调用机制的相关文章

Android View 按键事件分发流程 onTouch onTouchEvent onClick onLongClick 和 onKey onKeyDown onClick

1.为了测试,我们同时将View 设置 onTouch  onTouchEvent  onClick onLongClick 四个事件,经过加打印测试发现,按键分发流程是这样的 如果是短按:onTouch-->>onTouchEvent--->>onClick .长按:onTouch-->>onTouchEvent--->>onLongClick-->>onClick.为什么会是这样? 我们看View 源码 public boolean disp

Android onTouchEvent, onClick及onLongClick的调用机制

针对屏幕上的一个View控件,Android如何区分应当触发onTouchEvent,还是onClick,亦或是onLongClick事件? 在Android中,一次用户操作可以被不同的View按次序分别处理,并将完全响应了用户一次UI操作称之为消费了该事件(consume),那么Android是按什么次序将事件传递的呢?又在什么情况下判定为消费了该事件? 搞清楚这些问题对于编写出能正确响应UI操作的代码是很重要的,尤其当屏幕上的不同View需要针对此次UI操作做出各种不同响应的时候更是如此,一

onTouchEvent,onClick,onLongClick的return值和事件响应顺序

其实你只要理解了事件处理机制,知道true和false在其中起着标志事件是否被消耗,如果消耗了就不再传递给其他控件了. 如果没有消耗则还会传递给其他控件,触发其他控件的事件处理函数.使用的时候注意下就是了. 给一个button同时添加这三种事件,onTouchEvent的action_down是最先触发的, 如果返回true,则表示action_down事件已经被消耗,本次点击(长按或点击)不会再响应其他的事件 if (event.getAction() == MotionEvent.ACTIO

Android系统篇之----Binder机制和远程服务调用机制分析

一.前景概要 最近要实现Android中免注册Activity就可以运行的问题,那么结果是搞定了,就是可以不用在AndroidManifest.xml中声明这个Activity即可运行,主要是通过骗取系统,偷龙转凤技术的,这个知识点后面会详细讲解的,因为在研究了这个问题过程中遇到了很多知识点,当然最重要也是最根本的就是Android中的Binder机制和远程服务调用机制,而关于Binder机制的话,在Android中算是一个非常大的系统架构模块了,光这篇文章是肯定不能讲解到全部的,而且本人也不是

android内核剖析系列---JNI调用机制分析

为什么需要JNI? android这个庞大的系统从下到上主要由linux内核,C/C++库,java应用程序框架,java应用程序组成.这就涉及到一个问题,C/C++库如何与java应用有交集,或者说能相互调用,要解决这个问题,就需要JNI登场了. JNI调用机制分析 JNI--java native interface,翻译成中文是java本地接口,所谓的"本地"是指C/C++库一层的C/C++语言(以下统称C).

Android系统篇之----解读AMS远端服务调用机制以及Activity的启动流程

一.为何本文不介绍Hook系统的AMS服务 在之前一篇文章中已经讲解了 Android中Hook系统服务,以及拦截具体方法的功能了,按照流程本文应该介绍如何Hook系统的AMS服务拦截应用的启动流程操作,但是本文并不会,因为在介绍这个知识点之前,还有一件大事要做,那就是得先分析一下Android中应用的启动流程,如果这个流程不搞清楚的话,后面没办法Hook的,因为你都找不到Hook点,当然Hook代理对象倒是很容易获得,如果没有Hook点,是没办法后续的操作的,所以得先把流程分析清楚了,当然现在

Android开发之触摸事件处理机制详解

android触碰消息传递机制 用户的每次触碰(onClick,onLongClick,onScroll,etc.)都是由一个ACTION_DOWN+n个ACTION_MOVE+1个ACTION_UP组成的,用户触碰必先有个ACTION_DOWN响应,用户触碰结束必然会有个ACTION_UP.(当然如果在途中被拦截,就可能不会有了!)那么View是如何分发消息和拦截消息呢? 1.View及其子类都会有的两个方法: public boolean dispatchTouchEvent(MotionE

Android中的事件分发机制(下)——View的事件处理

综述 在上篇文章Android中的事件分发机制(上)--ViewGroup的事件分发中,对ViewGroup的事件分发进行了详细的分析.在文章的最后ViewGroup的dispatchTouchEvent方法调用dispatchTransformedTouchEvent方法成功将事件传递给ViewGroup的子View.并交由子View进行处理.那么现在就来分析一下子View接收到事件以后是如何处理的. View的事件处理 对于这里描述的View,它是ViewGroup的父类,并不包含任何的子元

Android ViewGroup 触摸事件传递机制

引言 上一篇博客我们学习了Android View 触摸事件传递机制,不了解的同学可以查看Android View 触摸事件传递机制.今天继续学习Android触摸事件传递机制,这篇博客将和大家一起探讨ViewGroup的触摸事件传递机制. 示例 示例代码如下: public class MainActivity extends ActionBarActivity { private String TAG = "MainActivity"; private MyViewGroup pa