Android应用开发-- 如何在页面切换的过程中屏蔽屏幕事件?

本文介绍了一种简单有效的方法,用于防止用户在页面动画未完成时重复点击触发页面跳转,通过记录并比较时间间隔实现对触摸屏事件连续响应的限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    今天客户反馈要求在 页面跳转动画没有完成时,应当屏蔽屏幕触摸事件?  这样可以防止用户的恶意的连续性操作。

     因为在项目中运用了动画效果来做页面之间的跳转。

     举例说明:

        PageA --> PageB  use  'push_left_in' ,'push_left_out'  animation

        PageB--> PageA  use  'push_right_in' ,'push_right_out'  animation

        PageA--> PageC  use 3d rotation

       这三个页面的右下角都有一个按钮来触发,页面跳转事件,但是当用户在PageB页面连续点击多下 button,此时的效果是:先慢慢从pageB 转换到 pageA ,然后再3d 旋转到paceC.

       显然,后一个跳转是没有必要的。

       所以就有必要对 这种情况进行有效地处理。一开始就想着“ 如何去屏蔽屏幕触摸事件 ?”,”如何去重新设置动画效果? “,结果一直找不到好的解决方案。

      今天终于找对了关键词,换一种角度去思考,结果原来很简单就能解决问题。

       key word ---如何限制触摸屏事件连续响应

      solution: 在动画开始的时候,记住一个时间,在响应点击事件的时候,要检查一下,当前时间与保存的时候差值有没有超过1秒,如果超过,可以认为是一次有效的操作

       代码如下:

  @Override
    public void onClick(View v) {     
        if(LimitLRForLTUtil.IsNormalOperation()){
            System.out.println("Normally operation.... ");
            startActivityForResult(IntentHelperUtil.getInstance().getIntent(ProblemDetailActivity.this, HomeActivity.class),0);
            overridePendingTransition(R.anim.push_right_in,R.anim.push_right_out);
        }else{
            System.out.println(".... Should be disregarded ");
        }
        super.onClick(v);
    }

 

 /**
 *  be used to limit continuous response for continuous touch screen event
 * @file LimitLRForLT.java
 * @author Samuel.Cai
 * @date Sep 28, 2011
 */
public class LimitLRForLTUtil {
    private static long oldTime;

    public static long INTERVALTIMEOFANIMATION = 1000;
    
    public static void setOldTime(long time){
        oldTime = time;
    }
    
    public static  boolean IsNormalOperation(){
        // the interval time between animations is 1000
        if((System.currentTimeMillis() - oldTime) < INTERVALTIMEOFANIMATION ){
            return false;
        }
        oldTime = System.currentTimeMillis();
        return true;
    }
}


     



      



  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值