Android可拖动的ImageView

本文介绍了一种简单实现可拖动ImageView的方法。通过重写onTouchEvent方法并处理不同触摸事件,实现了图片视图的拖动功能。适用于Android平台。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//简单实现可拖动的ImageView
import android.annotation.TargetApi;
import android.content.Context;
import android.os.Build;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.widget.ImageView;

/**
 * Created by  on 16-4-15.
 */
public class DragImageView extends ImageView{

    private final static String TAG = "DragImageView";

    private int startX;
    private int startY;
    private int startL;//初始时左上X,相对于父容器
    private int startT;//初始时左上Y
    private int startR;//初始时右下X
    private int startB;//初始时右下X
    private int stopX;
    private int stopY;


    public DragImageView(Context context) {
        super(context);
    }

    public DragImageView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @TargetApi(Build.VERSION_CODES.LOLLIPOP)
    public DragImageView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
    }

    public DragImageView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        int action = event.getAction();
        switch (action){
            case MotionEvent.ACTION_DOWN:
                startX = (int) event.getRawX();//相对于屏幕的x坐标,getX()是相对于组件的坐标
                startY = (int) event.getRawY();
                startL = getLeft();
                startT = getTop();
                startR = getRight();
                startB = getBottom();
                Log.d(TAG,"x:"+startX+",rawX,"+event.getRawX()+",left:"+getLeft());
                break;
            case MotionEvent.ACTION_MOVE:
            case MotionEvent.ACTION_UP:
                stopX = (int) event.getRawX();
                stopY = (int) event.getRawY();
                int deltaX = stopX - startX;//拖动偏移量
                int deltaY = stopY - startY;
                this.moveToPosition(startL+deltaX,startT+deltaY,startR+deltaX,startB+deltaY);
                stopX = (int) event.getRawX();
                stopY = (int) event.getRawY();
                invalidate();
                break;
        }
        return true;
    }

    private void moveToPosition(int leftX,int leftY,int rightX,int bottom){
        this.layout(leftX,leftY,rightX,bottom);
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值