From bf853ab0d81fa04ca707b273413156f2cbbdbef5 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期四, 30 六月 2022 15:22:50 +0800
Subject: [PATCH] #

---
 static/js/object/StoreShelf.js |   77 +++++++++++++++++++++++++++-----------
 1 files changed, 55 insertions(+), 22 deletions(-)

diff --git a/static/js/object/StoreShelf.js b/static/js/object/StoreShelf.js
index 98bea40..cf49404 100644
--- a/static/js/object/StoreShelf.js
+++ b/static/js/object/StoreShelf.js
@@ -1,3 +1,5 @@
+import * as BufferGeometryUtils from '../utils/BufferGeometryUtils.js';
+
 function StoreShelf(option) {
     this.binLength = option.binLength||50;//搴撲綅闀垮害
     this.binWidth = option.binWidth||50;//搴撲綅瀹�
@@ -11,22 +13,22 @@
     this.positionZ = option.position.z||0;//搴撲綅浣嶇疆
     this.rackLengh = 3;//鏀灦鐨勯暱搴︼紝榛樿璁惧姩涓�3
     this.rackWidth = 3;//鏀灦鐨勫搴︼紝榛樿璁惧畾涓�3
+    this.mesh = null;
 
     // 鏉愯川
-    let shelfMat = new THREE.MeshLambertMaterial({color:0x175EC0});//瀹氫箟鏀灦鍜屾墭鐩樼殑鏉愯川
-    //瀹氫箟涓�涓粍鍚堜綋
-    let group = new THREE.Group();
+    let shelfMat = new THREE.MeshPhysicalMaterial({
+        color: 0x175EC0,
+        transparent: false,
+        opacity: 0.7
+    });
 
     // 璐ф灦鎬婚珮
     let shelfHeight=this.bottomHight+(this.binYNum)*this.binHeight;
-    // 璐ф灦鎬诲
-    let shelfWidth=this.binZNum*this.binWidth;
     // 鏀灦妯″瀷 + 鏉愯川
     let rackBoxGeometry=new THREE.BoxGeometry(this.rackLengh,shelfHeight,this.rackWidth);
-    let rackObject=new THREE.Mesh(rackBoxGeometry, shelfMat, 0);
     // 鎵樻澘妯″瀷 + 鏉愯川
     let planeBoxGeometry = new THREE.BoxGeometry(this.binLength, 2, this.binWidth+this.rackWidth);  // 瑕嗙洊澶氫竴鏍规敮鏋跺搴�
-    let planeObject=new THREE.Mesh(planeBoxGeometry, shelfMat, 0);
+    let planeRackBoxGeometry = new THREE.BoxGeometry(3, 2, this.binWidth+this.rackWidth);
 
     // Y杞村畾浣�
     let positionY = this.positionY + shelfHeight / 2;
@@ -36,29 +38,60 @@
     //鍙充晶鏀灦鏌辩殑X杞村畾浣�
     let rightPositionX=this.positionX+this.binLength/2 - this.rackLengh;    // 缂╄繘鏀灦闀垮害
 
+    let geometries = [];
+    let transform = new THREE.Object3D();
     // 鍒濆鍖栨敮鏋舵ā鍨�
     for(let i=0;i<=this.binZNum;i++) {
-        let leftRack = rackObject.clone();
         let positionZ = - ( this.positionZ + i*this.binWidth );
-        leftRack.position.set(leftPositionX,positionY,positionZ);
-        leftRack.updateMatrix();
-        group.add(leftRack);
+        // -----
+        let leftClone = rackBoxGeometry.clone();
+        transform.position.set(leftPositionX,positionY,positionZ);
+        transform.updateMatrix();
+        leftClone.applyMatrix4(transform.matrix);
+        geometries.push(leftClone);
 
-        let rightRack = rackObject.clone();
-        rightRack.position.set(rightPositionX,positionY,positionZ);
-        rightRack.updateMatrix();
-        group.add(rightRack);
+        let rightClone = rackBoxGeometry.clone();
+        transform.position.set(rightPositionX,positionY,positionZ);
+        transform.updateMatrix();
+        rightClone.applyMatrix4(transform.matrix);
+        geometries.push(rightClone);
     }
     // 鍒濆鍖栨墭鏉挎ā鍨�
     for(let i = 0;i < this.binZNum;i++) {
         for (let j = 0;j <= this.binYNum;j++) {
-            let plane = planeObject.clone();
-            let positionY= this.positionY + this.bottomHight + j*this.binHeight + 1;
-            let positionZ= - ( this.positionZ + i * this.binWidth + this.binWidth/2 );
-            plane.position.set(this.positionX-this.rackLengh/2,positionY,positionZ);
-            plane.updateMatrix();
-            group.add(plane);
+            if (j !== this.binYNum) {
+                let leftClone = planeRackBoxGeometry.clone();
+                let positionY = this.positionY + this.bottomHight + j*this.binHeight + 1;
+                let positionZ = - ( this.positionZ + i * this.binWidth + this.binWidth/2 );
+                transform.position.set(this.positionX - 16, positionY, positionZ);
+                transform.updateMatrix();
+                leftClone.applyMatrix4(transform.matrix);
+                geometries.push(leftClone);
+
+                let rightClone = planeRackBoxGeometry.clone();
+                positionY = this.positionY + this.bottomHight + j*this.binHeight + 1;
+                positionZ = - ( this.positionZ + i * this.binWidth + this.binWidth/2 );
+                transform.position.set(this.positionX + 13, positionY, positionZ);
+                transform.updateMatrix();
+                rightClone.applyMatrix4(transform.matrix);
+                geometries.push(rightClone);
+            } else {
+                let clone = planeBoxGeometry.clone();
+                let positionY= this.positionY + this.bottomHight + j*this.binHeight + 1;
+                let positionZ= - ( this.positionZ + i * this.binWidth + this.binWidth/2 );
+                transform.position.set(this.positionX-this.rackLengh/2,positionY,positionZ);
+                transform.updateMatrix();
+                clone.applyMatrix4(transform.matrix);
+                geometries.push(clone);
+            }
         }
     }
-    return group;
+
+    let mergedGeometry = BufferGeometryUtils.mergeBufferGeometries(geometries);
+    let mesh = new THREE.Mesh(mergedGeometry, shelfMat);
+    mesh.castShadow = true;
+    this.mesh = mesh;
+    return this;
 }
+
+export {StoreShelf}

--
Gitblit v1.9.1