CSS2DObject无法触发点击事件

three.js@0.13X版本后,CSS2DRenderer中的 CSS2DObject无法触发点击事件。 原因是OrbitControls中会对绑定的Dom进行事件监听,并且阻止穿透。

解决办法是:

  • 在实例化 OrbitControls 时绑定renderer(而不是CSS2DRenderer)
  • 这时候OrbitControls无法转动,因为CSS2DRenderer的图层较高,所以还需要给 CSS2DRendererpointerEvents='none'
  • 再给 CSS2DObject的el的pointerEvents='auto'
Typescript 复制代码
const camera = new THREE.PerspectiveCamera(fov, aspect, near, far)
const renderer = new THREE.WebGLRenderer({ antialias: true, alpha: true })
renderer.setSize(element.offsetWidth, element.offsetHeight)
element.appendChild(renderer.domElement)
const CSSRenderer = new CSS2DRenderer()
CSSRenderer.setSize(element.offsetWidth, element.offsetHeight)
CSSRenderer.domElement.style.position = 'absolute'
CSSRenderer.domElement.style.top = '0px'
element.appendChild(CSSRenderer.domElement)
const control = new OrbitControls(camera, renderer.domElement) // important!
CSSRenderer.domElement.style.pointerEvents = 'none' // important!
// CSSObject
const div = document.createElement("div")
div.style.pointerEvents = "auto" // important!
const object = new CSS2DObject(div)
相关推荐
戳气球的爱玛镇皇后2 分钟前
BroadcastChannel 使用总结
前端
戳气球的爱玛镇皇后4 分钟前
wps加载项不同窗口间通信
前端
心在飞扬30 分钟前
LangGraph 基础知识
前端·后端
Lee川1 小时前
深入浅出JavaScript事件机制:从捕获冒泡到事件委托
前端·javascript
光影少年1 小时前
async/await和Promise的区别?
前端·javascript·掘金·金石计划
恋猫de小郭1 小时前
Flutter 发布官方 Skills ,Flutter 在 AI 领域再添一助力
android·前端·flutter
心在飞扬1 小时前
工具调用出错捕获提升程序健壮性
前端·后端
HelloReader1 小时前
Tauri 命令作用域(Command Scopes)精细化控制你的应用权限
前端
心在飞扬1 小时前
基于工具调用的智能体设计与实现(*)
前端·后端
心在飞扬1 小时前
函数调用快速提取结构化数据使用技巧
前端·后端