Skip to content

webgl 可视化

地理信息获取

1-H5 地理信息.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<style>
			#box {
				width: 300px;
				height: 300px;
				border: 1px solid #000;
			}
		</style>
	</head>
	<body>
		<div id="box"></div>
		<script>
			if ("geolocation" in navigator) {
				//console.log(navigator.geolocation);
				let nub = 0;
				let index = navigator.geolocation.watchPosition(
					(position) => {
						//console.log("请求成功",position);
						nub++;
						box.innerHTML = `
           当前时间: ${position.timestamp}<br/>
           维度: ${position.coords.latitude}<br/>
           经度: ${position.coords.longitude}<br/>
           ${nub}
        `;
						if (nub >= 10) {
							navigator.geolocation.clearWatch(nub);
						}
					},
					(err) => {
						console.log("请求失败", err);
					},
					{
						enableHighAccuracy: true,
						timeout: 3000,
					}
				);
			} else {
				alert("对不起您的设备不支持地理定位");
			}
		</script>
	</body>
</html>

各种地图的 API

百度地图

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<script src="http://api.map.baidu.com/api?v=3.0&ak=zKmy0EuvQ863eYPVAV0i4nwAIGqpB1Fs"></script>
		<style>
			#box {
				width: 300px;
				height: 300px;
			}
		</style>
	</head>
	<body>
		<div id="box"></div>
		<script>
			// 在 box 中创建一份地图
			var map = new BMap.Map("box");
			// 获取以当前经纬为中心的地图信息
			var point = new BMap.Point(116.404, 39.915);
			// 创建点坐标
			// 给 box 中 map 设置 中心点 以及缩放级别
			map.centerAndZoom(point, 15);
		</script>
	</body>
</html>

坐标系转换

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<script src="https://api.map.baidu.com/api?v=3.0&ak=zKmy0EuvQ863eYPVAV0i4nwAIGqpB1Fs"></script>
		<style>
			#box {
				width: 300px;
				height: 300px;
			}
		</style>
	</head>
	<body>
		<div id="box"></div>
		<div id="box2"></div>
		<script>
			navigator.geolocation.getCurrentPosition(
				(position) => {
					let { latitude, longitude } = position.coords;
					// 在 box 中创建一份地图
					var map = new BMap.Map("box");
					// 获取以当前经纬为中心的地图信息
					var point = new BMap.Point(longitude, latitude);
					// 创建点坐标
					// 给 box 中 map 设置 中心点 以及缩放级别
					var convertor = new BMap.Convertor();
					var pointArr = [point];
					convertor.translate(pointArr, 1, 5, (data) => {
						//box2.innerHTML = data.points[0];
						map.centerAndZoom(data.points[0], 15);
					});
				},
				(err) => {
					console.log("请求失败", err);
				},
				{
					enableHighAccuracy: true,
					timeout: 3000,
				}
			);
		</script>
	</body>
</html>

百度定位

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<script src="http://api.map.baidu.com/api?v=3.0&ak=zKmy0EuvQ863eYPVAV0i4nwAIGqpB1Fs"></script>
		<style>
			#box {
				width: 300px;
				height: 300px;
			}
		</style>
	</head>
	<body>
		<div id="box"></div>
		<div id="box2"></div>
		<script>
			{
				let geolocation = new BMap.Geolocation();
				geolocation.getCurrentPosition((e) => {
					if (geolocation.getStatus() === BMAP_STATUS_SUCCESS) {
						//console.log(e);
						let map = new BMap.Map("box");
						let mark = new BMap.Marker(e.point);
						map.centerAndZoom(e.point, 15);
						map.addOverlay(mark);
					} else {
						alert("定位失败");
					}
				});
			}
		</script>
	</body>
</html>

行走日记

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<script src="http://api.map.baidu.com/api?v=3.0&ak=zKmy0EuvQ863eYPVAV0i4nwAIGqpB1Fs"></script>
		<style>
			html {
				font-size: 10vw;
			}
			body {
				margin: 0;
				font-size: 0.3rem;
			}
			h1 {
				margin: 0;
			}
			#main {
				display: flex;
				position: fixed;
				left: 0;
				top: 0;
				width: 100%;
				height: 100%;
				flex-direction: column;
			}
			.header {
				height: 1.4rem;
				background: #000;
			}
			.header h1 {
				font: 0.45rem/1.4rem "宋体";
				text-align: center;
				color: #fff;
			}
			#view {
				flex: 1;
			}
			.view {
				height: 100%;
				display: none;
				overflow: auto;
			}
			#view .show {
				display: block;
			}
			#nav {
				display: flex;
				border-top: 2px solid #000;
				height: 1.2rem;
			}
			#nav a {
				flex: 1;
				background: #000;
				color: #fff;
				font: 0.3rem/1.2rem "宋体";
				text-align: center;
			}
			#nav a.active {
				color: #000;
				background: #fff;
			}
		</style>
	</head>
	<body>
		<section id="main">
			<header class="header">
				<h1>行走日记</h1>
			</header>
			<div id="view">
				<div class="view show" id="map"></div>
				<div class="view">
					<textarea id="text"></textarea>
					<button id="btn">发布日记</button>
				</div>
				<div class="view" id="list">
					<ul class="message_list">
						<li>
							<p>心情不错,放飞了自己</p>
							<span>北京市</span>
						</li>
						<li>
							<p>心情不错,放飞了自己2</p>
							<span>北京市</span>
						</li>
						<li>
							<p>心情不错,放飞了自己3</p>
							<span>北京市</span>
						</li>
					</ul>
				</div>
			</div>
			<nav id="nav">
				<a class="active">地图</a>
				<a>记录</a>
				<a>日记</a>
			</nav>
		</section>
		<script>
			{
				let navs = document.querySelectorAll("#nav a");
				let views = document.querySelectorAll("#view .view");
				let map = new BMap.Map("map");
				let geolocation = new BMap.Geolocation();
				let nowPoint = new BMap.Point(116.331398, 39.897445);
				let nowCity = "";
				let marks = [];
				let messageList = document.querySelector(".message_list");
				if (localStorage.getItem("gis")) {
					gis = JSON.parse(localStorage.getItem("gis"));
				} else {
					gis = [
						{
							title: "哈哈哈",
							point: new BMap.Point(116.331398, 39.897445),
							city: "北京市",
						},
					];
				}
				addLabel();
				renderList();
				map.centerAndZoom(nowPoint, 12);

				// 在地图上添加覆盖物
				function addLabel() {
					marks.forEach((mark) => {
						map.removeOverlay(mark);
					});
					gis.forEach((info) => {
						let mark = new BMap.Marker(info.point);
						let txt = info.title.substr(0, 10);
						let width = txt.length * 12 + 10;
						let opt = {
							position: info.point,
							offset: new BMap.Size(-width / 2 - 2, 2),
						};
						let label = new BMap.Label(txt, opt);
						label.setStyle({
							width: width + "px",
							fontSize: "12px",
							color: "red",
							height: "30px",
							lineHeight: "30px",
							textAlign: "center",
						});
						map.addOverlay(mark);
						map.addOverlay(label);
						marks.push(mark);
						marks.push(label);
					});
				}

				// 渲染日记

				function renderList() {
					if (gis.length < 1) {
						messageList.innerHTML = "暂无日记";
						return;
					}
					messageList.innerHTML = gis
						.map((info) => {
							return `<li>
                    <p>${info.title}</p>
                    <span>${info.city}</span>
                </li>`;
						})
						.join("");
				}

				// 获取当前位置
				geolocation.getCurrentPosition(
					(e) => {
						if (geolocation.getStatus() == 0) {
							nowPoint = e.point;
							console.log(e);
							nowCity = e.address.city;
							let myIcon = new BMap.Icon(
								"http://lbsyun.baidu.com//jsdemo/img/fox.gif",
								new BMap.Size(300, 157)
							);
							let mark = new BMap.Marker(nowPoint, { icon: myIcon });
							map.addOverlay(mark);
							map.panTo(nowPoint);
						}
					},
					{
						enableHighAccuracy: true,
					}
				);

				// 发布日记
				let btn = document.querySelector("#btn");
				let text = document.querySelector("#text");
				btn.onclick = function () {
					gis.push({
						title: text.value,
						point: nowPoint,
						city: nowCity,
					});
					addLabel();
					renderList();
					localStorage.setItem("gis", JSON.stringify(gis));
				};

				navs.forEach((a, index) => {
					a.onclick = function () {
						navs.forEach((a, index) => {
							a.classList.remove("active");
							views[index].classList.remove("show");
						});
						a.classList.add("active");
						views[index].classList.add("show");
					};
				});
			}
		</script>
	</body>
</html>

控件

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<script src="http://api.map.baidu.com/api?v=3.0&ak=zKmy0EuvQ863eYPVAV0i4nwAIGqpB1Fs"></script>
		<style>
			html {
				font-size: 10vw;
			}
			body {
				margin: 0;
				font-size: 0.3rem;
			}
			h1 {
				margin: 0;
			}
			#main {
				display: flex;
				position: fixed;
				left: 0;
				top: 0;
				width: 100%;
				height: 100%;
				flex-direction: column;
			}
			#map {
				flex: 1;
			}
		</style>
	</head>
	<body>
		<section id="main">
			<div id="map"></div>
		</section>
		<script>
			{
				let map = new BMap.Map("map");
				let nowPoint = new BMap.Point(116.331398, 39.897445);
				map.centerAndZoom(nowPoint, 12);
				map.addControl(
					new BMap.NavigationControl({
						anchor: BMAP_ANCHOR_BOTTOM_RIGHT,
						offset: new BMap.Size(100, 0),
						type: BMAP_NAVIGATION_CONTROL_PAN,
					})
				);
				map.addControl(new BMap.OverviewMapControl());
				map.addControl(new BMap.ScaleControl());
				map.addControl(new BMap.MapTypeControl());
				map.addControl(new BMap.GeolocationControl());
			}
		</script>
	</body>
</html>

高德地图

HTML5 拖放操作和 FileReader

1-Drag 与 Drop

1.拖拽与拖放的效果

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
	</head>
	<body>
		<p>呵呵哈哈哈</p>
		<div>
			<a href="http://kaikeba.com">呵呵呵呵</a>
		</div>
		<img src="./images/logo-new.png" />

		<div style="width: 100px;height: 100px;background: red"></div>
	</body>
</html>

2.拖放基本流程

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
	</head>
	<body>
		<p>呵呵哈哈哈</p>
		<div>
			<a href="http://kaikeba.com">呵呵呵呵</a>
		</div>
		<img src="./images/logo-new.png" draggable="false" />

		<!-- 设置被拖放元素的draggable属性为true -->
		<div
			id="box1"
			draggable="true"
			style="width: 100px;height: 100px;background: red"
		></div>

		<script>
			/*
            我们可以给默认可以拖拽的元素(选中的文本、链接、图像)设置draggable为false,就可以阻止它们拖拽

            firefox:如果拖拽的元素没有设置拖放内容,还是不能拖放
                - draggable=true
                - 设置拖放内容
        */
			let box1 = document.querySelector("#box1");

			box1.ondragstart = function (e) {
				// 设置拖放内容:e.dataTransfer.setData('text', 'kaikeba');
				e.dataTransfer.setData("text", "kaikeba");
			};
		</script>

		<div
			id="box1"
			draggable="true"
			style="width: 100px;height: 100px;background: red"
		></div>

		<div
			id="box2"
			draggable="true"
			style="width: 200px;height: 200px;background: green; position: absolute; left: 400px;top: 200px;"
		></div>

		<img src="./images/logo-new.png" />

		<script>
			let box1 = document.querySelector("#box1");
			let box2 = document.querySelector("#box2");

			box1.ondragstart = function (e) {
				// 如果在这里设置了拖拽的数据,则会触发浏览器的默认行为
				e.dataTransfer.setData("text", "http://kaikeba.com");

				console.log("dragstart");
			};

			box1.ondrag = function () {
				console.log("drag");
			};

			box1.ondragend = function () {
				console.log("dragend");
			};

			box2.ondragenter = function () {
				console.log("dragenter");
			};

			box2.ondragleave = function () {
				console.log("dragleave");
			};

			/*
            默认情况下,不是所有元素都能成为放置元素的
            我们需要在dragover事件中阻止默认的行为:不允许放置
        */
			box2.ondragover = function (e) {
				// 该事件每次触发的时候都会重置默认行为
				e.preventDefault();
				console.log("dragover");
			};

			box2.ondrop = function (e) {
				// 当drop事件触发的时候,还有会有其它的一些默认的行为
				e.preventDefault();
				e.stopPropagation();
				console.log("drop");
			};
		</script>
	</body>
</html>

3.拖放数据-拖放内容

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
	</head>
	<body>
		<div
			id="box1"
			draggable="true"
			style="width: 100px;height: 100px;background: red"
		></div>

		<div
			id="box2"
			draggable="true"
			style="width: 200px;height: 200px;background: green; position: absolute; left: 400px;top: 200px;"
		></div>

		<img src="./images/logo-new.png" />

		<script>
			let box1 = document.querySelector("#box1");
			let box2 = document.querySelector("#box2");

			box1.ondragstart = function (e) {
				// e.dataTransfer.setData('text/html', 'http://kaikeba.com');
				// e.dataTransfer.setData('text/plain', 'abc');
				// e.dataTransfer.setData('text', box1);

				e.dataTransfer.setData("text", "#box1");
			};

			box2.ondragover = function (e) {
				e.preventDefault();
			};

			box2.ondrop = function (e) {
				e.preventDefault();
				e.stopPropagation();

				// console.log('drop', e.dataTransfer.getData('text/html'));
				// console.log('drop', e.dataTransfer.getData('text/plain'));

				// console.log(e.dataTransfer.getData('text'));

				let id = e.dataTransfer.getData("text");
				let el = document.querySelector(id);

				this.appendChild(el);
			};
		</script>
	</body>
</html>

4.拖放数据-拖放效果

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
	</head>
	<body>
		<div
			id="box1"
			draggable="true"
			style="width: 100px;height: 100px;background: red"
		></div>

		<div
			id="box2"
			draggable="true"
			style="width: 200px;height: 200px;background: green; position: absolute; left: 400px;top: 200px;"
		></div>

		<img src="./images/logo-new.png" />

		<script>
			let box1 = document.querySelector("#box1");
			let box2 = document.querySelector("#box2");

			box1.ondragstart = function (e) {
				e.dataTransfer.setData("text", "开课吧");

				// 后续 dropEffect 值的白名单
				e.dataTransfer.effectAllowed = "copyLink";
			};

			box2.ondragover = function (e) {
				// 禁止放置
				// e.dataTransfer.dropEffect = 'none';

				// console.log( e.dataTransfer.dropEffect );

				e.dataTransfer.dropEffect = "move";

				e.preventDefault();
			};

			box2.ondrop = function (e) {
				e.preventDefault();
				e.stopPropagation();
				console.log("drop");
			};
		</script>
	</body>
</html>

5.拖放数据-拖放图片

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
	</head>
	<body>
		<div
			id="box1"
			draggable="true"
			style="width: 100px;height: 100px;background: red"
		></div>

		<div
			id="box2"
			draggable="true"
			style="width: 200px;height: 200px;background: green; position: absolute; left: 400px;top: 200px;"
		></div>

		<!-- <img src="./images/logo-new.png" /> -->

		<script>
			let box1 = document.querySelector("#box1");
			let box2 = document.querySelector("#box2");

			let img = new Image(); // document.createElement('img');
			img.src = "./images/logo-new.png";

			box1.ondragstart = function (e) {
				e.dataTransfer.setData("text", "开课吧");

				// 后续 dropEffect 值的白名单
				e.dataTransfer.effectAllowed = "copyLink";

				// 设置拖放图片
				e.dataTransfer.setDragImage(img, 100, 100);
			};

			box2.ondragover = function (e) {
				// 禁止放置
				// e.dataTransfer.dropEffect = 'none';

				// console.log( e.dataTransfer.dropEffect );

				e.dataTransfer.dropEffect = "move";

				e.preventDefault();
			};

			box2.ondrop = function (e) {
				e.preventDefault();
				e.stopPropagation();
				console.log("drop");
			};
		</script>
	</body>
</html>

2-系统文件拖放与读取

1.拖放系统文件到页面.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<style>
			html,
			body {
				margin: 0;
				width: 100%;
				height: 100%;
			}
		</style>
	</head>
	<body>
		<script>
			// 设置body为可放置元素
			document.body.ondragover = function (e) {
				e.preventDefault();
			};
			// 处理放置后的行为
			document.body.ondrop = function (e) {
				// 防止浏览器打开文件这个默认行为
				e.preventDefault();
				e.stopPropagation();

				// console.log('drop');

				console.log(e.dataTransfer.files);
			};
		</script>
	</body>
</html>

2.input.file.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
	</head>
	<body>
		<input type="file" id="f" />

		<script>
			let f = document.querySelector("#f");

			f.onchange = function () {
				// console.log('change');
				// console.log( this.value );

				console.log(this.files);
			};
		</script>
	</body>
</html>

3.FileReader.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<style>
			html,
			body {
				margin: 0;
				width: 100%;
				height: 100%;
			}
		</style>
	</head>
	<body>
		<script>
			// 设置body为可放置元素
			document.body.ondragover = function (e) {
				e.preventDefault();
			};
			// 处理放置后的行为
			document.body.ondrop = function (e) {
				// 防止浏览器打开文件这个默认行为
				e.preventDefault();
				e.stopPropagation();

				// console.log('drop');

				// console.log( e.dataTransfer.files );

				let file = e.dataTransfer.files[0];

				// 读取文件的内容
				let fr = new FileReader();

				fr.onload = function () {
					console.log(this.result);
				};

				// fr.readAsText( file );
				// fr.readAsText( file, 'gbk' );
			};
		</script>
	</body>
</html>

4.FileReader-dataURL.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<style>
			html,
			body {
				margin: 0;
				width: 100%;
				height: 100%;
			}
		</style>
	</head>
	<body>
		<!-- <img src="" /> -->

		<script>
			// 设置body为可放置元素
			document.body.ondragover = function (e) {
				e.preventDefault();
			};
			// 处理放置后的行为
			document.body.ondrop = function (e) {
				// 防止浏览器打开文件这个默认行为
				e.preventDefault();
				e.stopPropagation();

				// console.log('drop');

				// console.log( e.dataTransfer.files );

				let file = e.dataTransfer.files[0];

				// 读取文件的内容
				let fr = new FileReader();

				fr.onload = function () {
					// console.log(this.result);

					let img = new Image(); // new Image() => document.createElement('img')
					img.src = this.result;
					document.body.appendChild(img);
				};

				fr.readAsDataURL(file);
			};
		</script>
	</body>
</html>

5.FileReader-ArrayBuffer.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<style>
			html,
			body {
				margin: 0;
				width: 100%;
				height: 100%;
			}
		</style>
	</head>
	<body>
		<script>
			// 设置body为可放置元素
			document.body.ondragover = function (e) {
				e.preventDefault();
			};
			// 处理放置后的行为
			document.body.ondrop = function (e) {
				// 防止浏览器打开文件这个默认行为
				e.preventDefault();
				e.stopPropagation();

				// console.log('drop');

				// console.log( e.dataTransfer.files );

				let file = e.dataTransfer.files[0];

				// 读取文件的内容
				let fr = new FileReader();

				fr.onload = function () {
					console.log(this.result);

					let int8Array = new Int8Array(this.result);
					console.log(int8Array);

					int8Array.forEach((data) => {
						// console.log(data);

						console.log(String.fromCharCode(data));
					});
				};

				fr.readAsArrayBuffer(file);
			};
		</script>
	</body>
</html>

3-系统文件夹拖放与读取

resources/recycle-bin.svg

html
<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg
	t="1559012320249"
	class="icon"
	style=""
	viewBox="0 0 1024 1024"
	version="1.1"
	xmlns="http://www.w3.org/2000/svg"
	p-id="993"
	xmlns:xlink="http://www.w3.org/1999/xlink"
	width="200"
	height="200"
>
	<defs><style type="text/css"></style></defs>
	<path
		d="M944.355556 170.666667h-166.115556V111.502222c0-27.306667-20.48-47.786667-47.786667-47.786666H293.546667c-27.306667 0-47.786667 20.48-47.786667 47.786666v56.888889H79.644444C61.44 170.666667 45.511111 186.595556 45.511111 204.8s15.928889 34.133333 34.133333 34.133333h866.986667c18.204444 0 34.133333-15.928889 34.133333-34.133333-2.275556-18.204444-18.204444-34.133333-36.408888-34.133333zM812.373333 311.751111H211.626667c-9.102222 0-18.204444 2.275556-22.755556 9.102222-6.826667 6.826667-9.102222 13.653333-9.102222 22.755556v550.684444c0 54.613333 45.511111 100.124444 100.124444 100.124445h466.488889c54.613333 0 100.124444-45.511111 100.124445-100.124445V343.608889c0-18.204444-15.928889-31.857778-34.133334-31.857778zM425.528889 841.955556c0 18.204444-15.928889 34.133333-34.133333 34.133333s-34.133333-15.928889-34.133334-34.133333V482.417778c0-18.204444 15.928889-34.133333 34.133334-34.133334s34.133333 15.928889 34.133333 34.133334V841.955556z m241.208889 0c0 18.204444-15.928889 34.133333-34.133334 34.133333s-34.133333-15.928889-34.133333-34.133333V482.417778c0-18.204444 15.928889-34.133333 34.133333-34.133334s34.133333 15.928889 34.133334 34.133334V841.955556z"
		fill="#d81e06"
		p-id="994"
	></path>
</svg>

1.系统文件夹拖放.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<title>Document</title>
		<style>
			html,
			body {
				margin: 0;
				width: 100%;
				height: 100%;
			}
		</style>
	</head>
	<body>
		<script>
			document.body.ondragover = function (e) {
				e.preventDefault();
			};

			document.ondrop = function (e) {
				e.preventDefault();
				e.stopPropagation();

				// 拖拽的内容
				// console.log( e.dataTransfer.files );

				// items:拖拽的文件
				// console.log( e.dataTransfer.items );

				[...e.dataTransfer.items].forEach((item) => {
					// console.log(item);

					// let file = item.getAsFile();
					// console.log(file);

					// 要获取当前item对象的FileSystemEntry对象,通过该对象我们可以分辨出是文件还是文件夹
					let entry = item.webkitGetAsEntry();
					// console.log( entry );

					getFiles(entry);
				});
			};

			function getFiles(entry) {
				if (entry.isFile) {
					// 如果是文件,直接转成File对象
					entry.file(
						(f) => {
							console.log(f); //File
						},
						(err) => {
							console.log("读取失败");
						}
					);
				}

				if (entry.isDirectory) {
					// console.log('我是一个目录');

					// 创建一个目录读取对象
					let dirReader = entry.createReader();
					dirReader.readEntries((entries) => {
						// console.log(entries);

						entries.forEach((entry) => {
							getFiles(entry);
						});
					});
				}
			}
		</script>
	</body>
</html>

实例-1-拖拽项目到回收站

实例-1-拖拽项目到回收站-无 JS 版本.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>实例-1-拖拽项目到回收站-无JS版本</title>
		<style>
			.recycle-bin {
				position: fixed;
				right: 80px;
				top: 80px;
				width: 120px;
				height: 120px;
				background: url("./resources/recycle-bin.svg") no-repeat;
				background-size: cover;
			}
			.box {
				margin: 100px auto 0;
				width: 800px;
				overflow: hidden;
			}
			ul {
				float: left;
				margin: 0;
				padding: 10px;
				width: 30%;
				min-height: 40px;
				border: 4px solid #aaaaab;
				color: #aaaaab;
				list-style: none;
			}
			ul.focus {
				border-color: #5fa207;
				border-style: dashed;
				color: #5fa207;
			}
			li {
				padding: 20px;
				line-height: 20px;
			}
			li.drag {
				background-color: #5fa207;
				color: #fff;
			}
		</style>
	</head>
	<body>
		<div class="recycle-bin"></div>

		<div class="box">
			<ul class="left">
				<li>选项一</li>
				<li>选项二</li>
				<li>选项三</li>
				<li>选项四</li>
			</ul>
		</div>
	</body>
</html>
实例-1-拖拽项目到回收站.html
html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Title</title>
		<style>
			.recycle-bin {
				position: fixed;
				right: 80px;
				top: 80px;
				width: 120px;
				height: 120px;
				background: url("./resources/recycle-bin.svg") no-repeat;
				background-size: cover;
			}
			.box {
				margin: 100px auto 0;
				width: 800px;
				overflow: hidden;
			}
			ul {
				float: left;
				margin: 0;
				padding: 10px;
				width: 30%;
				min-height: 40px;
				border: 4px solid #aaaaab;
				color: #aaaaab;
				list-style: none;
			}
			ul.focus {
				border-color: #5fa207;
				border-style: dashed;
				color: #5fa207;
			}
			li {
				padding: 20px;
				line-height: 20px;
			}
			li.drag {
				background-color: #5fa207;
				color: #fff;
			}
		</style>
	</head>
	<body>
		<div class="recycle-bin"></div>

		<div class="box">
			<ul class="left">
				<li>选项一</li>
				<li>选项二</li>
				<li>选项三</li>
				<li>选项四</li>
			</ul>
		</div>

		<script>
			/*
	1. 获取所有的li元素,并给它们绑定
		1. dragstart
			1. 设置该元素的class为drag
		2. dragend
			2. 删除该元素的drag样式

	2. 获取到回收站元素,也给它绑定
		1. dragover
		2. drop
			删除拖放到回收站上的元素
	
*/

			let liElements = document.querySelectorAll("li");
			let recycleBinElement = document.querySelector(".recycle-bin");
			let dragElement = null;

			liElements.forEach((liElement) => {
				liElement.setAttribute("draggable", true);

				liElement.ondragstart = function (e) {
					e.dataTransfer.setData("text", "");

					this.classList.add("drag");
					dragElement = this;
				};

				liElement.ondragend = function () {
					this.classList.remove("drag");
				};

				recycleBinElement.ondragover = function (e) {
					e.preventDefault();
				};

				recycleBinElement.ondrop = function (e) {
					e.preventDefault();
					e.stopPropagation();

					dragElement.remove();
				};
			});
		</script>
	</body>
</html>

实例-2-拖拽的穿梭框

实例-2-拖拽的穿梭框-无 JS 版本.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Title</title>
		<style>
			.box {
				margin: 100px auto 0;
				width: 800px;
				overflow: hidden;
			}
			ul {
				margin: 0;
				padding: 10px;
				width: 30%;
				min-height: 40px;
				border: 4px solid #aaaaab;
				color: #aaaaab;
				list-style: none;
			}
			ul.left {
				float: left;
			}
			ul.right {
				float: right;
			}
			ul.focus {
				border-color: #5fa207;
				border-style: dashed;
				color: #5fa207;
			}
			li {
				padding: 20px;
				line-height: 20px;
			}
			li.drag {
				background-color: #5fa207;
				color: #fff;
			}
		</style>
	</head>
	<body>
		<div class="box">
			<ul class="left">
				<li>选项一</li>
				<li>选项二</li>
				<li>选项三</li>
				<li>选项四</li>
			</ul>
			<ul class="right"></ul>
		</div>
	</body>
</html>

实例-2-拖拽的穿梭框.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Title</title>
		<style>
			.box {
				margin: 100px auto 0;
				width: 800px;
				overflow: hidden;
			}
			ul {
				margin: 0;
				padding: 10px;
				width: 30%;
				min-height: 40px;
				border: 4px solid #aaaaab;
				color: #aaaaab;
				list-style: none;
			}
			ul.left {
				float: left;
			}
			ul.right {
				float: right;
			}
			ul.focus {
				border-color: #5fa207;
				border-style: dashed;
				color: #5fa207;
			}
			li {
				padding: 20px;
				line-height: 20px;
			}
			li.drag {
				background-color: #5fa207;
				color: #fff;
			}
		</style>
	</head>
	<body>
		<div class="box">
			<ul class="left">
				<li>选项一</li>
				<li>选项二</li>
				<li>选项三</li>
				<li>选项四</li>
			</ul>
			<ul class="right"></ul>
		</div>

		<script>
			/*
			1. 获取到所有的li元素,并给它们绑定
				dragstart、dragend
			2. 给两个ul绑定
				dragover、dragleave、drop
		*/

			let liElements = document.querySelectorAll("li");
			let leftElement = document.querySelector(".left");
			let rightElement = document.querySelector(".right");

			let dragElement = null;

			liElements.forEach((liElement) => {
				liElement.setAttribute("draggable", true);

				liElement.ondragstart = function (e) {
					e.dataTransfer.setData("text", "");

					this.classList.add("drag");
					dragElement = this;
				};

				liElement.ondragend = function () {
					this.classList.remove("drag");
				};
			});

			leftElement.ondragover = rightElement.ondragover = function (e) {
				// console.log( dragElement.parentNode == this );
				// console.log( this.contains( dragElement ) );

				if (!this.contains(dragElement)) {
					e.preventDefault();
					this.classList.add("focus");
				}
			};

			leftElement.ondragleave = rightElement.ondragleave = function (e) {
				this.classList.remove("focus");
			};

			leftElement.ondrop = rightElement.ondrop = function (e) {
				e.preventDefault();
				e.stopPropagation();

				this.classList.remove("focus");

				this.appendChild(dragElement);
			};
		</script>
	</body>
</html>

实例-3-拖拽无刷新上传

前端版本

index.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Title</title>
		<style>
			html,
			body {
				height: 100%;
				margin: 0;
			}
			ul {
				margin: 0;
				padding: 0;
				list-style: none;
			}
			.drop_dashed {
				position: fixed;
				left: 0;
				top: 0;
				width: 100%;
				height: 100%;
				border: 5px dashed rgb(0, 0, 0);
				background-color: rgb(255, 255, 255);
				opacity: 0.2;
				box-sizing: border-box;
				display: none;
			}
			.drop_dashed:before {
				position: absolute;
				left: 0;
				top: 50%;
				width: 100%;
				text-align: center;
				font-size: 24px;
				line-height: 24px;
				content: "文件拖放到此处";
			}

			.task_panel {
				display: none;
				position: fixed;
				right: 20px;
				bottom: 20px;
				z-index: 99;
				width: 500px;
				box-shadow: 0 1px 4px 0 rgba(15, 32, 66, 0.2);
				border: 1px solid rgba(5, 13, 27, 0.16);
				overflow: hidden;
			}
			.task_panel:before {
				content: "";
				position: absolute;
				top: 0;
				left: 0;
				right: 0;
				border: 2px solid #00a4ff;
			}

			.icon {
				display: inline-block;
				width: 36px;
				height: 36px;
				line-height: 36px;
				background-repeat: no-repeat;
				background-position: center;
			}
			.task-progress-status-success {
				background-image: url("./images/icon-task-succ.svg");
			}
			.window-fold {
				background-image: url("./images/icon-window-fold.svg");
			}
			.all-close {
				background-image: url("./images/icon-all-close.svg");
			}

			.task_header {
				padding: 20px;
				border-bottom: 1px solid #eeeeee;
			}

			.task_header h4 {
				margin: 0;
				padding: 0;
				font-size: 24px;
			}
			.task_header .icon {
				position: absolute;
				top: 20px;
				cursor: pointer;
				transition: all 0.5s;
			}
			.task_header .icon.window-fold {
				right: 40px;
			}
			.task_header .icon.all-close {
				right: 10px;
			}
			.task_header .icon.window-fold.down,
			.task_header .icon.all-close:hover {
				transform: rotate(180deg);
			}

			.task_body {
				height: 313px;
				overflow: auto;
				transition: height 0.5s;
			}
			.task_body.hide {
				height: 0;
			}
			.task_body li {
				margin-bottom: 2px;
				position: relative;
				height: 20px;
				line-height: 20px;
				padding: 20px;
			}
			.task_body span {
				position: relative;
				z-index: 99;
			}
			.task_body li .task-progress-status {
				position: absolute;
				right: 10px;
				top: 0;
				z-index: 99;
				line-height: 60px;
			}
			.task_body li .task-progress-status .icon {
				position: relative;
				top: 15px;
			}
			.task_body .progress {
				position: absolute;
				left: 0;
				top: 0;
				width: 0%;
				height: 60px;
				background-color: rgba(0, 40, 255, 0.3);
			}
		</style>
	</head>
	<body>
		<div class="drop_dashed"></div>

		<div class="task_panel">
			<div class="task_header">
				<h4></h4>

				<span class="icon window-fold"></span>
				<span class="icon all-close"></span>
			</div>
			<ul class="task_body">
				<li>
					<span>任务一</span>
					<div class="task-progress-status">上传中……</div>
					<div class="progress"></div>
				</li>
				<li>
					<span>任务二</span>
					<div class="task-progress-status">
						<span class="icon task-progress-status-success"></span>
					</div>
					<div class="progress"></div>
				</li>
				<li>
					<span>任务三</span>
					<div class="task-progress-status">
						<span class="icon task-progress-status-success"></span>
					</div>
					<div class="progress"></div>
				</li>
			</ul>
		</div>
	</body>
</html>

icon-all-close.svg

html
<?xml version="1.0" encoding="UTF-8"?>
<svg
	width="20px"
	height="20px"
	viewBox="0 0 20 20"
	version="1.1"
	xmlns="http://www.w3.org/2000/svg"
	xmlns:xlink="http://www.w3.org/1999/xlink"
>
	<!-- Generator: Sketch 48.2 (47327) - http://www.bohemiancoding.com/sketch -->
	<title>icon-all-close</title>
	<desc>Created with Sketch.</desc>
	<defs></defs>
	<g
		id="Artboard-4"
		stroke="none"
		stroke-width="1"
		fill="none"
		fill-rule="evenodd"
	>
		<g id="ic_close_task">
			<g>
				<rect id="Rectangle-22" x="0" y="0" width="20" height="20"></rect>
				<path
					d="M11,9 L17,9 L17,11 L11,11 L11,17 L9,17 L9,11 L3,11 L3,9 L9,9 L9,3 L11,3 L11,9 Z"
					id="Combined-Shape"
					fill="#484848"
					transform="translate(10.000000, 10.000000) rotate(-45.000000) translate(-10.000000, -10.000000) "
				></path>
			</g>
		</g>
	</g>
</svg>

icon-task-succ.svg

html
<?xml version="1.0" encoding="UTF-8"?>
<svg
	width="20px"
	height="20px"
	viewBox="0 0 20 20"
	version="1.1"
	xmlns="http://www.w3.org/2000/svg"
	xmlns:xlink="http://www.w3.org/1999/xlink"
>
	<!-- Generator: Sketch 48.2 (47327) - http://www.bohemiancoding.com/sketch -->
	<title>icon-task-succ</title>
	<desc>Created with Sketch.</desc>
	<defs></defs>
	<g
		id="Artboard-7"
		stroke="none"
		stroke-width="1"
		fill="none"
		fill-rule="evenodd"
	>
		<path
			d="M8.58578644,11.8284271 L5.75735931,9 L4.34314575,10.4142136 L7.17157288,13.2426407 L8.58578644,14.6568542 L15.6568542,7.58578644 L14.2426407,6.17157288 L8.58578644,11.8284271 Z M10,19 C5.02943725,19 1,14.9705627 1,10 C1,5.02943725 5.02943725,1 10,1 C14.9705627,1 19,5.02943725 19,10 C19,14.9705627 14.9705627,19 10,19 Z"
			id="icon-task-succ"
			fill="#01BD88"
		></path>
	</g>
</svg>

icon-window-fold.svg

html
<?xml version="1.0" encoding="UTF-8"?>
<svg
	width="20px"
	height="20px"
	viewBox="0 0 20 20"
	version="1.1"
	xmlns="http://www.w3.org/2000/svg"
	xmlns:xlink="http://www.w3.org/1999/xlink"
>
	<!-- Generator: Sketch 48.2 (47327) - http://www.bohemiancoding.com/sketch -->
	<title>icon-window-fold</title>
	<desc>Created with Sketch.</desc>
	<defs></defs>
	<g
		id="Artboard-3"
		stroke="none"
		stroke-width="1"
		fill="none"
		fill-rule="evenodd"
	>
		<g id="ic_unfold">
			<g
				transform="translate(10.000000, 10.000000) scale(1, -1) translate(-10.000000, -10.000000) "
			>
				<rect id="Rectangle-19" x="0" y="0" width="20" height="20"></rect>
				<path
					d="M7,11 L15,11 L15,13 L7,13 L5,13 L5,3 L7,3 L7,11 Z"
					id="Combined-Shape"
					fill="#484848"
					transform="translate(10.000000, 8.000000) rotate(-45.000000) translate(-10.000000, -8.000000) "
				></path>
			</g>
		</g>
	</g>
</svg>

后端版本

基于 koa.js

app.js

js
const Koa = require("koa");
const Router = require("koa-router");
const Multer = require("koa-multer");
const KoaStaticCache = require("koa-static-cache");

const app = new Koa();
const upload = Multer({
	storage: Multer.diskStorage({
		destination: function (req, file, cb) {
			cb(null, "./uploads");
		},
		filename: function (req, file, cb) {
			cb(
				null,
				file.originalname.replace(
					/(\.[a-zA-Z0-7]+)$/g,
					($0, $1) => "-" + Date.now() + $1
				)
			);
		},
	}),
});

app.use(
	KoaStaticCache({
		prefix: "/public",
		dir: "./public",
		dynamic: true,
	})
);

const router = new Router();

router.all("*", async (ctx, next) => {
	ctx.set("Access-Control-Allow-Origin", "*");
	ctx.set("Access-Control-Allow-Methods", "POST,OPTIONS");
	await next();
});

router.options("/upload", async (ctx) => {
	ctx.body = "";
});

router.post("/upload", upload.single("file"), async (ctx) => {
	ctx.body = "上传完成";
});

app.use(router.routes());

app.listen(9999);

package.json

json
"dependencies": {
    "koa": "^2.7.0",
    "koa-multer": "^1.0.2",
    "koa-router": "^7.4.0",
    "koa-static-cache": "^5.1.2"
  }

public\index.html

html
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<title>Title</title>
		<style>
			html,
			body {
				height: 100%;
				margin: 0;
			}
			ul {
				margin: 0;
				padding: 0;
				list-style: none;
			}
			.drop_dashed {
				position: fixed;
				left: 0;
				top: 0;
				width: 100%;
				height: 100%;
				border: 5px dashed rgb(0, 0, 0);
				background-color: rgb(255, 255, 255);
				opacity: 0.2;
				box-sizing: border-box;
				display: none;
			}
			.drop_dashed:before {
				position: absolute;
				left: 0;
				top: 50%;
				width: 100%;
				text-align: center;
				font-size: 24px;
				line-height: 24px;
				content: "文件拖放到此处";
			}

			.task_panel {
				display: none;
				position: fixed;
				right: 20px;
				bottom: 20px;
				z-index: 99;
				width: 500px;
				box-shadow: 0 1px 4px 0 rgba(15, 32, 66, 0.2);
				border: 1px solid rgba(5, 13, 27, 0.16);
				overflow: hidden;
			}
			.task_panel:before {
				content: "";
				position: absolute;
				top: 0;
				left: 0;
				right: 0;
				border: 2px solid #00a4ff;
			}

			.icon {
				display: inline-block;
				width: 36px;
				height: 36px;
				line-height: 36px;
				background-repeat: no-repeat;
				background-position: center;
			}
			.task-progress-status-success {
				background-image: url("./images/icon-task-succ.svg");
			}
			.window-fold {
				background-image: url("./images/icon-window-fold.svg");
			}
			.all-close {
				background-image: url("./images/icon-all-close.svg");
			}

			.task_header {
				padding: 20px;
				border-bottom: 1px solid #eeeeee;
			}

			.task_header h4 {
				margin: 0;
				padding: 0;
				font-size: 24px;
			}
			.task_header .icon {
				position: absolute;
				top: 20px;
				cursor: pointer;
				transition: all 0.5s;
			}
			.task_header .icon.window-fold {
				right: 40px;
			}
			.task_header .icon.all-close {
				right: 10px;
			}
			.task_header .icon.window-fold.down,
			.task_header .icon.all-close:hover {
				transform: rotate(180deg);
			}

			.task_body {
				height: 313px;
				overflow: auto;
				transition: height 0.5s;
			}
			.task_body.hide {
				height: 0;
			}
			.task_body li {
				margin-bottom: 2px;
				position: relative;
				height: 20px;
				line-height: 20px;
				padding: 20px;
			}
			.task_body span {
				position: relative;
				z-index: 99;
			}
			.task_body li .task-progress-status {
				position: absolute;
				right: 10px;
				top: 0;
				z-index: 99;
				line-height: 60px;
			}
			.task_body li .task-progress-status .icon {
				position: relative;
				top: 15px;
			}
			.task_body .progress {
				position: absolute;
				left: 0;
				top: 0;
				width: 0%;
				height: 60px;
				background-color: rgba(0, 40, 255, 0.3);
			}
		</style>
	</head>
	<body>
		<div class="drop_dashed"></div>

		<div class="task_panel">
			<div class="task_header">
				<h4></h4>

				<span class="icon window-fold"></span>
				<span class="icon all-close"></span>
			</div>
			<ul class="task_body">
				<li>
					<span>任务一</span>
					<div class="task-progress-status">上传中……</div>
					<div class="progress"></div>
				</li>
				<li>
					<span>任务二</span>
					<div class="task-progress-status">
						<span class="icon task-progress-status-success"></span>
					</div>
					<div class="progress"></div>
				</li>
				<li>
					<span>任务三</span>
					<div class="task-progress-status">
						<span class="icon task-progress-status-success"></span>
					</div>
					<div class="progress"></div>
				</li>
			</ul>
		</div>

		<script src="./js/index.js"></script>
	</body>
</html>

public\js\index.js

js
let dropDashedElement = document.querySelector(".drop_dashed");

/**
 * 当有文件拖放到浏览器的时候,显示 dropDashedElement
 */
document.body.ondragover = function (e) {
	e.dataTransfer.setData("text", "");
	console.log("sdsd");

	dropDashedElement.style.display = "block";
};

images\

icon-all-close.svg

html
<?xml version="1.0" encoding="UTF-8"?>
<svg
	width="20px"
	height="20px"
	viewBox="0 0 20 20"
	version="1.1"
	xmlns="http://www.w3.org/2000/svg"
	xmlns:xlink="http://www.w3.org/1999/xlink"
>
	<!-- Generator: Sketch 48.2 (47327) - http://www.bohemiancoding.com/sketch -->
	<title>icon-all-close</title>
	<desc>Created with Sketch.</desc>
	<defs></defs>
	<g
		id="Artboard-4"
		stroke="none"
		stroke-width="1"
		fill="none"
		fill-rule="evenodd"
	>
		<g id="ic_close_task">
			<g>
				<rect id="Rectangle-22" x="0" y="0" width="20" height="20"></rect>
				<path
					d="M11,9 L17,9 L17,11 L11,11 L11,17 L9,17 L9,11 L3,11 L3,9 L9,9 L9,3 L11,3 L11,9 Z"
					id="Combined-Shape"
					fill="#484848"
					transform="translate(10.000000, 10.000000) rotate(-45.000000) translate(-10.000000, -10.000000) "
				></path>
			</g>
		</g>
	</g>
</svg>

icon-task-succ.svg

html
<?xml version="1.0" encoding="UTF-8"?>
<svg
	width="20px"
	height="20px"
	viewBox="0 0 20 20"
	version="1.1"
	xmlns="http://www.w3.org/2000/svg"
	xmlns:xlink="http://www.w3.org/1999/xlink"
>
	<!-- Generator: Sketch 48.2 (47327) - http://www.bohemiancoding.com/sketch -->
	<title>icon-task-succ</title>
	<desc>Created with Sketch.</desc>
	<defs></defs>
	<g
		id="Artboard-7"
		stroke="none"
		stroke-width="1"
		fill="none"
		fill-rule="evenodd"
	>
		<path
			d="M8.58578644,11.8284271 L5.75735931,9 L4.34314575,10.4142136 L7.17157288,13.2426407 L8.58578644,14.6568542 L15.6568542,7.58578644 L14.2426407,6.17157288 L8.58578644,11.8284271 Z M10,19 C5.02943725,19 1,14.9705627 1,10 C1,5.02943725 5.02943725,1 10,1 C14.9705627,1 19,5.02943725 19,10 C19,14.9705627 14.9705627,19 10,19 Z"
			id="icon-task-succ"
			fill="#01BD88"
		></path>
	</g>
</svg>

icon-window-fold.svg

html
<?xml version="1.0" encoding="UTF-8"?>
<svg
	width="20px"
	height="20px"
	viewBox="0 0 20 20"
	version="1.1"
	xmlns="http://www.w3.org/2000/svg"
	xmlns:xlink="http://www.w3.org/1999/xlink"
>
	<!-- Generator: Sketch 48.2 (47327) - http://www.bohemiancoding.com/sketch -->
	<title>icon-window-fold</title>
	<desc>Created with Sketch.</desc>
	<defs></defs>
	<g
		id="Artboard-3"
		stroke="none"
		stroke-width="1"
		fill="none"
		fill-rule="evenodd"
	>
		<g id="ic_unfold">
			<g
				transform="translate(10.000000, 10.000000) scale(1, -1) translate(-10.000000, -10.000000) "
			>
				<rect id="Rectangle-19" x="0" y="0" width="20" height="20"></rect>
				<path
					d="M7,11 L15,11 L15,13 L7,13 L5,13 L5,3 L7,3 L7,11 Z"
					id="Combined-Shape"
					fill="#484848"
					transform="translate(10.000000, 8.000000) rotate(-45.000000) translate(-10.000000, -8.000000) "
				></path>
			</g>
		</g>
	</g>
</svg>

音频可视化

音频视频操作

Released under the MIT License.