index.vue 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <template>
  2. <div class="map" id="mapEchart" style="width: 100%; height: 100vh"></div>
  3. </template>
  4. <script lang="ts" setup>
  5. // 引入工具
  6. import geoJson from "@/assets/json/福州市v2_full.json"; //该文件路径改成自己项目中的文件路径即可
  7. import * as echarts from "echarts";
  8. import "echarts-gl"; //3D地图插件
  9. import { onMounted } from "vue";
  10. // 定义echarts方法
  11. const chartMap = () => {
  12. var myChart = echarts.init(document.getElementById("mapEchart"));
  13. // 重点:不要遗漏这句代码!!
  14. echarts.registerMap("zhejiang", geoJson);
  15. // 图表配置项
  16. let option = {
  17. tooltip: {
  18. show: true,
  19. },
  20. //热力图配置项
  21. visualMap: [
  22. {
  23. type: "continuous",
  24. text: ["xxx"],
  25. calculable: true,
  26. max: 250,
  27. inPange: {
  28. color: ["#87aa66", "#eba438", "#d94d4c"],
  29. },
  30. },
  31. ],
  32. //3D地图配置项
  33. geo3D: {
  34. map: "zhejiang",
  35. roam: true,
  36. itemStyle: {
  37. color: "#007aff",
  38. opacity: 0.8,
  39. borderWidth: 0.4,
  40. borderColor: "#000",
  41. // areaColor: '#fff'
  42. },
  43. viewControl: {
  44. autoRotate: true,
  45. autoRotateAfterStill: 3,
  46. distance: 120,
  47. minAlpha: 5, // 上下旋转的最小 alpha 值。即视角能旋转到达最上面的角度。[ default: 5 ]
  48. maxAlpha: 90, // 上下旋转的最大 alpha 值。即视角能旋转到达最下面的角度。[ default: 90 ]
  49. minBeta: -360, // 左右旋转的最小 beta 值。即视角能旋转到达最左的角度。[ default: -80 ]
  50. maxBeta: 360, // 左右旋转的最大 beta 值。即视角能旋转到达最右的角度。[ default: 80 ]
  51. animation: true, // 是否开启动画。[ default: true ]
  52. animationDurationUpdate: 1000, // 过渡动画的时长。[ default: 1000 ]
  53. animationEasingUpdate: "cubicInOut", // 过渡动画的缓动效果。[ default: cubicInOut ]
  54. },
  55. emphasis: {
  56. disabled: true, //是否可以被选中
  57. label: {
  58. //移入时的高亮文本
  59. show: true,
  60. color: "#333", //显示字体颜色变淡
  61. fontSize: 18, //显示字体变大
  62. },
  63. itemStyle: {
  64. color: "#ff7aff", //显示移入的区块变粉色
  65. },
  66. },
  67. label: {
  68. show: true,
  69. position: "top",
  70. color: "#111", //地图初始化区域字体颜色
  71. fontSize: 14,
  72. lineHeight: 16,
  73. },
  74. shading: "lambert",
  75. light: {
  76. //光照阴影
  77. main: {
  78. // color: "#fff", //光照颜色
  79. intensity: 1, //光照强度
  80. //shadowQuality: 'high', //阴影亮度
  81. shadow: true, //是否显示阴影
  82. shadowQuality: "medium", //阴影质量 ultra //阴影亮度
  83. alpha: 55,
  84. beta: 10,
  85. },
  86. ambient: {
  87. intensity: 0.7,
  88. },
  89. },
  90. },
  91. // series: [
  92. // //3D柱状图配置项
  93. // {
  94. // name: "xxx",
  95. // type: "bar3D",
  96. // show: false,
  97. // coordinateSystem: "geo3D",
  98. // barSize: 3,
  99. // shading: "lambert",
  100. // opacity: 1,
  101. // bevelSize: 0.2,
  102. // label: {
  103. // show: false,
  104. // formatter: "{a}",
  105. // },
  106. // //自定义的data数组 value中数组的含义:[杭州的经度or纬度,要展示的3d柱状图数值大小]
  107. // data: [
  108. // { name: "杭州", value: [120.161693, 30.280059, 643] },
  109. // { name: "温州", value: [120.705869, 28.001095, 98] },
  110. // { name: "湖州", value: [120.094566, 30.899015, 72] },
  111. // { name: "嘉兴", value: [120.762045, 30.750912, 131] },
  112. // { name: "绍兴", value: [120.586673, 30.036519, 116] },
  113. // { name: "丽水", value: [119.929503, 28.472979, 40] },
  114. // { name: "衢州", value: [118.880768, 28.941661, 22] },
  115. // { name: "金华", value: [119.654027, 29.084455, 156] },
  116. // { name: "台州", value: [121.426996, 28.662297, 110] },
  117. // { name: "宁波", value: [121.556686, 29.880177, 163] },
  118. // { name: "舟山", value: [122.214339, 29.991092, 20] },
  119. // ],
  120. // },
  121. // ],
  122. };
  123. myChart.setOption(option);
  124. //让可视化地图跟随浏览器大小缩放
  125. window.addEventListener("resize", () => {
  126. myChart.resize();
  127. });
  128. };
  129. onMounted(() => {
  130. // 挂载echart
  131. chartMap();
  132. });
  133. </script>
  134. <style lang="less" scoped></style>