成都网站建设设计

将想法与焦点和您一起共享

Android中怎么通过自定义View实现自动吸附功能

Android中怎么通过自定义View实现自动吸附功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

专注于为中小企业提供成都网站设计、成都网站制作、外贸网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业虎林免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了1000+企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

1.简述

最近开发app过程中要实现拖动view后要可以自动吸附功能,所以需要自定义view来在onTouchEvent中来利用动画来实现此功能

2.功能代码部分

import android.content.Context;import android.graphics.Canvas;import android.util.AttributeSet;import android.util.Log;import android.view.MotionEvent;import android.view.animation.DecelerateInterpolator;import android.widget.ImageView;public class AdsorbentViews extends ImageView {  private int maxWidth;  private int maxHeight;  private int viewWidth;  private int viewHeight;  private float downx;  private float downy;  private Context mContext;  public CustomViews(Context context) {    this(context, null);  }   public CustomViews(Context context, AttributeSet attrs) {    this(context, attrs, 0);  }   public CustomViews(Context context, AttributeSet attrs, int defStyleAttr) {    super(context, attrs, defStyleAttr);    mContext = context;  }  @Override  protected void onDraw(Canvas canvas) {    super.onDraw(canvas);    DisplayMetrics outMetrics = new DisplayMetrics();    WindowManager windowManager = (WindowManager) mContext.getSystemService(Context.WINDOW_SERVICE);    windowManager.getDefaultDisplay().getRealMetrics(outMetrics);    //屏幕的宽度    maxWidth = outMetrics.widthPixels;    //屏幕的高度    maxHeight = outMetrics.heightPixels;    /**     * 控件的宽高     */    viewWidth = canvas.getWidth();    viewHeight = canvas.getHeight();  }  @Override  public boolean onTouchEvent(MotionEvent event) {    switch (event.getAction()) {      case MotionEvent.ACTION_DOWN:        clearAnimation();        downx = event.getX();        downy = event.getY();        return true;      case MotionEvent.ACTION_MOVE:        float moveX = event.getRawX() - downx;        float moveY = event.getRawY() - downy;        moveX = moveX < 0 ? 0 : (moveX + viewWidth > maxWidth) ? (maxWidth - viewWidth) : moveX;        moveY = moveY < 0 ? 0 : (moveY + viewHeight) > maxHeight ? (maxHeight - viewHeight) : moveY;        this.setY(moveY);        this.setX(moveX);        return true;      case MotionEvent.ACTION_UP:        //做吸附效果        float centerX = getX() + viewWidth / 2;        if (centerX > maxWidth/2){          //靠右吸附          animate().setInterpolator(new DecelerateInterpolator())              .setDuration(500)              .x(maxWidth-viewWidth)              .y(maxHeight-viewHeight)              .start();        }else {          animate().setInterpolator(new DecelerateInterpolator())              .setDuration(500)              .x(0)              .y(maxHeight-viewHeight)              .start();        }        return true;      default:        return super.onTouchEvent(event);    }  }}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


网站标题:Android中怎么通过自定义View实现自动吸附功能
链接分享:http://chengdu.cdxwcx.cn/article/ijdsos.html