Vector语法简介
Android以一种简化的方式对SVG进行了兼容,这种方式就是通过使用它的Path标签,通过Path标签,几乎可以实现SVG中的其它所有标签,虽然可能会复杂一点,但这些东西都是可以通过工具来完成的,所以,不用担心写起来会很复杂。
Path指令解析如下所示:
支持的指令:
M = moveto(M X,Y) :将画笔移动到指定的坐标位置
L = lineto(L X,Y) :画直线到指定的坐标位置
H = horizontal lineto(H X):画水平线到指定的X坐标位置
V = vertical lineto(V Y):画垂直线到指定的Y坐标位置
C = curveto(C X1,Y1,X2,Y2,ENDX,ENDY):三次贝赛曲线
S = smooth curveto(S X2,Y2,ENDX,ENDY)
Q = quadratic Belzier curve(Q X,Y,ENDX,ENDY):二次贝赛曲线
T = smooth quadratic Belzier curveto(T ENDX,ENDY):映射
A = elliptical Arc(A RX,RY,XROTATION,FLAG1,FLAG2,X,Y):弧线
Z = closepath():关闭路径
使用原则:
坐标轴为以(0,0)为中心,X轴水平向右,Y轴水平向下
所有指令大小写均可。大写绝对定位,参照全局坐标系;小写相对定位,参照父容器坐标系
指令和数据间的空格可以省略
同一指令出现多次可以只用一个。。
注意,'M'处理时,只是移动了画笔, 没有画任何东西。 它也可以在后面给出上同时绘制不连续线。
步骤
data:image/s3,"s3://crabby-images/1a8a7/1a8a7d9900013d011fc5fcbd50fac7332c4a0e2f" alt="7077845-1bf440e258ad0e25.png"
data:image/s3,"s3://crabby-images/db4ad/db4ad07315f38d4ab46b61c2bf17017f44681c24" alt="7077845-e38913cfef0632ab.png"
data:image/s3,"s3://crabby-images/9128a/9128adb7690ef9c46f154ca5b95f437edaa976f0" alt="7077845-d0c4df43372323ee.png"
data:image/s3,"s3://crabby-images/c2442/c2442db0ad94c6d6f959fcc062ebb9fe2a18e5cb" alt="7077845-57f243a03484daca.png"
data:image/s3,"s3://crabby-images/1107c/1107cf4c57d37e6a99fca451266973a060311e45" alt="7077845-e5e960ac6f4ced30.png"