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. 数据导入:支持从外部文件导入热力图数据
相关推荐
moMo18 小时前
当LLM学会"递纸条",AI是如何调用工具的
人工智能
拾年27518 小时前
大模型的"聪明"从哪来?聊聊 AI 数据集的那些事儿
人工智能·深度学习·机器学习
拾年27518 小时前
从 Prompt 到 Context 再到 Harness:AI 工程化的三年三级跳
人工智能
用户30904636139418 小时前
Claude 不会直接执行你的函数,它只会生成一段结构化的工具调用请求。真正执行函数、访问数据库、请求外部 API 的动作,必须由你的后端完成。
人工智能
不加辣椒18 小时前
第14章 Prompt 编排与优化技术
人工智能
Bolt18 小时前
读懂 Claude Code `/loop` 与编码 Agent 的循环革命
人工智能·程序员·agent
用户2080468045618 小时前
文本分块策略与最佳实践实战指南
人工智能
Delicate18 小时前
前端路由扫盲篇:Hash 模式和 History 模式到底怎么选?
前端
妙码生花18 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十四):眨眼小人登录页制作
前端·javascript·ai编程
妙码生花18 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十三):前端路由初始化
前端·javascript·ai编程