此九宫格手势自定义控件虽然比较简陋,但是也基本实现了如下功能:
1.默认显示九个小内圆,实心圆。 另外提供了,设置其半径,初始化颜色,以及选中之后的颜色
2.如果选中了小内圆,对应的也显示外圆环。 另外提供了,选中时候的颜色,以及失败的时候的颜色的设置
3.连线的绘制,在触摸滑动的过程中选中的点为联络站进行绘制路径。另外提供了 触摸时候连线的颜色以及失败的时候的颜色设置
4.手指离开触摸屏的时候,记录了对应的密码数字。并提供回调接口,可传递给外界进行校验判断。
注意:逻辑不复杂,但是需要注意的是,测量的时候对于AT_MOST如何处理。另外对自定义View设置padding的情况下如何处理,使其生效。
下面直接贴代码:
1.自定义View
package com.example.win10.smallprojecttest; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.Path; import android.graphics.Point; import android.support.annotation.Nullable; import android.util.AttributeSet; import android.view.MotionEvent; import android.view.View; import android.view.ViewGroup; import java.lang.reflect.Array; import java.util.ArrayList; import java.util.logging.Handler; /** * Created by WIN10 on 2019/2/11. */ public class MyLockView extends View { public Context context; private int screenWidth; private int screenHeight; int width;//去掉内边距之后的宽度,可用来画画的宽度 int height;//此去掉内边距之后的高度,可用来画画的高度 //内圆的画笔,color1默认,color11 被选中时候的颜色 private int radio1 = 50; private int color1 = Color.GRAY; private int color11 = Color.BLUE; private Paint paint1; //外圆的画笔参数 private int radio2 = 80; private int color2 = Color.BLUE; private int color22 = Color.RED; private Paint paint2; //连线画笔的参数 private int color3 = Color.BLUE; private int color33 = Color.RED; private Paint paint3; int left0 = 0;//大圆环的最左边的坐标 在无pading时为0 int top0 = 0;//大圆环的最上边的坐标 在无padding时为0 //下面是九个点 Point point1 = new Point(); Point point2 = new Point(); Point point3 = new Point(); Point point4 = new Point(); Point point5 = new Point(); Point point6 = new Point(); Point point7 = new Point(); Point point8 = new Point(); Point point9 = new Point(); ArrayList<Point> pointList = new ArrayList<>(); public void setSmallCircle(int radio,int defaultColor,int selectColor){ radio1=radio; color1=defaultColor; color11=selectColor; } public void setLargeCircle(int radio,int defaultColor,int errorColor){ radio2=radio; color2=defaultColor; color22=errorColor; } public void setLine(int defaultColor,int errorColor){ color3=defaultColor; color33=errorColor; } public MyLockView(Context context) { this(context, null); } public MyLockView(Context context, @Nullable AttributeSet attrs) {