Three.js 3D 热力图效果 | 三维可视化 / AI 提示词

Three.js 3D 热力图效果 | 三维可视化 / AI 提示词

📋 AI 提示词

prompt 复制代码
使用 Three.js 和 heatmap.js 库创建 3D 热力图效果,通过 ShaderMaterial 将热力图数据转换为 3D 高度可视化。

🖼️ 效果预览


🎮 案例演示

立即体验


效果拆解

效果 实现方式
热力图生成 使用heatmap.js生成2D热力图
纹理转换 将热力图Canvas转换为Three.js纹理
高度映射 通过着色器将热力值映射为高度
颜色显示 根据高度值显示对应颜色
透明度控制 根据高度值调整透明度
参数调节 使用GUI控制高度比例

核心技术点

1. 热力图生成

javascript 复制代码
const getRandom = (max, min) => Math.round((Math.random() * (max - min + 1) + min) * 10) / 10

var heatmap = h337.create({
  container: document.createElement('div'),
  width: 256,
  height: 256,
  blur: '0.8',
  radius: 10
});

var i = 0, max = 10, data = [];
while (i < 2000) {
  data.push({ x: getRandom(1, 256), y: getRandom(1, 256), value: getRandom(1, 6) });
  i++;
}

heatmap.setData({
  max: max,
  data: data
});

2. 纹理创建

javascript 复制代码
const texture = new THREE.CanvasTexture(heatmap._renderer.canvas);

3. 着色器材质

javascript 复制代码
const geometry = new THREE.PlaneGeometry(50, 50, 1000, 1000);
geometry.rotateX(-Math.PI * 0.5);

const material = new THREE.ShaderMaterial({
  uniforms: {
    heightMap: { value: texture },
    heightRatio: { value: 5 }
  },
  vertexShader: `	
    uniform sampler2D heightMap;
    uniform float heightRatio;
    varying vec2 vUv;
    varying float hValue;
    varying vec3 cl;
    void main() {
      vUv = uv;
      vec3 pos = position;
      cl = texture2D(heightMap, vUv).rgb;
      hValue = texture2D(heightMap, vUv).r;
      pos.y = hValue * heightRatio;
      gl_Position = projectionMatrix * modelViewMatrix * vec4(pos,1.0);
    }`,
  fragmentShader: `
    varying float hValue;
    varying vec3 cl;
    void main() {
      float v = abs(hValue - 1.);
      gl_FragColor = vec4(cl, .8 - v * v) ; 
    }`,
  transparent: true,
})

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

4. GUI控制

javascript 复制代码
new gui.add(mesh.material.uniforms.heightRatio, "value", 1, 15).name("heightRatio")

调试技巧

  1. 高度比例:调整heightRatio参数改变3D高度
  2. 热力点数量:修改循环次数控制热力点密度
  3. 热力点强度:调整value参数改变热力点强度
  4. 网格密度:调整PlaneGeometry的分段数获得更精细的效果
  5. 透明度范围:修改fragmentShader中的透明度计算公式

扩展思路

  1. 动态数据:实现热力图数据的实时更新
  2. 交互效果:鼠标悬停显示具体数值
  3. 多层数据:叠加多个热力图层
  4. 时间序列:实现热力图随时间变化的效果
  5. 3D交互:添加点击选择和缩放功能
  6. 数据导入:支持从外部文件导入热力图数据
相关推荐
海盗12341 小时前
科技与科学领域每日新闻摘要-2026年5月20日
人工智能·科技
听风吹等浪起1 小时前
基于改进ResUNet的植物叶片语义分割系统设计与实现
人工智能·深度学习·分类
vivo互联网技术1 小时前
VAPD AgentKit:可组合 Agent 前端通用库实践
前端·ai·架构·agent
lichenyang4531 小时前
鸿蒙聊天 Demo 练习 02:AI 回复打字机输出与 ForEach 刷新问题
前端
Royzst1 小时前
图书管理案例
java·开发语言
得物技术1 小时前
Claude Code Harness 工程:数仓侧落地方案|得物技术
数据库·人工智能·ai编程
Hello--_--World1 小时前
利用CDN进行首屏优化。能不能看CDN与本地服务器谁快用谁?
运维·服务器·前端·javascript·vite
隔窗听雨眠1 小时前
AI开发者的网络卡点:Anthropic连接超时实战避坑
网络·人工智能
我的世界洛天依1 小时前
胡桃讲编程 | 外挂的另一种方法与防御 —— 对象(JS ES262)
开发语言·javascript·ecmascript