首页 前端知识 echarts实现3D地球模式--3D线

echarts实现3D地球模式--3D线

2024-05-03 18:05:16 前端知识 前端哥 548 227 我要收藏

前言:基于echarts实现3D地球自动旋转展示及不同坐标点相互连线

这里主体基于echarts,需引入依赖资源 echarts.min.js,echarts-gl.min.js

效果如下:
在这里插入图片描述

代码如下:

依赖资源

  <script src="./echarts.min.js"></script>
  <script src="./echarts-gl.min.js"></script>

HTML

	<div id="earth" style="width: 100%; height: 100%"></div>

CSS

	* {
		margin: 0;
		padding: 0;
	}
	html,
	body {
		height: 100%;
		width: 100%;
	}

JS

	const dom = document.getElementById("earth")
    let myChart = echarts.init(dom);
    let baseTexture = null
    let option = null
    let geoJson = []

    // 绘制球体
    const drawEarth = () => {
      option = {
        backgroundColor: "#013954",
        tooltip: {
          trigger: "item",
        },
        globe: {
          baseTexture: "img2.jpg", //地球的纹理
          heightTexture: "img2.jpg", //地图的高度纹理
          displacementScale: 0, //地球顶点位移的大小
          shading: 'realistic', //着色效果,真实感渲染
          realisticMaterial: { //真实感渲染配置
            roughness: 1 //材质的粗糙度
          },
          postEffect: { //后处理特效配置
            enable: true
          },
          globeRadius: 150,
          environment: "#000",
          shading: "color",
          light: {
            // 光照阴影
            main: {
              color: "#fff", // 光照颜色
              intensity: 1, // 光照强度
              //shadowQuality: "high", //阴影亮度
              //shadow: true, // 是否显示阴影
              alpha: 40,
              beta: -30,
            },
            ambient: {
              color: "#fff",
              intensity: 1,
            },
          },
          viewControl: {
            alpha: 30,
            beta: 160,
            autoRotate: true,
            autoRotateAfterStill: 10,
            distance: 240,
          },
        },
        series: [{
          name: "lines3D",
          type: "lines3D",
          coordinateSystem: "globe",
          effect: {
            show: true,
          },
          blendMode: "lighter",
          lineStyle: {
            width: 2,
          },
          data: [],
          silent: false,
        }, ],
      };
      // 随机数据 i控制线数量
      for (let i = 0; i < 30; i++) {
        option.series[0].data = option.series[0].data.concat(randomData());
      }
      myChart.setOption(option, true);
    }

    // 随机生成起始及终点经纬度坐标
    const randomData = () => {
      let name = "随机点" + Math.random().toFixed(5) * 100000;
      // 起点经纬度-北京
      let longitude = 116.2,
        latitude = 39.56;
      // 随机终点经纬度
      let longitude2 = Math.random() * 360 - 180;
      let latitude2 = Math.random() * 180 - 90;
      return {
        coords: [
          [longitude, latitude],
          [longitude2, latitude2],
        ],
        value: (Math.random() * 3000).toFixed(2),
      };
    }

    // 初始化入口
    drawEarth()

贴图奉上

在这里插入图片描述

echarts官方文档地址:https://echarts.apache.org/zh/index.html

简单记录如有问题或更优解还请不要吝啬的分享出来,此结。

转载请注明出处或者链接地址:https://www.qianduange.cn//article/6816.html
标签
评论
发布的文章

JQuery中的load()、$

2024-05-10 08:05:15

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!