上次我们使用Paint的RadialGradient实现了类似水波纹渲染的效果,这次我们来个更炫酷的,使用shader的梯度渲染来实现雷达扫描效果.这种场景之前迅雷的手机版好像有过这种效果,就是搜索附近的片子之类的.废话不多说,老样子,咱先看效果.这玩意不好录,实际效果比现在看到的好得多,大家可以自己尝试一下.
data:image/s3,"s3://crabby-images/90529/905298e0280f68bf1f4be21301cd388d9837a671" alt=""
还是老样子,自定义控件继承自View重写构造方法,我们可能要自定义一些属性.包括,雷达的半径,有多少个环形,环形的颜色,以及梯度渐变的颜色起始值以及末尾值.所以在含有两个参数的构造中我们将这些值取出来:
data:image/s3,"s3://crabby-images/bed78/bed78919ba03ab537df331600c8e875a30ccd9a4" alt=""
data:image/s3,"s3://crabby-images/61a53/61a5391d034c983da8a328ece753bab403be4ebd" alt=""
我们对自定义控件做一个测量,确定我们要画的环形的宽高.
data:image/s3,"s3://crabby-images/87e70/87e7083e33550f8aed749326a464bf7e6b7c4d64" alt=""
data:image/s3,"s3://crabby-images/39c67/39c67719a97de7cf49aabdf39781de1b022707f0" alt=""
第一步,先画环形(无梯度渐变),也就是雷达的背景:
data:image/s3,"s3://crabby-images/2957c/2957c1944c00cf8dc4479d1fcbf8d1b5117a1ba5" alt=""
第二步,画雷达扫描效果,给最大的圆环加入梯度渲染效果:
data:image/s3,"s3://crabby-images/88f54/88f549248c2dbf4e2092f3fae7fc5bbc223a462d" alt=""
第三步,就是动画了,让我们的扫描效果动起来:
我们使用Handler来刷新效果:
data:image/s3,"s3://crabby-images/cee34/cee34237382b83382a9d29eb510c535780d60aca" alt=""
data:image/s3,"s3://crabby-images/80398/803986b32ca5ed2a3c932a448c7e2b745eb1e339" alt=""
这样,一个雷达扫描效果就出来了.
网友评论