From 967b1b51f17b94b9aaa6264d14266a73d48416ed Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@63.com> Date: 星期三, 22 六月 2022 14:14:32 +0800 Subject: [PATCH] # --- static/js/object/CrnTask.js | 1 static/js/object/StaTask.js | 12 ++ static/js/object/StoreGoods_Copy.js | 182 +++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 192 insertions(+), 3 deletions(-) diff --git a/static/js/object/CrnTask.js b/static/js/object/CrnTask.js index ea833f3..befe7e7 100644 --- a/static/js/object/CrnTask.js +++ b/static/js/object/CrnTask.js @@ -248,6 +248,7 @@ break case 'fork': that.crnFork.position.set(point.x + xOffset1, point.y, point.z); + // console.log("loadPos:" + curves[i].loadPos + "\n" + that.pallet); if (curves[i].loadPos === 1 && that.pallet) { that.pallet.position.setX(point.x + palletX); that.goods.position.setX(point.x + goodsX); diff --git a/static/js/object/StaTask.js b/static/js/object/StaTask.js index 6680755..970d667 100644 --- a/static/js/object/StaTask.js +++ b/static/js/object/StaTask.js @@ -7,6 +7,7 @@ that.object = object; that.no = 0; + that.readyIn = false; that.run = false; that.loaded = 0; that.wrkNo = null; @@ -35,18 +36,23 @@ } if (that.loaded === 0 && staData.loaded === 1) { + that.readyIn = true; + } + if (that.readyIn && staData.wrkNo && staData.wrkNo !== '0') { + console.log(staData) // 鏃犺揣 ===>> 鏈夎揣 // 1.鍏ュ簱绗竴绔� 銆愭柊澧炪�� if (that.inlet === 1) { InitPallet(that.object, [{wrkNo: staData.wrkNo}], {position: that.position}, 2); InitGoods(that.object, [{wrkNo: staData.wrkNo}], {position: that.position}, 2); - // 2.鏉ヨ嚜鍏朵粬绔欑偣鐨勮揣鐗� 銆愮Щ鍔ㄣ�� + // 2.鏉ヨ嚜鍏朵粬绔欑偣鐨勮揣鐗� 銆愮Щ鍔ㄣ�� } else { } - + that.readyIn = false; } + if (that.loaded === 1 && staData.loaded === 0) { // 鏈夎揣 ===>> 鏃犺揣 @@ -61,7 +67,7 @@ that.object.removeObject(that.wrkNo + "-Goods"); } } - + that.readyIn = false; } // 瀹炴椂鏇存柊 diff --git a/static/js/object/StoreGoods_Copy.js b/static/js/object/StoreGoods_Copy.js new file mode 100644 index 0000000..b83ff8d --- /dev/null +++ b/static/js/object/StoreGoods_Copy.js @@ -0,0 +1,182 @@ +import {MTLLoader} from "../lib/MTLLoader.js"; +import {OBJLoader} from "../lib/OBJLoader.js"; +import * as THREE from '../three.module.js'; + +const palletX = -18; +const palletY = 2; +const palletZ = -46; + +const goodsX = -17; +const goodsY = 5; +const goodsZ = -6; + +/** + * 鍒濆鍖栨墭鐩樻ā鍨� + * @param scene 鍦烘櫙 + * @param palletList 鎵樼洏鏁版嵁鍒楄〃 + * @param ref 鍙傜収鐗� + * @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; + + clone.name = item.loc_no + "-" + "Pallet"; + clone.traverse (function (child) { + if (child instanceof THREE.Mesh) { + child.name = item.loc_no + "-" + child.name; + } + }) + 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"; + clone.traverse (function (child) { + if (child instanceof THREE.Mesh) { + child.name = item.wrkNo + "-" + child.name; + } + }) + 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); + }) + }); +} + +/** + * 鍒濆鍖栬揣鐗╂ā鍨� + * @param scene 鍦烘櫙 + * @param goodsList 璐х墿鏁版嵁鍒楄〃 + * @param ref 鍙傜収鐗� + * @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"; + clone.traverse (function (child) { + if (child instanceof THREE.Mesh) { + child.name = item.loc_no + "-" + child.name; + } + }) + 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"; + clone.traverse (function (child) { + if (child instanceof THREE.Mesh) { + child.name = item.wrkNo + "-" + child.name; + } + }) + 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) { + let that = this; + + that.data = data; + that.object = object; + that.shelf = shelf; + + let palletList = []; + let goodsList = []; + + let init = function () { + for (let i=0;i<that.data.length;i++) { + let obj = that.data[i]; + if (obj.loc_sts === 'D') { + palletList.push(obj); + } else if (obj.loc_sts === 'F') { + palletList.push(obj); + goodsList.push(obj); + } + } + if (palletList.length > 0) { + InitPallet(that.object, palletList, that.shelf, 1); + } + if (goodsList.length > 0) { + InitGoods(that.object, goodsList, that.shelf, 1); + } + } + init(); + +} + +// export {StoreGoods, InitPallet, InitGoods} -- Gitblit v1.9.1