import styles from './modalMap.scss';// 样式
import React, { Component } from 'react';
import BBDMapChinaDataRange from 'components/common/echarts/BBDMapChinaDataRange';
import {cityDistribute} from 'services/screenDisplay/monitorRisking.js';
import {isNotEmpty} from 'utils/util.js';
//地图上高亮label的图片
const iconJG = 'image://';
export default class Map extends Component {
constructor(props){
super(props);
this.state = {
mapOption: null,
provinceJson: require('../../../../../data/map/' + `${props.provinceName}` + '.json') //引入地图的json数据
};
}
componentDidMount() {
let params = {
province: this.props.provinceName,
type: this.props.type
};
this.getMapData(params);
}
getMapData = async (params) => {
let geoCoordMap = {};
this.state.provinceJson.features.forEach((v) => {
var name = v.properties.name;
geoCoordMap[name] = v.properties.cp;
});
let resData = await cityDistribute(params);
let data = resData.map(line =>{if(isNotEmpty(line.region)){return [{ name: line.region, value: line.companyNum }];} });
data = [...data].filter(p=>{if(isNotEmpty(p)){return p;}});
var convertData = function (data) {
var res = [];
for (var i = 0; i < data.length; i++) {
var dataItem = data[i];
var fromCoord = geoCoordMap[dataItem[0].name];
data[i][0]['value'] = [...fromCoord, data[i][0]['value']];
res.push(data[i][0]);
}
return res;
};
data = await convertData(data);
// 过滤数据,从json数据中找出亮点的坐标
this.setChart(data, params);
}
setChart = async (data, params) => {
const mapType = this.props.provinceName;// "四川省"
let option = {
// backgroundColor: '#FAFAFC',
tooltip: {
show: false
},
geo: {
type: 'map',
map: mapType, // "四川省"
show: true,
roam: false, // 不允许平移
label: {
normal: {
show: false,
textStyle: {
color: '#FFFFFF'
}
},
emphasis: {
textStyle: {
color: '#FE8E5C'
}
}
},
zoom: '0.9',
aspectScale: 0.75,
zlevel: 1,
itemStyle: {
normal: {
areaColor: '#2747CB',
borderColor: '#0A2965',
borderWidth: 1,
shadowColor: '#0A2965',
// shadowBlur: 10,
shadowOffsetY: 10, //阴影偏移的位置 上下
shadowOffsetX: 0 //阴影偏移的位置 左右
},
emphasis: {
borderColor: '#FFFFFF',
areaColor: '#1359B3'
}
}
},
series: [
{
type: 'map',
map: mapType,
show: true,
roam: false, // 不允许平移
symbolSize: 10,
label: {
normal: {
show: true,
position: 'bottom',
formatter: e=>{
if(e.value){
return `\r\r\n\n\n${e.name}`;
}else{
return e.name;
}
},
textStyle: {
color: '#1FF1FF'
}
},
emphasis: {
textStyle: {
color: '#FE8E5C'
}
}
},
zoom: '0.9',
aspectScale: 0.75,
zlevel: 1,
itemStyle: {
normal: {
areaColor: '#2747CB',
borderColor: '#0A2965',
borderWidth: 1,
shadowColor: '#0A2965',
// shadowBlur: 10,
shadowOffsetY: 0
},
emphasis: {
borderColor: 'transparent',
areaColor: '#1359B3'
}
},
data: data
},
{
name: '',
type: 'effectScatter',
coordinateSystem: 'geo',
aspectScale: 0.75,
zoom: 0.9,
// symbol: `image://${mapIcon}`,
symbolOffset: [0, 0], // 标记相对于原本位置的偏移。默认情况下,标记会居中置放在数据对应的位置
tooltip: {
show: true,
backgroundColor: 'transparent',
formatter: (item, index) => {
return `<div class=${styles.mapToolTip}>
<h3>${item.name}</h3>
<p><i class=${styles.iconDot}></i>${params.type === 'source' ? '被传导企业数量' : '源头企业数'}:${item.value[2]}家</p>
</div>`;
}
},
show: true,
roam: false,
data: data,
symbolSize: 20,
symbol: iconJG,
showEffectOn: 'render',
rippleEffect: {
brushType: 'stroke'
},
hoverAnimation: true,
label: {
normal: {
formatter: (e)=>{
return e.value[2];
},
position: 'top',
show: true,
textStyle: {
color: '#E6AB05'
}
},
emphasis: {
textStyle: {
color: '#FE8E5C'
}
}
},
itemStyle: { // 圆点
normal: {
color: '#FBDA35',
shadowBlur: 10,
shadowColor: '#FF5F03'
},
emphasis: {
color: '#FE8E5C',
shadowColor: '#FF5F03'
}
},
zlevel: 2
}
]
};
this.setState({ mapOption: { geoJson: this.state.provinceJson, mapType, option } });
}
render() {
let { mapOption } = this.state;
return (
<div style={{width: '100%', height: '100%'}} >
{
mapOption ? !mapOption.option ? null :
<BBDMapChinaDataRange option={mapOption} />
: null
}
</div>
);
}
}
image.png
下载json 数据的 网址:
ttps://gallery.echartsjs.com/editor.html?c=xmCAi_XNuJ
备注:监测预警-风险传导-点击图标-弹窗-点全国地图,下钻到省份地图
网友评论