尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

Three.js 三维转屏幕坐标教程

Three.js 三维转屏幕坐标教程
📅 发布时间:2026/6/30 16:54:18

三维转屏幕坐标 ·World to Screen· ▶ 在线运行案例

  • 案例合集:三维可视化功能案例(threehub.cn)
  • 开源仓库github地址:https://github.com/z2586300277/three-cesium-examples
  • 400个案例代码:网盘链接

你将学到什么

  • vector.project(camera)世界坐标 → NDC → 屏幕像素
  • 不用 CSS2DRenderer 的手动 DOM 跟随写法
  • 每帧在 rAF 里更新标签位置

效果说明

30 个小立方体,每个上方有一个绝对定位的 DOM(图片 + 文字 D0~D29),随立方体在屏幕上移动而移动,像简易版 3D 标牌。

核心概念

project 管线

世界坐标 (World)

↓ matrixWorld × projectionMatrix NDC 归一化设备坐标 (-1 ~ 1) ↓ 视口变换 屏幕像素 (px)

const worldPosition = mesh.getWorldPosition(new THREE.Vector3());

worldPosition.project(camera);

const screenX = (worldPosition.x + 1) / 2 * width; const screenY = (-worldPosition.y + 1) / 2 * height;

div.style.left = screenX + 'px'; div.style.top = screenY + 'px';

注意Y 轴翻转:NDC 的 y 向上,屏幕 CSS 的 y 向下,故screenY取负。

与 CSS2DRenderer 对比

| 方式 | 本案例 | cssElement | |------|--------|-----------------------------------------------| | 实现 | 手算 project + DOM | CSS2DRenderer 自动投影 | | 深度遮挡 | 无,DOM 总在最上层 | 可选 | | 适用 | 理解原理、轻量标签 | 生产推荐 |

代码要点

import * as THREE from 'three'

import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js'

const DOM = document.getElementById('box')

const scene = new THREE.Scene()

const camera = new THREE.PerspectiveCamera(75, DOM.clientWidth / DOM.clientHeight, 0.1, 1000)

camera.position.set(10, 10, 10)

const renderer = new THREE.WebGLRenderer()

renderer.setSize(DOM.clientWidth, DOM.clientHeight)

DOM.appendChild(renderer.domElement)

const controls = new OrbitControls(camera, renderer.domElement)

controls.enableDamping = true

scene.add(new THREE.AxesHelper(50))

const R = () => Math.random() * 10 - 5

const list = []

for (let i = 0; i < 30; i++) {

const div = createDom('D' + i)

const mesh = new THREE.Mesh(new THREE.BoxGeometry(0.3, 0.3, 0.3), new THREE.MeshBasicMaterial({ color: Math.random() * 0xffffff }))

mesh.position.set(R(), R(), R())

scene.add(mesh)

mesh.div = div

list.push(mesh)

}

function updateCSS2DVisibility() {

list.forEach(mesh => {

const worldPosition = mesh.getWorldPosition(new THREE.Vector3())

worldPosition.project(camera);

const width = renderer.domElement.clientWidth

const height = renderer.domElement.clientHeight

const screenX = (worldPosition.x + 1) / 2 * width

const screenY = (-worldPosition.y + 1) / 2 * height

mesh.div.style.left = screenX + 'px'

mesh.div.style.top = screenY + 'px' })

}

animate()

function animate() {

requestAnimationFrame(animate)

updateCSS2DVisibility()

controls.update()

renderer.render(scene, camera)

}

window.onresize = () => {

renderer.setSize(box.clientWidth, box.clientHeight)

camera.aspect = box.clientWidth / box.clientHeight

camera.updateProjectionMatrix()

}

// 创建dom function createDom(text) {

const div = document.createElement('div')

div.style.position = 'absolute'

const img = document.createElement('img')

img.src = HOST + '/files/author/KallkaGo.jpg'

img.style.width = '50px'

img.style.height = '50px'

div.appendChild(img)

div.innerHTML += text

div.style.color = 'white'

document.body.appendChild(div)

return div

}

完整源码:GitHub

小结

  • 本文提供三维转屏幕坐标完整 Three.js 源码与在线 Demo,建议先运行案例再改 uniform/参数做二次实验
  • 更多 Three.js 实战案例见 three-cesium-examples 合集 与 GitHub 开源仓库

相关新闻

  • 别再手动调参了!用ModelScope的pipeline,5行代码搞定图像风格迁移与视频修复
  • 学机器视觉,别先纠结 OpenCV、HALCON 还是深度学习
  • 保姆级教程:用R语言mediation包搞定NHANES数据的中介效应分析(附完整代码)

最新新闻

  • 如何快速上手Platinum-MD:跨平台MiniDisc无损音乐管理终极指南
  • Apache日志入侵分析实战:从日志定位到攻击链还原
  • AI驱动UI自动化测试:Maestro框架与LLM结合实现10倍效率提升
  • 华硕笔记本性能管家:G-Helper轻量控制工具三分钟上手指南
  • 线上面试实时编程如何与面试官沟通?留学生在线写代码通关指南「蒸汽求职分享」
  • Midscene.js视觉驱动架构:革新UI自动化测试,告别元素定位失效

日新闻

  • 【计算机毕业设计案例】基于 Spring Boot+Vue 的电影售票系统设计与实现 前后端分离架构下影院在线购票管理平台(程序+文档+讲解+定制)
  • 到底 TMD 用哪个: npm, pnpm, Yarn, Bun, Deno? 傻瓜, 当然用 npm 啦
  • Google限制Meta使用Gemini模型 凸显AI授权竞争白热化

周新闻

  • Windows字体自定义终极方案:No!! MeiryoUI完全指南
  • Deepin Boot Maker:告别命令行,3分钟制作Linux启动盘的智能解决方案
  • Plain Craft Launcher 2:重新定义你的Minecraft游戏体验

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号