From 0b75b43cca6c04f49ddeae6d873ac53185e390bc Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期四, 07 四月 2022 13:08:36 +0800
Subject: [PATCH] #

---
 static/js/app.js |   97 +++++++++++++++---------------------------------
 1 files changed, 31 insertions(+), 66 deletions(-)

diff --git a/static/js/app.js b/static/js/app.js
index 3e46db3..d3c5c04 100644
--- a/static/js/app.js
+++ b/static/js/app.js
@@ -11,9 +11,8 @@
 import {StoreShelf} from './object/StoreShelf.js';
 import {StoreCrn} from './object/StoreCrn.js';
 import {StoreConvey} from './object/StoreConvey.js';
-import { Sky } from './object/Sky.js';
-
-
+import {StoreGoods} from './object/StoreGoods.js';
+import {StaTask} from './object/StaTask.js';
 
 var APP = {
 
@@ -28,6 +27,7 @@
 		this.outlinePass = null;
 		this.goodTypes=[];//瀛樺偍鎵�鏈夌殑搴撲綅绫诲瀷
 		this.crnTasks = [];// 鍫嗗灈鏈哄垪琛�
+		this.staTasks = [];// 杈撻�佺嚎鍒楄〃
 		this.moveForward = false;//鏄惁鍚戝墠杩愯
 		this.moveBackward = false;//鏄惁鍚戝悗杩愯
 		this.moveLeft = false;//鏄惁鍚戝乏杩愯
@@ -73,6 +73,8 @@
 			this.stats.end();
 			this.queryCrn();
 			this.crnMove();
+			this.querySta();
+			this.staChange();
 		}
 		this.initScene = function () {
 			this.scene = new THREE.Scene();
@@ -108,19 +110,6 @@
 			let ambient = new THREE.AmbientLight(0xffffff, 1); //AmbientLight,褰卞搷鏁翠釜鍦烘櫙鐨勫厜婧�
 			ambient.position.set(0, 0, 0);
 			this.addObject(ambient);
-
-
-			// 娣诲姞骞宠鍏�,骞宠鍏夌被浼间簬澶槼鍏�
-			// let directionalLight = new THREE.DirectionalLight(0xffffff, 0.3);//妯℃嫙杩滃绫讳技澶槼鐨勫厜婧�
-			// directionalLight.position.set(0, 200, 0);
-			// this.addObject(directionalLight);
-			// //璁剧疆鐐瑰厜婧�
-			// let pointLight1 = new THREE.PointLight(0xffffff, 0.3);
-			// pointLight1.position.set(-500, 200, 0);
-			// this.addObject(pointLight1);
-			// let pointLight2 = new THREE.PointLight(0xffffff, 0.3);
-			// pointLight2.position.set(500, 200, 0);
-			// this.addObject(pointLight2);
 
 			// 闃村奖鑱氬厜鐏�
 			let pointLight = new THREE.SpotLight(0xFFFAFA,1);
@@ -161,29 +150,6 @@
 					"pz.jpg", "nz.jpg"
 				]);
 			}
-			// 澶槼
-			// let sky = new Sky();
-			// sky.scale.setScalar( 450000 );
-			// this.addObject( sky );
-			// let sun = new THREE.Vector3();
-			// const effectController = {
-			// 	turbidity: 10,
-			// 	rayleigh: 3,
-			// 	mieCoefficient: 0.005,
-			// 	mieDirectionalG: 0.7,
-			// 	elevation: 2,
-			// 	azimuth: 180,
-			// 	exposure: this.renderer.toneMappingExposure
-			// };
-			// const uniforms = sky.material.uniforms;
-			// uniforms[ 'turbidity' ].value = effectController.turbidity;
-			// uniforms[ 'rayleigh' ].value = effectController.rayleigh;
-			// uniforms[ 'mieCoefficient' ].value = effectController.mieCoefficient;
-			// uniforms[ 'mieDirectionalG' ].value = effectController.mieDirectionalG;
-			// const phi = THREE.MathUtils.degToRad( 90 - effectController.elevation );
-			// const theta = THREE.MathUtils.degToRad( effectController.azimuth );
-			// sun.setFromSphericalCoords( 1, phi, theta );
-			// uniforms[ 'sunPosition' ].value.copy( sun );
 		}
 		this.initReSize = function(object){
 			window.addEventListener('resize', function () {
@@ -365,25 +331,14 @@
 		this.initStoreObjects = function (object) {
 			if (this.firstTime === 1) {
 				if (Store3DData !== undefined && Store3DData !== null) {
-					for(var group of Store3DData.data.store.groups) {
+					for(let group of Store3DData.data.store.groups) {
 						new StoreCrn(group.crn, object);
-						for (var line of group.lines) {
+						for (let line of group.lines) {
 							let shelf = new StoreShelf(line);
-							object.addObject(shelf);
-							//鏄剧ず搴撲綅涓婄殑璐х墿
-							// for (var bin of line.bins) {
-							// 	let existGoods=this.getExistedGoodType(bin.State);
-							// 	let storeGoods = new StoreGoods(optionGroup, bin);
-							// 	if(existGoods==null) {
-							// 		let goods=storeGoods.create();
-							// 		object.addObject(goods);
-							// 		this.goodTypes.push({type: bin.State, object: goods});
-							// 	} else {
-							// 		let goods= storeGoods.clone(existGoods);
-							// 		object.addObject(goods);
-							// 	}
-							// }
-
+							object.addObject(shelf.mesh);
+							if (line.bins !== null) {
+								new StoreGoods(object, line.bins, shelf);
+							}
 						}
 					}
 					this.firstTime = 0;
@@ -404,20 +359,30 @@
 				}
 			}
 		}
-		this.getExistedGoodType=function(state){
-			for (let i=0;i<this.goodTypes.length;i++) {
-				let type=this.goodTypes[i];
-				if(type.type===state) {
-					return type.object;
-				}
-			}
-			return null;
-		}
-		this.crnMove = function (object) {
+		this.crnMove = function () {
 			for (let crnTask of this.crnTasks) {
 				crnTask.move();
 			}
 		}
+		this.querySta = function () {
+			if (StaDatas !== null && this.firstTime === 0) {
+				for (let staData of StaDatas) {
+					let staTask = getArrVal(this.staTasks, "no", staData.no);
+					if (null == staTask) {
+						this.staTasks.push(new StaTask(staData, this));
+					} else {
+						if(!staTask.run) {
+							staTask.modify(staData);
+						}
+					}
+				}
+			}
+		}
+		this.staChange = function () {
+			for (let staTask of this.staTasks) {
+				staTask.change();
+			}
+		}
 
 		// 鍔熻兘鏂规硶鍖�
 		this.changeStats = function () {

--
Gitblit v1.9.1