android 写了一个自定义轮廓,可以随意改变大小,拖动某个点

自定义View 触摸改变轮廓

复制代码
复制代码
import android.graphics.Rect;

import com.silverllt.base.utils.ConvertUtils;
import com.silverllt.skincenter.R;

public class DotPoint {
    private float dx;
    private float dy;
    private float radius;
    private Rect dotRect;

    public DotPoint(float x, float y) {
        dx = x;
        dy = y;
        radius = ConvertUtils.dp2px(15);
        dotRect = new Rect((int) (dx - radius), (int) (dy - radius), (int) (dx + radius), (int) (dy + radius));
    }

    public float getDx() {
        return dx;
    }

    public void setDx(float dx) {
        this.dx = dx;
    }

    public float getDy() {
        return dy;
    }

    public void setDy(float dy) {
        this.dy = dy;
    }

    public float getRadius() {
        return radius;
    }

    public void setRadius(float radius) {
        this.radius = radius;
    }

    public boolean containXy(float mStartX, float mStartY) {
        if (dotRect == null) return false;
        if (dotRect.contains((int) mStartX, (int) mStartY)) {
            return true;
        }

        return false;
    }

    public void upDateRect(float mStartX, float mStartY) {
        dx = mStartX;
        dy = mStartY;
        dotRect.set((int) (dx - radius), (int) (dy - radius), (int) (dx + radius), (int) (dy + radius));
    }
}
复制代码
import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;

import androidx.annotation.Nullable;



import java.util.ArrayList;

public class TouchDotView extends View {
    private ArrayList<DotPoint> mDotPointList = new ArrayList<>();
    private float mStartX;
    private float mStartY;
    private Context mContext;
    private Paint circlePaint;
    private Paint paint;
    private Path mPath = new Path();
    private int mTouchPointIndex = -1;

    public TouchDotView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
        initView(context);
    }

    public TouchDotView(Context context) {
        super(context);
        initView(context);
    }

    private void initView(Context context) {
        mContext = context;
        circlePaint = new Paint();
        circlePaint = new Paint();
        circlePaint.setAntiAlias(true);
        circlePaint.setStyle(Paint.Style.FILL);
        circlePaint.setColor(Color.WHITE);
        circlePaint.setStrokeWidth(2);


        paint = new Paint();
        paint.setAntiAlias(true);
        paint.setStyle(Paint.Style.STROKE);
        paint.setColor(Color.RED);
        paint.setStrokeWidth(2);

    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                mTouchPointIndex = -1;
                mStartX = event.getX();
                mStartY = event.getY();
                if (mDotPointList.size() == 10) {
                    mTouchPointIndex = findTouchPoint(mStartX, mStartY);
                    KLog.e("onTouchEvent:====="+ mTouchPointIndex);
                }
                break;
            case MotionEvent.ACTION_MOVE:
                if (mDotPointList.size() == 10) {
                    mStartX = event.getX();
                    mStartY = event.getY();
                    if (mTouchPointIndex >= 0 && mTouchPointIndex < mDotPointList.size()) {
                        DotPoint dotPoint = mDotPointList.get(mTouchPointIndex);
                        dotPoint.upDateRect(mStartX, mStartY);
                        invalidate();
                    }

                }
                break;
            case MotionEvent.ACTION_UP:
            case MotionEvent.ACTION_CANCEL:
                mTouchPointIndex = -1;
                mStartX = event.getX();
                mStartY = event.getY();
                if (mDotPointList == null) {
                    mDotPointList = new ArrayList<>();
                }
                if (mDotPointList.size() < 10) {
                    DotPoint dotPoint = new DotPoint(mStartX, mStartY);
                    mDotPointList.add(dotPoint);

             /*       if (mDotPointList.size() == 9) {
                        DotPoint dotPoint1 = mDotPointList.get(0);
                        DotPoint lastData = new DotPoint(dotPoint1.getDx(), dotPoint1.getDy());
                        mDotPointList.add(lastData);
                    }*/

                    invalidate();
                } else {

                }

                break;
        }
        return true;
    }

    private int findTouchPoint(float mStartX, float mStartY) {
        if (mDotPointList == null) return -1;
        for (int i = 0; i < mDotPointList.size(); i++) {
            DotPoint dotPoint = mDotPointList.get(i);
            boolean isTouchPoint = dotPoint.containXy(mStartX, mStartY);
            if (isTouchPoint) {
                return i;
            }
        }


        return -1;

    }

    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
    }


    @SuppressLint("Range")
    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        if (mDotPointList != null && mDotPointList.size() > 0) {
            mPath.reset();
            for (int i = 0; i < mDotPointList.size(); i++) {
                DotPoint dotPoint = mDotPointList.get(i);
                canvas.drawCircle(dotPoint.getDx(), dotPoint.getDy(), dotPoint.getRadius(), circlePaint);
                if (i == 0) {
                    mPath.moveTo(dotPoint.getDx(), dotPoint.getDy());
                } else {
                    mPath.lineTo(dotPoint.getDx(), dotPoint.getDy());
                    if (i == mDotPointList.size() - 1) {
                        mPath.lineTo(mDotPointList.get(0).getDx(), mDotPointList.get(0).getDy());
                    }
                }

            }
            canvas.drawPath(mPath, paint);
        }


    }

}
相关推荐
爱装代码的小瓶子3 小时前
【C++与Linux基础】进程间通讯方式:匿名管道
android·c++·后端
兴趣使然HX4 小时前
Android绘帧流程解析
android
JMchen1235 小时前
Android UDP编程:实现高效实时通信的全面指南
android·经验分享·网络协议·udp·kotlin
黄林晴5 小时前
Android 17 再曝猛料:通知栏和快捷设置终于分家了,这操作等了十年
android
有位神秘人6 小时前
Android获取设备中本地音频
android·音视频
JMchen1236 小时前
Android网络安全实战:从HTTPS到双向认证
android·经验分享·网络协议·安全·web安全·https·kotlin
CS创新实验室6 小时前
Pandas 3 的新功能
android·ide·pandas
ujainu6 小时前
护眼又美观:Flutter + OpenHarmony 鸿蒙记事本一键切换夜间模式(四)
android·flutter·harmonyos
三少爷的鞋6 小时前
为什么我不在 Android ViewModel 中直接处理异常?
android
草莓熊Lotso7 小时前
Linux 文件描述符与重定向实战:从原理到 minishell 实现
android·linux·运维·服务器·数据库·c++·人工智能