天才程序员教你写一个手势就能解锁的控件!是不是非常神奇!


效果分析:
仔细分析效果图发现,锁屏控件需要绘制的有三个部分,分别是:
1.图案点,图案点有四种状态,分别是默认、选中、正确和错误




2.图案点之间的连线
连线会根据1中点的状态改变发生颜色上的变化

3.悬空线段
就是图案点和悬空点之间的线段


实现:



View的状态用一个枚举类型来表示:

View的状态通过暴露一个方法给LockScreenViewGroup来进行设置。
在onDraw方法中判断类型,进行绘制:

这里在选中时用属性动画做了一个放大效果,在下次恢复正常的时候要将大小恢复回去



在构造函数中解析xml中的自定义属性:



这里有两个地方需要注意一下:




(3)在Up状态时,根据答案的正确与否,对LockScreenView设置不同的状态,并且对悬空线段起始点进行重置

在onTouchEvent方法最后会调用invalidate方法对视图进行重绘,这时会调用dispatchDraw方法进行子View的绘制。
在dispatchDraw方法中进行图像点间的线段路径以及悬空线段的绘制:


最后附上源代码,文章来源:烧饼正努力
欢迎大家关注我的博客:https://home.cnblogs.com/u/sm123456/
欢迎大家加入千人交流答疑群:125240963
相关推荐
湾区人工智能 2020-11-20
diskingchuan 2020-10-23
amicablehj 2020-11-16
smartbaby 2020-11-11
teamvx 2020-11-11
啊兵 2020-11-10
ruancw 2020-11-10
Elyn 2020-11-08
susmote 2020-11-07
lipin 2020-11-03
kinglomei 2020-10-27
bucai 2020-10-26
JAVA飘香 2020-10-26
重剑无锋 2020-10-25
adentheima 2020-10-25
zhaoyinghuan 2020-10-25
Elyn 2020-10-24
lipin 2020-10-22
feinifi 2020-10-14