美文网首页
ButterKnife之@OnTouch——界面交互效果进阶

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

作者: feisher | 来源:发表于2017-11-04 17:24 被阅读0次

    前言

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

    因由

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

    效果

    mark

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

    视频可能播放不出来,那就gif将就看吧

    实现

      @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;
        }
    

    支持

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

    相关文章

      网友评论

          本文标题:ButterKnife之@OnTouch——界面交互效果进阶

          本文链接:https://www.haomeiwen.com/subject/bjtqmxtx.html