ButterKnife之@OnTouch——界面交互效果进阶

12 篇文章 0 订阅
5 篇文章 0 订阅

前言

作为一个安卓开发,想必对ButterKnife 都不陌生,注解式搞定findviewbyid,搞定view绑定,再结合插件,简直好用到爆!然很少见到对@OnTouch注解具体使用的介绍,特此记录!

因由

由于公司开发需要优化交互效果,要对onClick和OnTouch都要有所响应,如果单个处理代码太乱,而butterKnife的插件可以自动生成@OnClick 注解将点击事件集中处理,而@OnTouch却没有,为了便于维护,多方探索之下终于将之搞定

效果

width="240" height="427" src="http://ovddupnnd.bkt.clouddn.com/device-2017-11-04-162828.mp4?autoPlay=true">

实现

  @OnClick({R.id.tv_back, R.id.Rl_my_info, R.id.ll_my_order, R.id.ll_my_wallet, R.id.ll_my_coupon, R.id.ll_my_massage, R.id.ll_about, R.id.ll_explain})
    public void onViewClicked(View view) {
        AnimUtils.clickAnimator(view);
        switch (view.getId()) {
            case R.id.tv_back:finish();
                break;
            case R.id.Rl_my_info:toast("我的资料");
                break;
            case R.id.ll_my_order:toast("订单");
                break;
            case R.id.ll_my_wallet:toast("钱包");
                break;
            case R.id.ll_my_coupon:toast("优惠券");
                break;
            case R.id.ll_my_massage:toast("消息");
                break;
            case R.id.ll_about:toast("关于");
                break;
            case R.id.ll_explain:toast("说明");
                break;
        }
    }
    @OnTouch({R.id.tv_back, R.id.Rl_my_info, R.id.ll_my_order, R.id.ll_my_wallet, R.id.ll_my_coupon, R.id.ll_my_massage, R.id.ll_about, R.id.ll_explain})
    public boolean onTouch(View v, MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN: //手指按下
                AnimUtils.touchDownAnimator(v);
                break;
            case MotionEvent.ACTION_MOVE: //手指移动(从手指按下到抬起 move多次执行)
                break;
            case MotionEvent.ACTION_UP: //手指抬起
                AnimUtils.touchUpAnimator(v);
                break;
        }
        return false;
    }

支持

![mm_facetoface_collect_qrcode_1509065133221](C:\Users\feisher\Documents\Tencent Files\458079442\FileRecv\MobileFile\mm_facetoface_collect_qrcode_1509065133221.png)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值