三次点击事件的原理图:数组的复制(android源码的调用):

下面就是第一步:

创建long数组,里面的数字代表点击的次数。
下面是主要代码实现:

system.arraycopy();里面的参数描述:

 
最后就是在if里面实现你想要的按钮的点击逻辑,不过最后一点很重要,当按钮还有触摸的点击事件的时候,有一点:

一定记得返回false;
下面贴出我的源码:tv_drag实现双击居中方法(里面有触摸事件):
 
 
package com.example.mobilesafe74.activity;
 
import com.example.mobilesafe74.R;
import com.example.mobilesafe74.utils.ConstantValue;
import com.example.mobilesafe74.utils.SpUtil;
 
import android.app.Activity;
import android.os.Bundle;
import android.os.SystemClock;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.RelativeLayout.LayoutParams;
 
public class ToastLocationActivity extends Activity {
 private ImageView tv_drag;
 private Button bt_top;
 private Button bt_bottom;
 private WindowManager mWm;
 private int mScreenwidth;
 private int mScreenheight;
 private long[] mhits = new long[2];
 
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  // TODO Auto-generated method stub
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_toast_location);
  initUI();
 }
 
 private void initUI() {
  // 当前可以拖拽的图片控件
  tv_drag = (ImageView) findViewById(R.id.tv_drag);
  bt_top = (Button) findViewById(R.id.bt_top);
  bt_bottom = (Button) findViewById(R.id.bt_bottom);
  mWm = (WindowManager) getSystemService(WINDOW_SERVICE);
  mScreenwidth = mWm.getDefaultDisplay().getWidth();
  mScreenheight = mWm.getDefaultDisplay().getHeight();
 
  int locationX = SpUtil.getInt(getApplicationContext(),
    ConstantValue.LOCATION_X, 0);
  int locationY = SpUtil.getInt(getApplicationContext(),
    ConstantValue.LOCATION_Y, 0);
 
  // 左上坐标作用在控件上面
  // 指定宽高都是w w
  LayoutParams LayoutParams = new RelativeLayout.LayoutParams(
    RelativeLayout.LayoutParams.WRAP_CONTENT,
    RelativeLayout.LayoutParams.WRAP_CONTENT);
  LayoutParams.leftMargin = locationX;
  LayoutParams.topMargin = locationY;
  if (LayoutParams.topMargin > mScreenheight / 2) {
   bt_bottom.setVisibility(View.INVISIBLE);
   bt_top.setVisibility(View.VISIBLE);
 
  } else {
   bt_bottom.setVisibility(View.VISIBLE);
   bt_top.setVisibility(View.INVISIBLE);
 
  }
  // 将以上规则作用在控件上面
  tv_drag.setLayoutParams(LayoutParams);
  tv_drag.setOnClickListener(new OnClickListener() {
 
   @Override
   public void onClick(View arg0) {
    System.arraycopy(mhits, 1, mhits, 0, mhits.length - 1);
    mhits[mhits.length - 1] = SystemClock.uptimeMillis();
    if (mhits[mhits.length - 1] - mhits[0] < 500) {
     // 满足双击事件后,居中
     int left = mScreenwidth / 2 - tv_drag.getWidth() / 2;
     int right = mScreenheight / 2 - tv_drag.getHeight() / 2;
     int top = mScreenwidth / 2 + tv_drag.getWidth() / 2;
     int bottom = mScreenheight / 2 + tv_drag.getHeight() / 2;
 
     // 显示出来
     tv_drag.layout(left, top, right, bottom);
 
    }
 
   }
  });
 
  // 可以拖拽的点击事件
  tv_drag.setOnTouchListener(new OnTouchListener() {
 
   private int startX;
   private int startY;
 
   @Override
   public boolean onTouch(View v, MotionEvent event) {
    switch (event.getAction()) {
    case MotionEvent.ACTION_DOWN:// 按下
     // 初始位置的坐标
     startX = (int) event.getRawX();
     startY = (int) event.getRawY();
 
     break;
    case MotionEvent.ACTION_MOVE:// 移动
     int moveX = (int) event.getRawX();
     int moveY = (int) event.getRawY();
 
     int disX = moveX - startX;
     int disY = moveY - startY;
 
     // 当前控件的上下左右的坐标
     int left = tv_drag.getLeft() + disX;
     int top = tv_drag.getTop() + disY;
     int right = tv_drag.getRight() + disX;
     int bottom = tv_drag.getBottom() + disY;
     // 容错处理
     if (left < 0) {
      return true;
     }
 
     if (right > mScreenwidth) {
      return true;
     }
 
     if (top < 0) {
      return true;
     }
 
     if (bottom > mScreenheight - 22) {
      return true;
     }
     if (top > mScreenheight / 2) {
      bt_bottom.setVisibility(View.INVISIBLE);
      bt_top.setVisibility(View.VISIBLE);
 
     } else {
      bt_bottom.setVisibility(View.VISIBLE);
      bt_top.setVisibility(View.INVISIBLE);
 
     }
 
     // 告知控件,按计算的坐标去展示
 
     tv_drag.layout(left, top, right, bottom);
     // 重置坐标
     startX = (int) event.getRawX();
     startY = (int) event.getRawY();
 
     break;
    case MotionEvent.ACTION_UP:// 抬起
     // 记录位置坐标
     SpUtil.putInt(getApplicationContext(),
       ConstantValue.LOCATION_X, tv_drag.getLeft());
     SpUtil.putInt(getApplicationContext(),
       ConstantValue.LOCATION_Y, tv_drag.getTop());
 
     break;
    }
    // 返回事件,只有触摸操作的时候用true,有点击事件记得加上return false
    return false;
   }
  });
 }
}
 
 

android的多次点击事件的实现(有源码)的更多相关文章

  1. Android Button四种点击事件和长按事件

    项目XML代码 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:andr ...

  2. 查找和定位Android应用的按钮点击事件的代码位置基于Xposed Hook实现

    本文博客地址:https://blog.csdn.net/QQ1084283172/article/details/80956455 在进行Android程序的逆向分析的时候,经常需要通过Androi ...

  3. Android学习---ListView的点击事件,simpleAdapter和arrayadapter,SimpleCursoAdapter的原理和使用

    如题,本文将介绍 listview的点击事件,simpleAdapter和arrayadapter的原理和使用. 1.ListView的注册点击事件 //注册点击事件 personListView.s ...

  4. android 入门 003 (点击事件)

    点击事件 有四种实现方式. 1.内部类实现方式 1.0 package cn.rfvip.clickevent; import android.app.Activity; import android ...

  5. Android 给TextView添加点击事件

    首先设定TextView的clickable属性为true. 可以在布局文件中进行设定,比如: <TextView android:id="@+id/phone" andro ...

  6. Android ListView中Item点击事件失效解决方案

    欢迎关注公众号,每天推送Android技术文章,二维码如下:(可扫描) 在平常的开发过程中,我们的ListView可能不只是简单的显示下文本或者按钮,更多的是显示复杂的布局,这样的话,我们就得自己写布 ...

  7. Android 自定义View——自定义点击事件

    每个人手机上都有通讯录,这是毫无疑问的,我们通讯录上有一个控件,在通讯录的最左边有一列从”#”到”Z”的字母,我们通过滑动或点击指定的字母来确定联系人的位置,进而找到联系人.我们这一节就通过开发这个控 ...

  8. Android 7.0 TextView点击事件无效修复方案

    public class PostTextView extends TextView { private Handler handler = new Handler(Looper.getMainLoo ...

  9. 关于Android避免按钮重复点击事件

    最近测试人员测试我们的APP的时候,喜欢快速点击某个按钮,出现一个页面出现多次,测试人员能不能禁止这样.我自己点击了几下,确实存在这个问题,也感觉用户体验不太好.于是乎后来我搜了下加一个方法放在我们U ...

随机推荐

  1. linux学习(一) -- ubuntu下lamp环境的配置

    以下为实测教程,希望能为大家提供帮助,转载请注明出处 ubuntu+apache+mysql+php7 第一.更换apt的源 1.复制原文件备份 sudo cp /etc/apt/source.lis ...

  2. Python框架之Django学习笔记(八)

    模板继承 到目前为止,我们的模板范例都只是些零星的 HTML 片段,但在实际应用中,你将用 Django 模板系统来创建整个 HTML 页面. 这就带来一个常见的 Web 开发问题: 在整个网站中,如 ...

  3. CSU-2019 Fleecing the Raffle

    CSU-2019 Fleecing the Raffle Description A tremendously exciting raffle is being held, with some tre ...

  4. Leetcode 611.有效三角形的个数

    有效三角形的个数 给定一个包含非负整数的数组,你的任务是统计其中可以组成三角形三条边的三元组个数. 示例 1: 输入: [2,2,3,4] 输出: 3 解释: 有效的组合是: 2,3,4 (使用第一个 ...

  5. ReentrantLock学习笔记

    参考:https://www.jianshu.com/p/4358b1466ec9 前言: 先来想象一个场景:手把手的进行锁获取和释放,先获得锁A,然后再获取锁B,当获取锁B后释放锁A同时获取锁C,当 ...

  6. hihoCoder 1133 二分·二分查找之k小数(TOP K算法)

    #1133 : 二分·二分查找之k小数 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在上一回里我们知道Nettle在玩<艦これ>,Nettle的镇守府有很 ...

  7. THUSC2018 爆零记

    没想到我还真能过这个...... 太玄学了= = 不过这直接导致我月考数学挂科,掉出年级前十= = 5.26 THU过了! 真是十分意外的惊喜啊$-\omega-$ 6.1 今天出发去帝都! 然而飞行 ...

  8. 四则运算出题系统,java

    程序设计思想: 首先通过判断选择计算的范围,然后用随机数生成两个随机数,定义另一个数,将两个随机数计算得到的值赋给定义的数 程序代码: package Kaos1; import java.util. ...

  9. 理解exports

    webpack-nodejs-模块系统 其实,Module.exports才是真正的接口,exports只不过是它的一个辅助工具. 最终返回给调用的是Module.exports而不是exports. ...

  10. 汽车加油行驶(cogs 737)

    «问题描述:给定一个N*N 的方形网格,设其左上角为起点◎,坐标为(1,1),X 轴向右为正,Y轴向下为正,每个方格边长为1,如图所示.一辆汽车从起点◎出发驶向右下角终点▲,其坐标为(N,N).在若干 ...