three.js绘制宽度大于1的线,并动态新增顶点

three.js提供的两种线,LineLine2 有所区别。前者只支持宽度为1的线,后者则支持任意线宽。

按照官方示例,可以很容易绘制出已确定顶点位置的线要素(静态的线)

然而很多时候我们都需要动态的往线要素里添加新的顶点,网上查了很多资料,大体思路都是构造新的几何体(LineGeometry)替换已有线对象的几何体,然后重新设置点位(line.geometry = new LineGeometry(); line.geometry.setPositions(positions););或是移除原有的线,然后构造新的线对象。这两种方式原理相似,如果在频繁加入顶点的情况下,会造成明显的性能问题。

我认为更好的做法是对已有线几何体的顶点位置做更新。由于改变顶点缓冲区的大小会耗费性能,基本等同于创建新几何体的开销。因此,初始给一个比较大的顶点容量,这样不用担心顶点不够用要去重新构建几何体对象了。

javascript 复制代码
const maxPoints = 100; // 最多支持的顶点个数
const geometry = new LineGeometry();
geometry.setPositions(new Float32Array(maxPoints * 3));
const material = new LineMaterial({ 
  color: 0xffffff,
  linewidth: 3,
});
const line = new Line2(geometry, material);
scene.add(line);

创建线要素时分配较大的缓冲区用于存放顶点位置

在有新顶点加入时更新缓冲区内的顶点数据就行。Line2 继承了 LineSegments2 ,由一系列线段组成,同时采用实例化方式绘制,因此使用方式和 Line 有些区别。更新 instanceStart 属性改变某一段的起点位置,更新 instanceEnd 属性改变某一段的终点位置,用 instanceCount 属性代替 setDrawRange 方法限制实际绘制的顶点个数(预留的缓冲区较大,实际只用到了一部分)。示例代码如下。

javascript 复制代码
const instanceIndex = pointsCount < 3 ? 0 : (pointsCount - 3) + 1; // 折线的第几段,从0开始计数
if (pointsCount == 1) {
	line.geometry.attributes.instanceStart.setXYZ(instanceIndex, newPosition[0], newPosition[1], newPosition[2]);
} else {
	line.geometry.attributes.instanceEnd.setXYZ(instanceIndex, newPosition[0], newPosition[1], newPosition[2]);
	line.geometry.attributes.instanceStart.setXYZ(instanceIndex + 1, newPosition[0], newPosition[1], newPosition[2]);
	line.geometry.attributes.instanceStart.needsUpdate = true;
	line.geometry.attributes.instanceEnd.needsUpdate = true;
	line.geometry.instanceCount = pointsCount - 1;
}

添加新的顶点位置到线要素

|---|
| |

动态绘制宽度大于1的线

相关推荐
love530love21 小时前
ComfyUI Hunyuan-3D-2 插件安装问题解决方案
人工智能·windows·python·3d·comfyui·hunyuan-3d-2·pygit2
明洞日记1 天前
【CUDA手册002】CUDA 基础执行模型:写出第一个正确的 Kernel
c++·图像处理·算法·ai·图形渲染·gpu·cuda
新启航-光学3D测量1 天前
汽车内饰等部位的光学三维扫描测量逆向-激光三维扫描仪
科技·3d·制造
BFT白芙堂1 天前
灵巧操作的“强力之躯”:Franka Research 3 在 GR-Dexter 通用机器人系统中的深度应用
3d·机器人
明洞日记1 天前
【CUDA手册004】一个典型算子的 CUDA 化完整流程
c++·图像处理·算法·ai·图形渲染·gpu·cuda
杀生丸学AI1 天前
【视频生成】HY-World 1.5:实时延迟和几何一致的交互式世界模型系统(腾讯混元)
人工智能·深度学习·3d·音视频·transformer·三维重建
做cv的小昊1 天前
3DGS加速&压缩指标评测方法、高斯数量变化曲线绘制——Training Time、FPS、Gaussian Number、Peak Memory
笔记·计算机视觉·3d·开源·github·图形渲染·3dgs
传说故事1 天前
【论文自动阅读】How Much 3D Do Video Foundation Models Encode?
人工智能·深度学习·3d
切糕师学AI1 天前
3D打印原理解析
3d
心 爱心 爱1 天前
Point-SRA: Self-Representation Alignment for 3D Representation Learning 论文精读
计算机视觉·3d·重建·三维点云表征学习·流建模