svg

1.svg的 polyline 和 path 的区别:

polyline:(直线,多条直线可以构建曲线)

<polyline> 元素是用于创建任何只有直线的形状

实例:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
  <polyline points="20,20 40,25 60,40 80,120 120,140 200,180"
  style="fill:none;stroke:black;stroke-3" />
</svg>

path:(路径)

<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轴水平向下。
所有指令大小写均可。大写绝对定位,参照全局坐标系;小写相对定位,参照父容器坐标系
指令和数据间的空格可以省略
同一指令出现多次可以只用一个

1、L H V指令

M 起点X,起点Y L(直线)终点X,终点Y H(水平线)终点X V(垂直线)终点Y
如:M 10,20 L 80,50 M 10,20 V 50 M 10,20 H 90

2、A指令

允许不闭合。可以想像成是椭圆的某一段,共七个参数:

A RX,RY,XROTATION,FLAG1,FLAG2,X,Y

RX,RY指所在椭圆的半轴大小
XROTATION指椭圆的X轴与水平方向顺时针方向夹角,可以想像成一个水平的椭圆绕中心点顺时针旋转XROTATION的角度。
FLAG1只有两个值,1表示大角度弧线,0为小角度弧线。
FLAG2只有两个值,确定从起点至终点的方向,1为顺时针,0为逆时针
X,Y为终点坐标

如:m 200,250 a 150,30 0 1 0 0,70

实例:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
  <path d="M150 0 L75 200 L225 200 Z" />
</svg>

2.使用 svg 绘制室内地图:

3.基于已有的 svg矢量图 制作室内地图:

(1) 通过 sublime 可以解析出 svg 是由 polyline(或path)组成的

(2) 动态加添 圆点 <circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="red" />

说明:

  • cx和cy属性定义圆点的x和y坐标。如果省略cx和cy,圆的中心会被设置为(0, 0)
  • r属性定义圆的半径

4.解决 svg 无法缩放的问题:

 方案一:

外层包裹一层div , 并设置div的width、height、overflow:scroll

svg 设置 width="600"、height="600"、viewbox="0 0 500 500"

注:width、height 为 svg 的实际宽高,0 0 为 svg 的起始点,500 500 为 svg 的 视区盒子(即 svg相当于屏幕,viewbox 相当于截屏工具所截取部分视图)

5.设置 svg 的缩放

        <script>
			var svg = document.getElementById('svg');
			var h = svg.getAttribute("height");
			var w = svg.getAttribute("width");
			document.getElementById('plus').addEventListener('click',function(){ // 放大
				h = Number(h) + 10;
				w = Number(w) + 10;
				svg.setAttribute('height',h);
				svg.setAttribute('width',w);
			});
			document.getElementById('reduce').addEventListener('click',function(){ // 缩小
				h = Number(h) - 10;
				w = Number(w) - 10;
				svg.setAttribute('height',h);
				svg.setAttribute('width',w);
			});
		</script>

.

原文地址:https://www.cnblogs.com/crazycode2/p/6949771.html