config.ts 2.09 KB
import { echartOptionProfixHandle, PublicConfigClass } from '@/packages/public'
import { AddThreeDimensionalMapConfig } from './index'
import { chartInitConfig } from '@/settings/designSetting'
import { CreateComponentType } from '@/packages/index.d'
import cloneDeep from 'lodash/cloneDeep'
import dataMaps from './data.json'

//省市区枚举
export const enum areaEnum {
  PROVINCE = 'PROVINCE', //省份
  CITY = 'CITY', //城市
  COUNTY = 'COUNTY', //县
  COUNTRY = 'COUNTRY', //国家
  TOWN = 'TOWN' //镇
}

export const includes = []

export const option = {
  iconColor: 'black',
  showIcon: false,
  iconDistanceRight: 20,
  iconDistanceTop: 20,
  drillingIn: false,
  dataset: dataMaps,
  mapRegion: {
    adcode: 'china',
    showHainanIsLands: true,
    saveSelect: {
      levelStr: areaEnum.COUNTRY
    }
  },
  tooltip: {
    show: true
  },
  geo3D: {
    show: false, // 隐藏该层,为true时会导致出现两个地图
    map: 'centerMap',
    roam: true,
    regionHeight: 0,
    emphasis: {
      label: {
        show: true,
        textStyle: {
          color: '#000',
          fontSize: 14
        }
      },
      itemStyle: {
        color: '#ff0'
      }
    }
  },
  series: [
    {
      type: 'map3D',
      map: 'centerMap',
      name: 'centerMap',
      regionHeight: 3,
      label: {
        show: true,
        textStyle: {
          color: '#fff',
          fontSize: 14
        }
      },
      itemStyle: {
        color: 'green',
        borderWidth: 0.8,
        borderColor: 'blue'
      },
      data: []
    },
    {
      name: 'scatter3D',
      type: 'scatter3D',
      coordinateSystem: 'geo3D',
      symbol: 'circle',
      symbolSize: 20,
      animation: true,
      data: dataMaps
    }
  ]
}
export const MapDefaultConfig = { ...option }
export default class Config extends PublicConfigClass implements CreateComponentType {
  public key: string = AddThreeDimensionalMapConfig.key
  public attr = { ...chartInitConfig, w: 750, h: 800, zIndex: -1 }
  public chartConfig = cloneDeep(AddThreeDimensionalMapConfig)
  public option = echartOptionProfixHandle(option, includes)
}