Three.js CSS3D、CSS2D及精灵的区别

在Three.js中,这三种API都可以用来制作标签,那么有什么区别呢,本文进行解惑。

首先,CSS3D和CSS2D都是DOM下的元素,而精灵使用Canvas作为纹理显示。

DOM下的元素,意思就是可以通过CSS或JS这些去获取ID控制样式,更新时调整元素的值就可以了,精灵的只能去Canvas画,包括更新时也如此。

主要区别如下:

CSS3D不面向摄像机,场景缩放时,缩小放大跟随着,不被模型遮挡,通过DOM事件点击

CSS2D面向摄像机,场景缩放时,缩小放大都一样大,不被模型遮挡,通过DOM事件点击。

精灵面向摄像机,场景缩放时,缩小放大跟随着,会被模型遮挡,可以被射线拾取。

CSS2D/CSS3D/精灵,这三种各有不同,看需求去做就是了。

这三种API也可以通过一些算法调整去模拟其他两个的功能,所以也不是绝对的,绝对的就是DOM和Canvas的区别了。

原文:Three.js CSS3D、CSS2D及精灵的区别 - 知乎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值