美文网首页
省份地图

省份地图

作者: 家有饿犬和聋猫 | 来源:发表于2020-04-20 15:14 被阅读0次
    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

    image.png

    备注:监测预警-风险传导-点击图标-弹窗-点全国地图,下钻到省份地图

    相关文章

      网友评论

          本文标题:省份地图

          本文链接:https://www.haomeiwen.com/subject/dcldihtx.html