three.js - 为什么three.js仅在定义新几何时才更新几何?
问题描述
我有一个关于使用 dat.gui 在three.js 中更新几何的问题。
我希望我可以通过按对象更新与几何相关的值来更新几何,如下所示。
gui.add(parameter, 'width')
.min(1)
.max(10)
.step(0.1)
.name('cubeWidth')
.onChange((value) => {
mesh.geometry.dispose();
geometry.parameters.width = parameter.width
console.log(mesh)
})
但是,只有当我像下面这样重新定义几何图形时,它才会更新几何图形。
mesh.geometry = new THREE.BoxGeometry(parameter.width, 1, 1);
这对我来说有点奇怪,因为即使我记录了几何数据,它们都显示了更新后的宽度值,如下所示。
为什么只有第一种方法有效而另一种方法无效?
解决方案
几何.参数.宽度=参数.宽度
这没有效果。只有在创建几何图形时才会处理参数。该parameters
属性实际上是只读的。
您的问题的解决方案确实是使用新的参数集重新创建几何图形。
推荐阅读
- python - Python:将消息编码为 base64 以解决“!” 和行长问题
- excel-formula - 不保留条件格式
- python - Flask-Sockets keepalive
- css - 使用调整大小的屏幕查看页面时,屏幕右侧显示黑色背景
- r - 具有 2 个键(不是层次结构)的 tsibble,以一年中的一周为索引
- amazon-web-services - 用户数据未在私有 VPC 子网中的 EC2 实例上运行
- java - 如何在java中读取文本文件中的列数
- c# - 如何在 Azure Dev Ops 上禁用代码签名 - 仍然收到“使用文件 mssharedlibsn1024.snk 中的公钥对输出进行错误签名 - 找不到文件”
- javascript - 如何设置新的 TextInput 值?
- pandas - Pandas 根据列表中的匹配子字符串拆分字符串