From 18bd54d17c3d09e48b14fcb0cc0fc74758a920b2 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@63.com> Date: 星期四, 30 六月 2022 16:51:43 +0800 Subject: [PATCH] # --- static/js/object/StoreGoods.js | 202 +++++++++++++++++++++++++++----------------------- 1 files changed, 108 insertions(+), 94 deletions(-) diff --git a/static/js/object/StoreGoods.js b/static/js/object/StoreGoods.js index 945f414..05b3394 100644 --- a/static/js/object/StoreGoods.js +++ b/static/js/object/StoreGoods.js @@ -1,14 +1,13 @@ -import {MTLLoader} from "../lib/MTLLoader.js"; -import {OBJLoader} from "../lib/OBJLoader.js"; import * as THREE from '../three.module.js'; +import * as BufferGeometryUtils from '../utils/BufferGeometryUtils.js'; -const palletX = -18; -const palletY = 2; -const palletZ = -46; +const palletX = -2; +const palletY = 0; +const palletZ = -25; -const goodsX = -17; -const goodsY = 5; -const goodsZ = -6; +const goodsX = -2; +const goodsY = 22; +const goodsZ = -25; /** * 鍒濆鍖栨墭鐩樻ā鍨� @@ -18,56 +17,71 @@ * @param type 鍙傜収鐗╃被鍨嬶細1 - 璐ф灦锛� 2 - 杈撻�佺嚎 */ function InitPallet(scene, palletList, ref, type) { - const manager = new THREE.LoadingManager(); - new OBJLoader( manager ) - .setPath( '../static/model/obj/' ) - .load( 'pallet.obj', function ( obj ) { - obj.traverse (function (child) { - child.castShadow = true; - if (child instanceof THREE.Mesh) { - child.material = new THREE.MeshLambertMaterial({ - color: 0x708090 - }); - } - }); - obj.scale.set(4, 4, 3.5); - palletList.map(item => { - let clone = obj.clone(); - let positionX; - let positionY; - let positionZ; - switch (type) { - case 1: - positionX = ref.positionX || 0; - positionY = ref.bottomHight + (item.lev1-1)*ref.binHeight || 0; - positionZ = (item.bay1-1)*-ref.binHeight || 0; + let palletMat = new THREE.MeshPhysicalMaterial({ + color: 0x637e97, + transparent: false, + opacity: 0.7 + }); - clone.name = item.loc_no + "-" + "Pallet"; - break; - case 2: - console.log(item); - console.log(ref) - positionX = ref.position.x || 0; - positionY = ref.position.y || 0; - positionZ = ref.position.z || 0; + let transform = new THREE.Object3D(); + let geometries = []; - positionX -= 46; - positionY += 50; - positionZ -= 128; + let palletGeometry = new THREE.BoxGeometry(30 ,2,40); + transform.position.set(0 ,7, 0); + transform.updateMatrix(); + palletGeometry.applyMatrix4(transform.matrix); + geometries.push(palletGeometry) - clone.name = item.wrkNo + "-" + "Pallet"; - break; - default: - console.error("InitPallet param[type] error ===>> " + type); - } + let palletLeftGeometry = new THREE.BoxGeometry(30 ,5,2); + transform.position.set(0 ,5, -15); + transform.updateMatrix(); + palletLeftGeometry.applyMatrix4(transform.matrix); + geometries.push(palletLeftGeometry) - clone.position.x = palletX + positionX; - clone.position.y = palletY + positionY; - clone.position.z = palletZ + positionZ; - scene.addObject(clone); - }) - }); + let palletRightGeometry = new THREE.BoxGeometry(30 ,5,2); + transform.position.set(0 ,5, 15); + transform.updateMatrix(); + palletRightGeometry.applyMatrix4(transform.matrix); + geometries.push(palletRightGeometry) + + let mergedGeometry = BufferGeometryUtils.mergeBufferGeometries(geometries); + + let palletObj = new THREE.Mesh(mergedGeometry, palletMat, 0); + + palletList.map(item => { + let clone = palletObj.clone(); + let positionX; + let positionY; + let positionZ; + switch (type) { + case 1: + positionX = ref.positionX || 0; + positionY = ref.bottomHight + (item.lev1-1)*ref.binHeight || 0; + positionZ = (item.bay1-1)*-ref.binHeight || 0; + + clone.name = item.loc_no + "-" + "Pallet"; + break; + case 2: + positionX = ref.position.x || 0; + positionY = ref.position.y || 0; + positionZ = ref.position.z || 0; + + positionX -= 48 - 1; + positionY += 20; + positionZ -= 138 + 20; + + clone.name = item.wrkNo + "-" + "Pallet"; + break; + default: + console.error("InitPallet param[type] error ===>> " + type); + } + + clone.position.x = palletX + positionX; + clone.position.y = palletY + positionY; + clone.position.z = palletZ + positionZ; + scene.addObject(clone); + }) } /** @@ -78,48 +92,48 @@ * @param type 鍙傜収鐗╃被鍨嬶細1 - 璐ф灦锛� 2 - 杈撻�佺嚎 */ function InitGoods(scene, goodsList, ref, type) { - const manager = new THREE.LoadingManager(); - const goodsWrapImg = new THREE.TextureLoader( manager ).load( '../static/img/goodsWrap.jpg' ); - const goodsImg = new THREE.TextureLoader( manager ).load( '../static/img/goods.jpg' ); - new OBJLoader( manager ).load( '../static/model/obj/goods.obj', function ( obj ) { - obj.traverse (function (child) { - child.castShadow = true; - if (child instanceof THREE.Mesh) { - if (child.name === 'goods') { - child.material.map = goodsImg; - } else if (child.name === "goods_wrap") { - child.material.map = goodsWrapImg; - } - } - }); - obj.scale.set(1, 1.2, 1.2); - - goodsList.map(item => { - let clone = obj.clone(); - let positionX; - let positionY; - let positionZ; - switch (type) { - case 1: - positionX = ref.positionX || 0; - positionY = ref.bottomHight + (item.lev1-1)*ref.binHeight || 0; - positionZ = (item.bay1-1)*-ref.binHeight || 0; - - clone.name = item.loc_no + "-" + "Goods"; - break; - case 2: - - break; - default: - console.error("InitGoods param[type] error ===>> " + type); - } - - clone.position.x = goodsX + positionX; - clone.position.y = goodsY + positionY; - clone.position.z = goodsZ + positionZ; - scene.addObject(clone); - }) + let goodsMat = new THREE.MeshPhysicalMaterial({ + color: 0x93710c, + transparent: false, + opacity: 0.7 }); + let goodsGeometry = new THREE.BoxGeometry(27 ,30,35); + let goodsObj = new THREE.Mesh(goodsGeometry, goodsMat, 0); + + goodsList.map(item => { + let clone = goodsObj.clone(); + let positionX; + let positionY; + let positionZ; + switch (type) { + case 1: + positionX = ref.positionX || 0; + positionY = ref.bottomHight + (item.lev1-1)*ref.binHeight || 0; + positionZ = (item.bay1-1)*-ref.binHeight || 0; + + clone.name = item.loc_no + "-" + "Goods"; + break; + case 2: + positionX = ref.position.x || 0; + positionY = ref.position.y || 0; + positionZ = ref.position.z || 0; + + positionX -= 48 - 1; + positionY += 20; + positionZ -= 138 + 20; + + clone.name = item.wrkNo + "-" + "Goods"; + break; + default: + console.error("InitGoods param[type] error ===>> " + type); + } + + clone.position.x = goodsX + positionX; + clone.position.y = goodsY + positionY; + clone.position.z = goodsZ + positionZ; + scene.addObject(clone); + }) + } function StoreGoods(object, data, shelf) { -- Gitblit v1.9.1