Android自定義View實現(xiàn)自動吸附功能
更新時間:2020年01月18日 16:15:46 投稿:lijiao
這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)自動吸附功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Android實現(xiàn)自動吸附功能的具體代碼,供大家參考,具體內容如下
1.簡述
最近開發(fā)app過程中要實現(xiàn)拖動view后要可以自動吸附功能,所以需要自定義view來在onTouchEvent中來利用動畫來實現(xiàn)此功能
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 Kotlin開發(fā)實例(Hello World!)及語法詳解
這篇文章主要介紹了Android Kotlin開發(fā)實例及語法詳解的相關資料,需要的朋友可以參考下2017-05-05
教你制作Android中炫酷的ViewPagerIndicator(不僅仿MIUI)
ViewPagerIndicator作為一款分頁指標小部件兼容ViewPager,封裝上做得非常不錯,目前已為眾多知名應用所使用。今天給你大家分享一個炫酷的效果,有需要的可以參考學習。2016-08-08

