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. 样式定制:支持自定义区域样式和边框
相关推荐
问心无愧05137 小时前
ctf show web入门160 161
前端·笔记
秋97 小时前
从 Python 后端工程师转型 AI Engineer(AI 工程化)的完整补课清单(2026实战版)
开发语言·人工智能·python
李小白667 小时前
第四天-WEB服务器基本原理,IIS服务
运维·服务器·前端
啦啦啦_99997 小时前
5. 迁移学习
人工智能·机器学习·迁移学习
A.说学逗唱的Coke7 小时前
【AI·Coding】TDD × SDD × AI Coding:从“测试驱动“到“规范驱动“的智能协作实践
人工智能·驱动开发·tdd
云烟成雨TD7 小时前
Spring AI Alibaba 1.x 系列【78】沙箱(Sandbox)
java·人工智能·spring
humcomm7 小时前
AI编程时代新前端职位
前端·ai编程
tq10867 小时前
基于SLIP的防幻觉的指南
人工智能
好家伙VCC8 小时前
Web Components主题热切换方案揭秘
java·前端
甲维斯8 小时前
Kimi版超级玛丽效果“惊人”,配额不足5厘米!
前端·人工智能