ECharts地图数据压缩-ZigZag算法

ECharts地图数据压缩-ZigZag算法

开发过程中需要都echarts的地图数据进行压缩,经查找资料,发现echarts支持直接使用对GEOJson的coordinates进行 ZigZag压缩后的数据。
开始,尝试使用 mapshare-plus,但这个代码太老了,没有人维护,批量导出GEOJson格式文件的功能是坏的------可能大佬写着写着忘了。。。
修改之后,发现导出地图文件载入ECharts后有地图图形丢失的情况。。。
本人不是专业前端,无奈只有将加密方法单独摘出,万幸测试通过,没有问题

javaScript 复制代码
function convert2Echarts(rawStr) {
    let json = JSON.parse(rawStr);
	// Meta tag 不能删除,ECharts会识别不到
    json.UTF8Encoding = true;
	let features = json.features;
	features.forEach(function (feature) {
		let encodeOffsets = feature.geometry.encodeOffsets = [];
		let coordinates = feature.geometry.coordinates;
		if (feature.geometry.type === 'Polygon') {
			coordinates.forEach(function (coordinate, idx) {
				coordinates[idx] = encodePolygon(
					coordinate, encodeOffsets[idx] = []
				);
			});
		} else if (feature.geometry.type === 'MultiPolygon') {
			coordinates.forEach(function (polygon, idx1) {
				encodeOffsets[idx1] = [];
				polygon.forEach(function (coordinate, idx2) {
					coordinates[idx1][idx2] = encodePolygon(
						coordinate, encodeOffsets[idx1][idx2] = []
					);
				});
			});
		}
	});
	return JSON.stringify(json);
}

function encodePolygon(coordinate, encodeOffsets) {
	let result = '';

	let prevX = quantize(coordinate[0][0]);
	let prevY = quantize(coordinate[0][1]);
	// Store the origin offset
	encodeOffsets[0] = prevX;
	encodeOffsets[1] = prevY;

	for (let i = 0; i < coordinate.length; i++) {
		let point = coordinate[i];
		result += encode(point[0], prevX);
		result += encode(point[1], prevY);

		prevX = quantize(point[0]);
		prevY = quantize(point[1]);
	}

	return result;
}

function encode(val, prev) {
	// Quantization
	val = quantize(val);
	// var tmp = val;
	// Delta
	val = val - prev;

	// 估计是那时候浏览器的bug,我试了客户现场的浏览器,没发现这个问题,就删了,如果需要适配老机型的需要注意
	// if (((val << 1) ^ (val >> 15)) + 64 === 8232) {
		  //WTF, 8232 will get syntax error in js code
	//	  val--;
	// }
	// ZigZag
	val = (val << 1) ^ (val >> 15);
	// add offset and get unicode
	return String.fromCharCode(val + 64);
}

function quantize(val) {
	return Math.ceil(val * 1024);
}

压缩后的地图数据大概是这样:

最后记一个还有地图数据下载地址:阿里云GEOJson地图数据生成器

相关推荐
灵感__idea11 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea13 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd14 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌15 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈15 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫15 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝15 小时前
svg图片
前端·css·学习·html·css3
橘子编程15 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇15 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧16 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint