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);
        }


    }

}
相关推荐
触想工业平板电脑一体机4 小时前
【触想智能】工业安卓一体机在人工智能领域上的市场应用分析
android·人工智能·智能电视
2501_915921436 小时前
iOS 是开源的吗?苹果系统的封闭与开放边界全解析(含开发与开心上架(Appuploader)实战)
android·ios·小程序·uni-app·开源·iphone·webview
allk556 小时前
OkHttp源码解析(一)
android·okhttp
allk556 小时前
OkHttp源码解析(二)
android·okhttp
2501_9159090610 小时前
原生 iOS 开发全流程实战,Swift 技术栈、工程结构、自动化上传与上架发布指南
android·ios·小程序·uni-app·自动化·iphone·swift
2501_9159090610 小时前
苹果软件混淆与 iOS 代码加固趋势,IPA 加密、应用防反编译与无源码保护的工程化演进
android·ios·小程序·https·uni-app·iphone·webview
2501_9160074710 小时前
苹果软件混淆与 iOS 应用加固实录,从被逆向到 IPA 文件防反编译与无源码混淆解决方案
android·ios·小程序·https·uni-app·iphone·webview
介一安全10 小时前
【Frida Android】基础篇6:Java层Hook基础——创建类实例、方法重载、搜索运行时实例
android·java·网络安全·逆向·安全性测试·frida
沐怡旸13 小时前
【底层机制】【Android】深入理解UI体系与绘制机制
android·面试
啊森要自信13 小时前
【GUI自动化测试】YAML 配置文件应用:从语法解析到 Python 读写
android·python·缓存·pytest·pip·dash