内容字号:默认大号超大号

段落设置:段首缩进取消段首缩进

字体设置:切换到微软雅黑切换到宋体

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

2018-06-08 19:00 出处:清屏网 人气: 评论(0

效果分析:

仔细分析效果图发现,锁屏控件需要绘制的有三个部分,分别是:

1.图案点,图案点有四种状态,分别是默认、选中、正确和错误

2.图案点之间的连线

连线会根据1中点的状态改变发生颜色上的变化

3.悬空线段

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

实现:

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

View的状态通过暴露一个方法给LockScreenViewGroup来进行设置。

在onDraw方法中判断类型,进行绘制:

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

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

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

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

在onTouchEvent方法最后会调用invalidate方法对视图进行重绘,这时会调用dispatchDraw方法进行子View的绘制。

在dispatchDraw方法中进行图像点间的线段路径以及悬空线段的绘制:

分享给小伙伴们:
本文标签: 解锁程序员

相关文章

发表评论愿您的每句评论,都能给大家的生活添色彩,带来共鸣,带来思索,带来快乐。

CopyRight © 2015-2016 QingPingShan.com , All Rights Reserved.

清屏网 版权所有 豫ICP备15026204号