🍺三维数字地球GIS系列相关文章(C++)🍺:
1 【小沐学GIS】基于C++绘制三维数字地球Earth(OpenGL、glfw、glut)第一期
2 【小沐学GIS】基于C++绘制三维数字地球Earth(OpenGL、glfw、glut)第二期
3 【小沐学GIS】基于C++绘制三维数字地球Earth(OpenGL、glfw、glut)第三期
4 【小沐学GIS】基于C++绘制三维数字地球Earth(QT、OpenGL)第四期
5 【小沐学GIS】基于C++绘制三维数字地球Earth(QT、OpenGL、Satellite、卫星轨道模拟)第五期
6 【小沐学GIS】基于C++绘制三维数字地球Earth(OpenG、SolarSystem、太阳系模拟)第六期
7 【小沐学GIS】基于C++绘制三维数字地球Earth(OpenGL、OpenSceneGraph / OSG)第七期
8 【小沐学GIS】基于C++绘制三维数字地球Earth(OpenGL、二维瓦片地图)第八期
9 【小沐学GIS】基于C++绘制三维数字地球Earth(OpenGL、三维瓦片地球)第九期
10 【小沐学GIS】基于C++绘制三维数字地球Earth(osgEarth、三维瓦片地球)第十期
11 【小沐学GIS】基于C++绘制OpenStreetMap地图矢量数据(QT、OpenGL、OSM、Mapbox)第十一期
12 【小沐学GIS】基于C++绘制地形DEM(OpenGL、Terrain、TIFF、hgt)第十二期
🍺GIS系列相关辅助工具如下🍺:
1 【小沐杂货铺】GIS瓦片地图下载工具(高德/天地图/谷歌/必应/OSM/MapBox/ArcGIS)
2 【小沐杂货铺】GIS高程地形tif文件转obj/gltf三维模型工具(geotiff to obj/gltf、3d模型处理)
🍺三维数字地球GIS系列相关文章(其他语言)🍺:
1 【小沐学GIS】基于C#绘制三维数字地球Earth(C#、OpenGL)
2 【小沐学GIS】基于Python绘制三维数字地球Earth(Python、OpenGL、地球/太阳系/卫星)
3 【小沐学GIS】基于Android绘制三维数字地球Earth(Android、OpenGL)
4 【小沐学GIS】基于Golang绘制三维数字地球Earth(Go、OpenGL)
5 【小沐学GIS】基于Rust绘制三维数字地球Earth(Rust、OpenGL)
6 【小沐学GIS】基于Lua绘制三维数字地球Earth(Lua、OpenGL)
7 【小沐学GIS】基于Java绘制三维数字地球Earth(Java、OpenGL)
8 【小沐学GIS】基于Unity3d绘制三维数字地球Earth(Unity3d、OpenGL)
9 【小沐学GIS】基于Vulkan绘制三维数字地球Earth(Vulkan)
10 【小沐学GIS】基于Godot绘制三维数字地球Earth(Godot)
11 【小沐学GIS】基于VTK绘制三维数字地球Earth(VTK)
12 【小沐学GIS】基于Babylon.JS绘制三维数字地球Earth(Babylon.JS、vue、react)
🍺三维数字地球WebGIS系列相关文章(Three.JS)🍺:
1 【小沐学WebGIS】基于Three.JS绘制三维数字地球Earth(WebGL、vue、react)
2 【小沐学WebGIS】基于Three.JS绘制三维太阳系Solar System(three.js、WebGL)第一期
3 【小沐学WebGIS】基于Three.JS绘制三维太阳系Solar System(three.js、WebGL)第二期
4 【小沐学WebGIS】基于Three.JS绘制卫星模拟Satellite Tracker(three.js、vue、react、卫星)
5 【小沐学WebGIS】基于Three.JS绘制OpenStreetMap地图矢量数据(WebGL、OSM、2d/3d)
6 【小沐学WebGIS】基于Three.JS绘制地形DEM(Three.JS、WebGL、TIFF)
7 【小沐学WebGIS】基于Three.JS绘制瓦片地图(Three.JS、WebGL、Mapbox)
8 【小沐学WebGIS】基于Three.JS绘制飞行轨迹Flight Tracker(Three.JS/ vue / react / WebGL)
9 【小沐学WebGIS】基于WebGL绘制三维数字地球Earth(WebGL、地球/卫星/航迹)
10 【小沐学WebGIS】基于WebGL绘制二三维地图地球晨昏效果(Three.JS/ vue / react )
11 【小沐学WebGIS】基于Three.JS绘制三维城市建筑(City / vue / react )
🍺Three.JS系列相关文章如下🍺:
1 【小沐杂货铺】基于Three.JS构建IFC模型浏览器(WebGL、CAD、Revit、IFC)
2 【小沐杂货铺】基于Three.JS绘制汽车展示Car(WebGL、vue、react、autoshow)第1期
3 【小沐杂货铺】基于Three.JS绘制汽车展示Car(WebGL、vue、react、autoshow)第2期
4 【小沐杂货铺】基于Three.JS绘制云图/热力图/CAE物理场渲染(Three.JS、WebGL、CAE、heatmap)
5 【小沐杂货铺】基于Three.js渲染三维风力发电机(WebGL、vue、react、WindTurbine)
6 【小沐杂货铺】基于Three.js渲染三维船舶航行仿真(WebGL、vue、react、ship/boat/vessel)
7 【小沐杂货铺】基于Three.js绘制三维管道Pipe(WebGL、vue、react)
8 【小沐杂货铺】基于Three.js绘制三维机械臂RobotArm(WebGL、vue、react)
9 【小沐杂货铺】基于Three.JS绘制三维海面/海洋/水面(WebGL / vue / react )
10 【小沐杂货铺】基于Three.JS构建三维虚拟教学实践课程(WebGL / vue / react )
11 【小沐杂货铺】基于Three.JS绘制URDF机器人模型(WebGL / vue / react )
12 【小沐杂货铺】基于Three.JS绘制动物世界Animal(WebGL / vue / react )
13 【小沐杂货铺】基于Three.js渲染三维飞行仿真Flight Simulation(WebGL / vue / react )
14 【小沐杂货铺】基于Three.js渲染三维无人机Drone(WebGL / vue / react )
🍺三维数字地球WebGIS系列相关文章(Cesium.JS)🍺:
1 【小沐学WebGIS】基于Cesium.JS绘制卫星轨迹Satellite Tracker(Cesium、vue、react)第1期
2 【小沐学WebGIS】基于Cesium.JS绘制卫星轨迹Satellite Tracker(Cesium、vue、react)第2期
3 【小沐学WebGIS】基于Cesium.JS绘制飞行轨迹Flight Tracker(Cesium/ vue / react / czml / GPX)
4 【小沐学WebGIS】基于Cesium.JS绘制雷达波束/几何体/传感器Sensor(Cesium / vue / react )
5 【小沐学WebGIS】基于Cesium.JS桌面端适配地球卫星App(Cesium.js+QT/C#/MFC/Python/Electron)
6 【小沐学WebGIS】基于Cesium.JS绘制火箭发射Rocket(Cesium、vue、react)
7 【小沐学WebGIS】基于Cesium.JS与TacView ACMI联动仿真通信(Cesium、vue、react)
🍺AI系列相关文章🍺:
1 【小沐学AI】基于AI大模型开发MCP Server服务(Cesium.JS、Three.JS、Blender)

1、简介

1.1 Three.JS

https://threejs.org/
Three.js 是一个基于 WebGL 的 JavaScript 3D 图形库,能够简化浏览器中复杂 3D 场景和动画的开发。它通过封装 WebGL 的底层复杂性,提供了直观的 API,支持几何体创建、材质与贴图、光照与阴影、动画控制等功能,适用于游戏开发、产品展示、教育培训、虚拟现实等多个领域。

npm install three
<!DOCTYPE html>
<html>
<head>
    <title>Three.js 立方体旋转示例</title>
    <style> body { margin: 0; } </style>
</head>
<body>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/three.min.js"></script>
    <script>
        // 初始化场景、相机、渲染器
        const scene = new THREE.Scene();
        const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
        const renderer = new THREE.WebGLRenderer();
        renderer.setSize(window.innerWidth, window.innerHeight);
        document.body.appendChild(renderer.domElement);

        // 创建立方体
        const geometry = new THREE.BoxGeometry(2, 2, 2);
        const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });
        const cube = new THREE.Mesh(geometry, material);
        scene.add(cube);

        // 调整相机位置
        camera.position.z = 5;

        // 动画循环
        function animate() {
            requestAnimationFrame(animate);
            cube.rotation.x += 0.01;
            cube.rotation.y += 0.01;
            renderer.render(scene, camera);
        }
        animate();

        // 窗口大小自适应
        window.addEventListener('resize', () => {
            camera.aspect = window.innerWidth / window.innerHeight;
            camera.updateProjectionMatrix();
            renderer.setSize(window.innerWidth, window.innerHeight);
        });
    </script>
</body>
</html>

1.2 Satellite.JS

Satellite.js 是一个专注于卫星轨道计算的 JavaScript 工具库,基于 SGP4/SDP4 模型实现卫星位置与速度的预测。它通过解析 TLE(两行轨道根数)数据,支持低地球轨道(LEO)和中地球轨道(MEO)卫星的实时跟踪与轨迹模拟,常用于航天工程、天文观测及地理可视化应用。

npm install satellite.js
<!DOCTYPE html>
<html>
<head>
    <title>Satellite.js 卫星位置示例</title>
</head>
<body>
    <script src="https://cdn.jsdelivr.net/npm/satellite.js@4.0.0/dist/satellite.min.js"></script>
    <script>
        // 定义卫星 TLE 数据(示例)
        const tleLine1 = '1 25544U 98067A   21294.56194444  .00000606  00000-0  18532-4 0  9996';
        const tleLine2 = '2 25544  51.6423 208.9163 0004018 152.5268 247.6898 15.48963555302849';

        // 解析 TLE 数据
        const satrec = satellite.twoline2satrec(tleLine1, tleLine2);
        const date = new Date(); // 当前时间

        // 计算卫星位置
        const positionAndVelocity = satellite.propagate(satrec, date);
        const gmst = satellite.gstime(date);
        const positionGeodetic = satellite.eciToGeodetic(positionAndVelocity.position, gmst);

        // 转换为经纬度(角度)
        const longitude = satellite.degreesLong(positionGeodetic.longitude);
        const latitude = satellite.degreesLat(positionGeodetic.latitude);
        const altitude = positionGeodetic.height;

        // 输出结果
        console.log('卫星当前位置:', {
            longitude: longitude.toFixed(4) + '°',
            latitude: latitude.toFixed(4) + '°',
            altitude: altitude.toFixed(2) + ' km'
        });
    </script>
</body>
</html>

2、测试代码(Three.JS)

A3_1_ThreeJS_Satellite_js

在这里插入图片描述
在这里插入图片描述

A3_2_ThreeJS_Satellite_js

在这里插入图片描述

在这里插入图片描述

A3_3_ThreeJS_Satellite_js_tle

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

A3_4_ThreeJS_Satellite_js_tle

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

A3_5_ThreeJS_Satellite_js_tle_python

在这里插入图片描述
在这里插入图片描述

A3_6_ThreeJS_Satellite_js_tle

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

A3_7_ThreeJS_Satellite_js_tle

在这里插入图片描述
在这里插入图片描述

A3_8_ThreeJS_Satellite_js_tle

在这里插入图片描述
在这里插入图片描述

A3_9_ThreeJS_Satellite_js_react_tle

在这里插入图片描述
在这里插入图片描述

A3_10_ThreeJS_Satellite_js_tle

在这里插入图片描述
在这里插入图片描述

A3_11_ThreeJS_Satellite_jsx_react_vite_tle

在这里插入图片描述
在这里插入图片描述

A3_12_ThreeJS_Satellite_js_tle_editor_3d

在这里插入图片描述

在这里插入图片描述

A3_13_ThreeJS_Satellite_js_six_editor_2d

在这里插入图片描述
在这里插入图片描述

A3_14_ThreeJS_Satellite_js_six_editor_3d

在这里插入图片描述
在这里插入图片描述

A3_15_ThreeJS_Satellite_tsx_react_next_tle

在这里插入图片描述
在这里插入图片描述

A3_16_ThreeJS_Satellite_js_tle_obj

在这里插入图片描述
在这里插入图片描述

A3_17_ThreeJS_Satellite_js_tle_N2YO

在这里插入图片描述

A3_18_ThreeJS_Satellite_js

在这里插入图片描述

A3_19_ThreeJS_Satellite_js_2d3d

在这里插入图片描述

A3_20_ThreeJS_Satellite_ts_react

在这里插入图片描述

A3_21_ThreeJS_Satellite_ts_react

在这里插入图片描述

A3_22_ThreeJS_Satellite_ts_react

在这里插入图片描述

A3_23_ThreeJS_Satellite_js_react

在这里插入图片描述

A3_24_ThreeJS_Satellite_js_python

在这里插入图片描述

A3_25_ThreeJS_Satellite_js_react_python

在这里插入图片描述

A3_26_ThreeJS_Satellite_js_react_next

在这里插入图片描述

A3_27_ThreeJS_Satellite_js_react_next

在这里插入图片描述

A3_28_ThreeJS_Satellite_js_react_vite_tle

在这里插入图片描述

A3_29_ThreeJS_Satellite_js_react_leaflet_stellarium

在这里插入图片描述

A3_30_ThreeJS_Satellite_js_tle_python

在这里插入图片描述

A3_31_ThreeJS_Satellite_js_tle

在这里插入图片描述

3、测试代码(WebGL)

C13_1_GIS_3dEarth_WebGL_satelliteJS_WorldWind

在这里插入图片描述
在这里插入图片描述

C13_2_GIS_3dEarth_WebGL_satelliteJS

在这里插入图片描述
在这里插入图片描述

结语

如果您觉得这些文字有一点点用处,请给作者点个赞;╮( ̄▽ ̄)╭
如果您有技术问题探讨,评论处留言。//(ㄒoㄒ)//
谢谢各位童鞋们啦( ´ ▽ ` )ノ ( ´ ▽ `` )っ!
更多精彩文章详见微信公众号:爱阅读的小沐

如需技术探讨 / 软件定制 / 代码分享,请加文章末尾的微信公众号或QQ!
在这里插入图片描述

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐