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. 样式定制:支持自定义区域样式和边框
相关推荐
神奇的程序员10 小时前
我的软件冲进苹果商店下载榜前 50 了
前端
阳光是sunny10 小时前
别再被 worktree 绕晕了!AI 编程时代你必须掌握的 Git 隔离神器
前端·人工智能·后端
冬奇Lab11 小时前
每日一个开源项目(第148篇):obsidian-skills - Obsidian CEO 亲写的 AI Agent 格式规范,让 Agent 不再破坏你的 Vault
人工智能·开源·资讯
ethantan11 小时前
AI Agent 组成:像人一样思考的智能体
人工智能·程序员·架构
冬奇Lab11 小时前
Workflow 系列(05):评测体系——三层测试结构与 Trace 追踪
人工智能·工作流引擎
万少12 小时前
万少的博客 - 技术分享与解决方案
前端·javascript·后端
ethantan12 小时前
一篇讲解AI Agent 组成:像人一样思考的智能体
人工智能·后端·程序员
Cosolar14 小时前
vLLM 生产级部署完全指南
人工智能·后端·架构
尘世中一位迷途小书童14 小时前
用 Cesium 撸了一个森林火情监控大屏,弧线、粒子、发光效果都齐了
前端·javascript
CodePlayer竟然被占用了14 小时前
被美国政府封杀18天,Claude Fable 5 回来了——但代价是什么?
人工智能