Android单击、多击事件、定时器

PART A:单击事件

一、

  1. 当前类实现View.onClickListener接口,覆写接口下的onClick()方法

  2. 在onCreate()中对指定控件设置点击监听并传入参数this

  3. 在onCLick()中使用switch-case语句来对相应控件实现点击事件的具体逻辑

    public class ClickActivity extends AppCompatActivity implements View.OnClickListener {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_click);
    
            findViewById(R.id.bt_click_event).setOnClickListener(this);
        }
    
        @Override
        public void onClick(View v) {
            switch (v.getId()) {
                case R.id.bt_click_event:
                    Toast.makeText(this, "点击事件的实现", Toast.LENGTH_SHORT).show();
                    break;
            }
        }
    }
    

二、

  1. 在onCreate()中对控件设置点击监听并传入一个View.onClickListener实例
    PS(本篇为方便使用匿名内部类,也可以自定义类继承onClickListener,覆写onClick()方法)

  2. 在onCLick()中使用switch-case语句来对相应控件实现点击事件的具体逻辑

    public class ClickActivity extends AppCompatActivity {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_click);
    
            findViewById(R.id.bt_click_event).setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    switch (v.getId()) {
                        case R.id.bt_click_event:
                            Toast.makeText(getApplicationContext(), "点击事件的实现", Toast.LENGTH_SHORT).show();
                            break;
                    }
                }
            });
        }
    }
    

三、

1.在布局文件中对控件设置onClick属性android:onClick="clickEvent"

<Button
        android:id="@+id/bt_click_event"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="clickEvent"
        android:text="点击事件"
        android:textSize="22sp" />

2.在Activity中实现public void clickEvent (View v)方法

  • 注意:必须声明为public,返回类型固定void,必须传入View实例(组件触发对象)

    public class ClickActivity extends AppCompatActivity {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_click);
        }
    
        public void clickEvent(View v) {
            Toast.makeText(this, "点击事件的实现", Toast.LENGTH_SHORT).show();
        }
    }
    

四、利用IOC注解(本篇使用ButterKnife)

public class ClickActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_click);
        ButterKnife.bind(this);
    }

    // 使用@onClick注解(可以省略方法声明public、传入的View组件对象)
    @OnClick(R.id.bt_click_event) 
    void clickEvent() {
        Toast.makeText(this, "点击事件的实现", Toast.LENGTH_SHORT).show();
    }
}

PART B:多击事件

  • 普通双击事件(不建议使用)

    long firstClickTime = 0;
    
    public void clicks(int intervalTime){ // 最长间隔时间			
    	if(firstClickTime > 0){
    		if(System.currentTimeMillis() - firstClickTime < intervalTime){
    			System.out.println("双击事件");
    			firstClickTime = 0; // 将第一次点击时间置为0
    		}
    	}
    		
    	firstClickTime = System.currentTimeMillis();
    }
    
  • 标准双击、多击事件(推荐使用)

    /**
     * 在intervalTime(ms)时间内点击了clickTimes次,就执行TODO逻辑
     */
    public void clicks(long intervalTime, int clickTimes) {
    	long[] mArrs = new long[clickTimes];
    	
    	//src    源数组
    	//srcPos 源数组的开始拷贝位置
    	//dst    目标数组
    	//dstPos 目标数组的开始拷贝位置
    	//length 数组的拷贝长度
    	System.arraycopy(mArrs, 1, mArrs, 0, mArrs.length - 1); //拷贝数组
    	mArrs[mArrs.length - 1] = SystemClock.uptimeMillis();
    	if (mArrs[0] >= (SystemClock.uptimeMillis() - intervalTime)) {
    		Log.d("clickEvent", "clickTimes次点击事件已发生,开始执行TODO");
    		// TODO
    	}
    }
    

PART C:定时器

![这里写图片描述](https://img-blog.csdnimg.cn/img_convert/7f2543eeee9f90fcd5ac748ade27dfd7.png)
  1. 直接分析构造方法,基本就直接会用了

    • schedule 与 scheduleAtFixedRate 的区别

      • **schedule:**后续任务的执行起点时间会在上一任务执行完成后开始执行。比如第一个任务从第1秒后开始执行3秒,但3秒后任务为完成,拖到第5秒才完成,那第二个任务就会在第5秒开始执行

      • **scheduleAtFixedRate :**后续任务会按照参数写好的时间来计算自己的开始执行时间。比如第一个任务从第1秒后开始执行3秒,但3秒后任务为完成,拖到第5秒才完成,那第二个任务会直接在第4秒开始执行,会导致并发

    • 典型:schedule(TimerTask task, long delay, long period)

      • **task:**计划表中要执行的任务

      • **delay:**多少ms后开始任务

      • **period:**每多少秒执行一次任务

  2. 简单案例:在1秒后开始任务,每3秒就执行一次TODO

    new Timer().schedule(new TimerTask() {
        @Override
        public void run() {
            // TODO
        }
    }, 1000, 3000);
    

    其中TimerTask包含的方法如下
    这里写图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值