有关THREE.Raycaster点拾取的问题记录

核心原理代码两句:

1: raycaster.setFromCamera(mouse, camera);    使用鼠标点击位置和camera(创建scene时的)位置,创造一个射线。

2:var intersects = raycaster.intersectObjects(scene.children);    检查射线和目标几何体们是否相交,并返回第一个相交的几何体。

其中camera是创建canvas时建立的相机对象,直接带入即可,该参数用于建立射线的方向的参数,关键是mouse的数据,我们现在人为将canvas的区域认为是一个-1.0~1.0的xoy局部坐标系平面,mouse就代表鼠标点击位置相对于这个局部坐标系的位置数据。但是在实际的鼠标点击事件时,我们只能获取鼠标在浏览器窗口中的相对位置,于是如何通过浏览器窗口中鼠标的点击位置来得到这个canvas中的局部坐标的数据,就是我们获取mouse数据的关键,这个转化计算的三个相关数据如图:

数据①就是我们在html中设定的canvas的style大小:

数据②①都能通过js代码得知:

注意其中的数据②一般都通过js代码获取,而不是通过我人为计算,因为需要考虑canvas的border宽度、canvas在div容器中的自动排列位置等,所以显然,人为计算算了个寂寞。

 

数据③:鼠标点击位置数据是相对于浏览器窗口起点的数据:

由此mouse的计算方法为:

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

aazhoukeaa

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值