Three.js 3D 地图可视化 | 三维可视化 / AI 提示词

Three.js 3D 地图可视化 | 三维可视化 / AI 提示词

📋 AI 提示词

prompt 复制代码
使用 Three.js 加载 GeoJSON 地图数据,通过坐标转换和 ExtrudeGeometry 创建 3D 地图效果,实现地理数据的 3D 可视化。

🖼️ 效果预览


🎮 案例演示

立即体验


效果拆解

效果 实现方式
GeoJSON加载 使用fetch API加载地图数据
坐标转换 将经纬度转换为平面坐标
形状创建 使用Shape和Path创建地图轮廓
挤压几何体 使用ExtrudeGeometry创建3D厚度
随机颜色 为每个区域分配随机颜色
中心定位 计算并设置地图中心点

核心技术点

1. GeoJSON加载和处理

javascript 复制代码
const geoJson = await fetch(
  FILE_HOST + '/files/json/guangdong.json'
).then((res) => res.json());

geoJson.features.forEach((i) => {
  if (i.geometry.type === "MultiPolygon")
    i.geometry.coordinates.forEach((j) =>
      j.forEach((z) => createShapeWithCoord(z, group, i))
    );
  else if (i.geometry.type === "Polygon")
    i.geometry.coordinates.forEach((j) =>
      createShapeWithCoord(j, group, i)
    );
});

translationOriginForGroup(group);
scene.add(group);

2. 坐标转换

javascript 复制代码
function coordToVector2(coord, slace = 10000) {
  const [lng, lat] = coord;

  const x = (lng * 20037508.34) / 180;

  let y =
    Math.log(Math.tan(((90 + lat) * Math.PI) / 360)) / (Math.PI / 180);

  y = (y * 20037508.34) / 180;

  return new THREE.Vector2(x / slace, y / slace);
}

3. 形状创建

javascript 复制代码
function createShapeWithCoord(coordinates, group, info = null) {
  const curvePoints = coordinates.map((k) => coordToVector2(k));

  const path = new THREE.Path(curvePoints);

  const shape = new THREE.Shape();

  shape.path = path;

  shape.curves.push(path);

  const parameters = {
    bevelEnabled: false,
    bevelThickness: 0,
    bevelSize: 0,
    bevelOffset: 0,
    depth: 2,
    bevelEnabled: false,
  };

  const geometry = new THREE.ExtrudeGeometry(shape, parameters);

  const material = new THREE.MeshBasicMaterial({
    color: 0xffffff * Math.random(),
    transparent: true,
  });

  const mesh = new THREE.Mesh(geometry, material);

  const boundingBox = new THREE.Box3().setFromObject(mesh);

  boundingBox.getCenter(mesh.position);

  mesh.geometry.center();

  mesh.info = info;

  group.attach(mesh);
}

4. 中心点设置

javascript 复制代码
function translationOriginForGroup(group) {
  const boundingBox = new THREE.Box3().setFromObject(group);

  boundingBox.getCenter(group.position);

  group.traverse((c) => {
    c.isMesh && c.position.sub(group.position);

    c.initTranslate = c.position.clone();
  });

  group.position.set(0, 0, 0);
}

调试技巧

  1. 坐标缩放:调整slace参数控制地图缩放比例
  2. 挤压深度:修改depth参数改变3D厚度
  3. 颜色设置:调整颜色生成算法获得更好的视觉效果
  4. 中心定位:检查translationOriginForGroup函数确保地图居中
  5. 坐标转换:验证坐标转换公式的准确性

扩展思路

  1. 交互效果:添加鼠标悬停高亮显示
  2. 数据标注:在地图上添加数据标签
  3. 高度映射:根据数据值调整区域高度
  4. 动画效果:实现地图的飞入或旋转动画
  5. 多层级:支持加载不同层级的地图数据
  6. 样式定制:支持自定义区域样式和边框
相关推荐
爱怪笑的小杰杰1 小时前
Leaflet 高性能大数据量图圆:彻底解决缩放/拖拽偏移问题
大数据·前端·vue.js·贴图
Soari1 小时前
oh-my-pi:一款面向终端的 AI Coding Agent,集成 LSP、Debugger、Subagents 与多模型路由
人工智能·里氏替换原则
Upsy-Daisy1 小时前
AI Agent 项目学习笔记(十一):TerminateTool、工具调用闭环与安全边界
人工智能·笔记·学习
羑悻的小杀马特1 小时前
工业时序数据选型的几点思考:从存储成本与查询延迟说起
数据库·人工智能
英辰朗迪AI获客1 小时前
Hy3-Preview-20260421 深度评测与实战指南
人工智能
WL_Aurora1 小时前
大数据技术之SparkCore
大数据·前端·spark·rdd
互联科技报1 小时前
专业的一站式数字孪生软件,解决高校无线网络仿真难题
人工智能
openFuyao1 小时前
以开源之力,突破多样化算力困局——openFuyao开源一周年背后的故事
人工智能·云原生·开源·openfuyao·多样化算力·集群软件
shchojj1 小时前
Software Applications - Lifecycle of a generative AI project
人工智能