ThreeJs模拟工厂生产过程四

简介: 这篇文章详细说明了如何在Three.js中为模拟的工厂产线添加警戒线,以增强产线模型的真实感和安全性表现,通过使用`PlaneGeometry`来创建并定位这些警戒线。

上节解决了模型多会存在的模型卡顿问题,用了模型整合来结局,这节继续这个模型的完善,很多时候可以在产线看到地上会画警戒线,防止工作人员越界以被机器伤到,所以会在机器的危险区域用警戒线框起来,那么这节做绘制警戒线的功能。

首先我们需要先针对一个产线做警戒线,然后再加到循环中给五个产线都加上警戒线。加警戒线我们使用PlaneGeometry对象,这是一个专门绘制2维的对象,他的属性如下

//平面的宽度(width)和高度(height),以及宽度分段数(widthSegments)和高度分段数(heightSegments)

new THREE.PlaneGeometry(width, height, widthSegments, heightSegments);

上面的分段数属性并不是吧这个线段分成多少段,而是指里面组成的三角形数量,你可以理解为分段数越多这个形状绘制的越丝滑,但是对性能的消耗也越多。下面我们绘制一条警戒线,一条产线的警戒线有四条,分别上下左右,我们先绘制上下部分


      //创建警戒线的贴图
      let LineMat = new THREE.MeshLambertMaterial();
      new THREE.TextureLoader().load( "/static/images/line.png", function( map ) {
        LineMat.map = map;
        LineMat.needsUpdate = true;
      } );
      //绘制一条横着的警戒线
      let geometryTop = new THREE.PlaneGeometry( width, length );
      let objTop = new THREE.Mesh( geometryTop, LineMat );
      objTop.position.set(x,y,z);
      this.scene.add( objTop );
      //绘制一条横着的警戒线
      let objBottom = objTop.clone()
      objBottom.position.set(x+lineLength,y,z);
      this.scene.add( objBottom );

因为上下的警戒线是相同的,所以这里绘制好顶部的警戒线,下面的直接clone一下,再改个位置就好了,贴图我找了一个黄色的图片,作为纹理贴图,这样我认为效果会好点。

下面绘制左右两侧的,左右两侧的也是相同的长度和宽度,所以也采用clone的方式做出另外一条,但是左右两侧的位置要向y正方向和负方向各偏移半个宽度。代码如下:

 let lineLength = this.conveyor.lang + 10;//加长一点警戒线的长度保证完全把产线包含在内
//绘制一条横着的警戒线
      let objBottom = objTop.clone()
      objBottom.position.set(x+lineLength,y,z);
      this.scene.add( objBottom );
      //绘制两条竖着的警戒线
      let geometry1 = new THREE.PlaneGeometry( width, lineLength ,2,5);
      let obj1 = new THREE.Mesh( geometry1, LineMat );
      obj1.rotation.z = -Math.PI / 2.0;
      obj1.position.set(x+lineLength/2,y+length/2-1,z);
      this.scene.add( obj1 );
      //因为左右两侧的警戒线只是在位置上有区别,所以可以clone一条出来修改位置就好了
      let obj2 = obj1.clone();
      obj2.position.set(x+lineLength/2,y-length/2+1,z);
      this.scene.add( obj2 );

这样就绘制出一个警戒线长方体把产线框在里面了,下面就只需要把它加到循环里,给所有的产线都加上警戒线就好了

 initMachine(){ // 初始哈设备
      for (let i = 0; i < 5; i++) {
        for (let i = 0; i < this.machineList.length; i++) {
          let geometry = new THREE.BoxGeometry(15,15,20);//创建一个几何体
          let material = new THREE.MeshBasicMaterial({color:'#CCCCCC'});//创建材质
          let box = new THREE.Mesh(geometry, material);//创建网格模型
          box.position.set(this.begin.x+20+35*i,this.begin.y,this.begin.z)
          this.initMachineName(this.begin.x+20+35*i,this.begin.y,10,this.machineList[i])
          this.initConveyor(this.begin.x+(this.conveyor.lang/2),this.begin.y,this.begin.z,6,this.conveyor.lang);//前三个参数是xyz,后面两个一个是传送带宽度,一个是传送带长度
          this.scene.add(box);//添加到场景中
          this.addPlane(this.begin.x-5,this.begin.y,this.begin.z-9,2,30);//添加警戒线
        }
        this.begin.y = this.begin.y +60
      }
    },

效果如下:

这样所有的警戒线都加好了,车间也更完善了一点,好了警戒线的添加方法就到这里,如果需要添加其他的警戒线也是用类似的方法就好了

相关文章
|
编解码 IDE 算法
2023年电赛---运动目标控制与自动追踪系统(E题)发挥题思路
2023年电赛---运动目标控制与自动追踪系统(E题)发挥题思路
598 0
|
6天前
ThreeJs模拟工厂生产过程六
这篇文章详细介绍了如何在Three.js中模拟工厂生产过程的第六部分,重点是创建和实现车间内线边仓货架的三维模型及其布局。
11 1
ThreeJs模拟工厂生产过程六
|
6天前
ThreeJs模拟工厂生产过程二
这篇文章详细介绍了如何使用Three.js创建一个模拟工厂车间的3D模型,包括绘制地面和墙面的具体步骤,并特别关注于如何创建带有门的墙面以增加车间的真实性。
16 5
|
6天前
|
UED
ThreeJs模拟工厂生产过程三
这篇文章介绍了在Three.js中通过使用mergeGeometries技术来合并大量车间模型,以减少浏览器渲染负担,提高性能,并提供了实现模型合并的具体方法和步骤。
15 5
|
6天前
ThreeJs模拟工厂生产过程一
这篇文章详细介绍了如何使用Three.js模拟工厂生产过程的第一部分,包括创建传送带、生产设备和产品的模型,并实现产品沿传送带移动的动画效果。
15 5
|
6天前
ThreeJs模拟工厂生产过程七
这篇文章详细介绍了如何在Three.js中为工厂车间的货架动态生成并放置货物,通过循环逻辑和贴图应用使货架上的物品更加逼真,增强了场景的真实感。
9 0
|
6天前
|
JavaScript
ThreeJs模拟工厂生产过程八
这篇文章详细介绍了如何在Three.js中模拟工厂生产过程的第八部分,重点是优化场景中的模型,包括合并货架上的料箱以减少渲染负担,并替换设备模型以增强场景的真实性和互动性。
21 0
|
6天前
|
程序员 图形学
ThreeJs模拟工厂生产过程五
这篇文章详细介绍了如何在Three.js中模拟工业生产过程的第五部分,重点在于添加并实现车间内人物的动态行走动画,使人能够在车间内来回移动,增加了场景的真实感。
16 0
|
4月前
经验大分享:QML动态标注线
经验大分享:QML动态标注线
22 0
|
5月前
|
设计模式 安全 Java
老系统重构系列--如何用一套流程接入所有业务线
**摘要:** 本文介绍了老系统改造的过程,作者提出,ToB业务的挑战在于需要支持多种差异化的业务需求,而模板模式在处理这种需求时可能会导致继承关系复杂和粒度过粗。为了解决这些问题,文章提出了以下步骤: 1. **梳理流程差异点**:识别不同业务流程的差异,以便确定扩展点。 2. **领域模型梳理**:区分核心域和支撑域,确保核心域的稳定性。 3. **二次抽象隔离层**:创建隔离层,避免核心域因新业务接入而变得不稳定。 4. **基于SPI的扩展体系建设**:选择了COLA-SPI实现扩展点,允许业务域定义接口并实现差异化的流程逻辑。
108 0