Android自定義View實現(xiàn)拖拽效果
騰訊QQ有那種紅點拖動效果,今天就來實現(xiàn)一個簡單的自定義View拖動效果,再回到原處,并非完全仿QQ紅點拖動。
先來看一下效果圖

簡單說一下實現(xiàn)步驟
1.創(chuàng)建一個類繼承View
2.繪制出一個小球
3.重寫onTouchEvent,來根據(jù)手指放下,移動,抬起,來控制小球
4.直接在布局中引用
先貼一張圖看下View的坐標系

下面就貼一下代碼,最后會給出源碼
public class CustomView extends View {
private int lastX;
private int lastY;
private int startLeft;
private int startRight;
private int startTop;
private int startBottom;
public CustomView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
//畫一個小球
Paint paint = new Paint();
paint.setStrokeWidth(30);
paint.setColor(Color.parseColor("#FF0000"));
paint.setAntiAlias(true);
paint.setStyle(Paint.Style.FILL_AND_STROKE);
canvas.drawCircle(getWidth()/2,getHeight()/2,30,paint);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
int action = event.getAction();
//獲取手機觸摸的坐標
int x = (int) event.getX();
int y = (int) event.getY();
switch (action){
case MotionEvent.ACTION_DOWN://按下,獲取小球初始的位置
startLeft = getLeft();
startRight = getRight();
startTop = getTop();
startBottom = getBottom();
lastX = x;
lastY = y;
break;
case MotionEvent.ACTION_MOVE://移動,小球跟隨手指的移動
int offsetX = x - lastX;
int offsetY = y - lastY;
layout(getLeft()+offsetX,getTop()+offsetY,
getRight()+offsetX,getBottom()+offsetY);
break;
case MotionEvent.ACTION_UP://當手指抬起時,回到小球初始的位置
layout(startLeft, startTop, startRight, startBottom);
break;
}
return true;
}
}
直接在布局中引用該自定義View就可以,寬高給固定
源碼地址:Android自定義View簡單拖拽效果
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android組件之DrawerLayout實現(xiàn)抽屜菜單
DrawerLayout組件同樣是V4包中的組件,也是直接繼承于ViewGroup類,所以這個類也是一個容器類。接下來通過本文給大家介紹Android組件之DrawerLayout實現(xiàn)抽屜菜單,感興趣的朋友一起學習吧2016-02-02
android中實現(xiàn)指針滑動的動態(tài)效果方法
本次實現(xiàn)的是類似于墨跡天氣中軌跡圖片上指針隨著數(shù)值滾動滑動的效果,基本思路是開啟線程,控制指針所在的imageview控件的padding屬性。2013-03-03
Android Studio 配置:自定義頭部代碼注釋及添加模版方式
這篇文章主要介紹了Android Studio 配置:自定義頭部代碼注釋及添加模版方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03

