阿里云开放平台geoJson文件下载地址:DataV.GeoAtlas地理小工具系列
1.在项目中通过axios获取数据
axios({
crossDomain: true, //设置cross跨域
methods: "GET",
url: 'geojson文件地址',
}).then((res) => {})
2.地图的声明
this.myChart = this.$echarts.init(document.getElementById("main")); // 初始化echarts
// 想要在echarts中使用自定义的地图数据,首先需要在ecahrts对象中对地图进行注册
this.$echarts.registerMap("地图名称(如:jiangsu)", "放geojson接口返回的数据"); // 注册地图
3.地图的引用
在地图进行注册声明后,可直接在echarts配置中使用series-map进行地图的绘制
option = {
...
series: [{
type: 'map',
mapType: 'jiangsu', //地图名
...
}]
...
}
以上便可以直接实现地图的简单绘制,更丰富的地图样式属性的设置请查询 Echarts文档
5.geo组件的使用
geo为地理坐标系组件,在一些场景需要使用,如地图上某特定坐标点的定位,地图飞线等,可以使用之前注册好的地图数据进行geo组件的声明
option = {
...
geo: {
map: 'jiangsu',//地图名
...
},
...
}
6.展示效果可以结合 echarts地图案例 或者 echarts社区案例 提供的组件中进行改动~
1.项目中涉及到省市区的穿透,所以地区编号是由后端返回的
if (address.type == 4) {
url = `https://geo.datav.aliyun.com/areas_v3/bound/${address.adcode}.json`;
} else {
// 8.1新增
if (
address.adcode == 310100 ||
address.adcode == 110100 ||
address.adcode == 500100 ||
address.adcode == 120100
) {
url = `https://geo.datav.aliyun.com/areas_v3/bound/${address.adcode
.toString()
.slice(0, 2)}0000_full.json`;
} else {
url = `https://geo.datav.aliyun.com/areas_v3/bound/${address.adcode}_full.json`;
}
ps:区的后缀格式和四个直辖市地区编码和数据库有区别,所以这里进行了一层判断
2.效果配置:
const option = {
// backgroundColor: '#013954', // 背景色
visualMap: [
{
seriesIndex: 1,
type: "piecewise",
categories: ["在线设备", "离线设备"],
selectedMode: "multiple",
dimension: 2,
pieces: [
{
label: "离线设备",
value: 0,
},
{
label: "在线设备",
value: 1,
},
],
textStyle: {
color: "white",
},
target: {
inRange: {
color: ["#cccccc", "#56c624"],
symbolSize: 20,
},
},
controller: {
inRange: {
color: ["#cccccc", "#56c624"],
},
},
top: 85,
left: 40,
},
],
tooltip: {
// 提示框
trigger: "item",
formatter: function (param) {
console.log(param, 204);
if (param.data?.name) {
return `${param.data.name}<i class="el-icon-map-location" style="margin-left: 3px"></i><br/>全部设备 ${param.data.value[0]}<br/>在线设备 ${param.data.value[1]} <br/> 离线设备 ${param.data.value[2]}`;
} else {
return param.name;
}
},
backgroundColor: "#34a3ff",
textStyle: {
color: "#fff",
lineHeight: 50,
},
borderColor: "#34a3ff",
padding: [18, 30, 18, 30],
// position:'left' 不会根据鼠标去滚动
},
geo: {
show: true,
map: "SZ",
zoom: 1,
roam: false,
itemStyle: {
normal: {
areaColor: {
type: "radial",
x: 0.5,
y: 0.5,
r: 0.8,
colorStops: [
{
offset: 0,
color: "#09132c", // 0% 处的颜色
},
{
offset: 1,
color: "#274d68", // 100% 处的颜色
},
],
globalCoord: true, // 缺省为 false
},
shadowColor: "#02104c",
shadowOffsetX: 10,
shadowOffsetY: 11,
},
emphasis: {
areaColor: "#2AB8FF",
borderWidth: 0,
color: "green",
label: {
show: false,
},
},
},
},
series: [
{
// ame: '苏州市',
type: "map",
roam: false, // 是否开启鼠标缩放和平移漫游
map: "SZ", // 自定义扩展图表类型
itemStyle: {
borderColor: "rgb(147, 235, 248)",
borderWidth: 1,
areaColor: {
type: "radial",
x: 0.5,
y: 0.5,
r: 0.8,
colorStops: [
{
offset: 0,
color: "#223c94", // 0% 处的颜色
},
{
offset: 1,
color: "#223c94", // 100% 处的颜色
},
],
globalCoord: true, // 缺省为 false
},
emphasis: {
areaColor: "rgb(46,229,206)",
// shadowColor: 'rgb(12,25,50)',
borderWidth: 0.1,
},
},
label: {
show: true,
textStyle: {
color: "white", //地图初始化区域字体颜色
},
emphasis: {
textStyle: {
color: "red", //地图区域字体高亮
},
},
},
data: this.areaList,
},
{
type: "scatter", // 气泡图
coordinateSystem: "geo",
symbolSize: 20,
show: true,
trigger: "item",
itemStyle: {
color: "#58c328",
borderColor: "#ffffff",
borderWidth: "2",
},
tooltip: {
position: "top",
//设备经纬度坐标
formatter: function (param) {
return param.data[3];
},
},
data: this.deviceList,
},
],
};
3.地图事件穿透
// 地图事件穿透
this.myChart.on("click", this.debounceClick);
// 地图防抖点击
debounceClick(params) {
if (this.timeout) {
clearTimeout(this.timeout);
}
this.timeout = setTimeout(() => {
this.echartsMapClick(params);
}, 300);
},
// 地图下钻
echartsMapClick(params) {
const result = this.areaList.find((item) => {
return item.adCode == params.data.adCode;
});
if (!result || !result.value[0]) return; // 判断是否有下钻数据
this.getData(params.data.adCode); // getData是封装的获取地图以及数据的方法
},
4.地图返回事件
goBack() {
if (this.areas.length === 1) return;
this.areas.pop();
this.getData(this.areas[this.areas.length - 1]);
},
我的方法是通过点击地图下钻的时候push()添加当前code,然后再通过pop()删除,最后再调用封装的getData()方法获取当前地图以及数据。
接下来是效果展示:
文章浏览阅读2w次,点赞7次,收藏51次。四个步骤1.创建C++ Win32项目动态库dll 2.在Win32项目动态库中添加 外部依赖项 lib头文件和lib库3.导出C接口4.c#调用c++动态库开始你的表演...①创建一个空白的解决方案,在解决方案中添加 Visual C++ , Win32 项目空白解决方案的创建:添加Visual C++ , Win32 项目这......_c#调用lib
文章浏览阅读4.6k次。苹方字体是苹果系统上的黑体,挺好看的。注重颜值的网站都会使用,例如知乎:font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Microsoft YaHei, Source Han Sans SC, Noto Sans CJK SC, W..._ubuntu pingfang
文章浏览阅读159次。表单表单概述表单标签表单域按钮控件demo表单标签表单标签基本语法结构<form action="处理数据程序的url地址“ method=”get|post“ name="表单名称”></form><!--action,当提交表单时,向何处发送表单中的数据,地址可以是相对地址也可以是绝对地址--><!--method将表单中的数据传送给服务器处理,get方式直接显示在url地址中,数据可以被缓存,且长度有限制;而post方式数据隐藏传输,_html表单的处理程序有那些
文章浏览阅读1.2k次。使用说明:开启Google的登陆二步验证(即Google Authenticator服务)后用户登陆时需要输入额外由手机客户端生成的一次性密码。实现Google Authenticator功能需要服务器端和客户端的支持。服务器端负责密钥的生成、验证一次性密码是否正确。客户端记录密钥后生成一次性密码。下载谷歌验证类库文件放到项目合适位置(我这边放在项目Vender下面)https://github.com/PHPGangsta/GoogleAuthenticatorPHP代码示例://引入谷_php otp 验证器
文章浏览阅读4.3k次,点赞5次,收藏11次。matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距
文章浏览阅读2.2k次。①Storage driver 处理各镜像层及容器层的处理细节,实现了多层数据的堆叠,为用户 提供了多层数据合并后的统一视图②所有 Storage driver 都使用可堆叠图像层和写时复制(CoW)策略③docker info 命令可查看当系统上的 storage driver主要用于测试目的,不建议用于生成环境。_docker 保存容器
文章浏览阅读834次,点赞27次,收藏13次。网络拓扑结构是指计算机网络中各组件(如计算机、服务器、打印机、路由器、交换机等设备)及其连接线路在物理布局或逻辑构型上的排列形式。这种布局不仅描述了设备间的实际物理连接方式,也决定了数据在网络中流动的路径和方式。不同的网络拓扑结构影响着网络的性能、可靠性、可扩展性及管理维护的难易程度。_网络拓扑csdn
文章浏览阅读1.8k次,点赞5次,收藏8次。IOS系统Date的坑要创建一个指定时间的new Date对象时,通常的做法是:new Date("2020-09-21 11:11:00")这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。在IOS年月日中间的横岗许换成斜杠,也就是new Date("2020/09/21 11:11:00")通常为了兼容IOS的这个坑,需要做一些额外的特殊处理,笔者在开发的时候经常会忘了兼容IOS系统。所以就想试着重写Date函数,一劳永逸,避免每次ne_date.prototype 将所有 ios
文章浏览阅读5.3k次。方法一:用PLSQL Developer工具。 1 在PLSQL Developer的sql window里输入select * from test for update; 2 按F8执行 3 打开锁, 再按一下加号. 鼠标点到第一列的列头,使全列成选中状态,然后粘贴,最后commit提交即可。(前提..._excel导入pl/sql
文章浏览阅读83次。Git常用命令速查手册1、初始化仓库git init2、将文件添加到仓库git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件...
文章浏览阅读202次。分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120
文章浏览阅读1.8k次。版权声明:转载请注明出处 http://blog.csdn.net/irean_lau。目录(?)[+]1、缺省构造函数。2、缺省拷贝构造函数。3、 缺省析构函数。4、缺省赋值运算符。5、缺省取址运算符。6、 缺省取址运算符 const。[cpp] view plain copy_空类默认产生哪些类成员函数