三次点击事件的原理图:数组的复制(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. Your branch is ahead of 'origin/master' by 21 commits.

    当切换到主分支后,准备 git pull 拉取远程 master 分支时,提示本地主分支显示有 21 个commits 问题原因: 因为你修改了 local master 本地的主分支,可以选择以下方 ...

  2. Github新手使用学习详解

    Github新手使用学习详解 (一)git的使用学习 首先下载git bash,安装一路默认选择即可. 安装好后第一步,获取ssh key,即属于自己的密钥: 打开Git bash后输入以下代码: $ ...

  3. [oldboy-django][2深入django]cookies + session

    1.1 cookies - 初识cookie a.cookie是保留在浏览器端的键值对 b.服务端可以向客户端写cookie c.客户端每次发送请求,会携带cookie一起发送过去,而且cookie是 ...

  4. 深入学习之mysql(二)表的操作

    1.表:是数据库中的存储数据的基本单位,一个表包含若干个字段和值 2.创建表: CREATE TABLE 表名称 ( 字段名1 数据库类型1 [约束条件1], 字段名2 数据库类型2 [约束条件2], ...

  5. ms sqlserver数据库主文件特别大怎么办

    因为项目中需要复制数据库,作为外网测试的数据库,但是数据库特别大,复制特别费劲,即使只复制主文件,主文件也特别大. 然后百度了下,发现数据库有个收缩功能,数据库右键——任务——收缩,可以对数据库进行收 ...

  6. mybatis maven 代码生成器(mysql)

    pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns="htt ...

  7. SolrCloud在linux上的搭建

    SolrCloud在linux上的搭建 1.环境准备 三台虚拟机的环境准备: 1. 更改主机名 2. 关闭selinux 3. 关闭防火墙 4. 更改主机名与ip地址的映射 5. 时钟同步 6. ss ...

  8. 基于深度摄像头的障碍物检测(realsense+opencv)

    前几天老大给了个任务,让我帮slam组写一个基于深度摄像头的障碍物检测,捣鼓了两天弄出来了,效果还不错,就在这里记一下了. 代码的核心思路是首先通过二值化,将一米之外的安全距离置零不考虑,然后通过开运 ...

  9. swarm集群数据管理

    1.volume [root@manager ~]# docker service create --mount type=volume,src=vol1,dst=/usr/local/nginx/h ...

  10. openssl Rsa 分段加密解密

    密钥长度 1024 openssl genrsa -out rsa_private_key.pem openssl rsa -in rsa_private_key.pem -pubout -out r ...