From 3cb912e46af76301748b38c8f667adcaba959e8f Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@63.com> Date: 星期六, 11 十二月 2021 07:57:31 +0800 Subject: [PATCH] # --- static/js/app.js | 101 ++++++++++++++++++++++++++++++++------------------ 1 files changed, 65 insertions(+), 36 deletions(-) diff --git a/static/js/app.js b/static/js/app.js index e8dedd1..5b4915f 100644 --- a/static/js/app.js +++ b/static/js/app.js @@ -29,15 +29,13 @@ this.initLight(); this.initFloor(); this.initModel(); - // 鍙栨暟鎹� - this.initStoreData(); + this.initStoreObjects(this); } this.animate = function () { requestAnimationFrame(this.animate.bind(this)); this.stats.begin(); this.renderer.render(this.scene, this.camera); this.stats.end(); - this.initStoreObjects(this); this.modelMove(); } this.initScene = function () { @@ -58,7 +56,7 @@ // this.camera.position.z = 600; // //鐩告満鐨勬湞鍚� // this.camera.lookAt(0, 0, 0); - this.camera.position.set( - 550, 670, 950 ); + this.camera.position.set( - 550, 2070, 4550 ); this.camera.lookAt( this.scene.position ); //灏嗙浉鏈烘斁鍒板満鏅腑 this.scene.add(this.camera); @@ -75,12 +73,29 @@ this.dom.appendChild( this.renderer.domElement ); } this.initLight = function () { + + //棣栧厛娣诲姞涓幆澧冨厜 + 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); + // --- - var bulbLight = new THREE.PointLight( 0xffee88, 1, 2000, 2 ); - bulbLight.position.set( 600, 600, 500 ); - bulbLight.castShadow = true; - bulbLight.power = 100; - this.addObject(bulbLight); + // var bulbLight = new THREE.PointLight( 0xffee88, 1, 2000, 2 ); + // bulbLight.position.set( 600, 600, 500 ); + // bulbLight.castShadow = true; + // bulbLight.power = 100; + // this.addObject(bulbLight); // --- // var bulbLight1 = new THREE.PointLight( 0xffee88, 1, 2000, 2 ); // bulbLight1.position.set( -600, 600, 500 ); @@ -104,12 +119,12 @@ // hemiLight.intensity = 0.0001; // this.addObject(hemiLight); - const ambientLight = new THREE.AmbientLight( 0xcccccc, 0.4 ); - this.addObject( ambientLight ); - - const directionalLight = new THREE.DirectionalLight( 0xffffff, 0.6 ); - directionalLight.position.set( - 1, 1, 1 ); - this.addObject( directionalLight ); + // const ambientLight = new THREE.AmbientLight( 0xcccccc, 0.4 ); + // this.addObject( ambientLight ); + // + // const directionalLight = new THREE.DirectionalLight( 0xffffff, 0.6 ); + // directionalLight.position.set( - 1, 1, 1 ); + // this.addObject( directionalLight ); } this.initOrbitControl = function () { this.orbitControl = new OrbitControls(this.camera, this.renderer.domElement); @@ -134,7 +149,7 @@ "posy.jpg", "negy.jpg", "posz.jpg", "negz.jpg" ]); - this.scene.background = new THREE.Color( 0x17c5dc ); + this.scene.background = new THREE.Color( 0xf0f0f0 ); } this.removeObject = function (nameorid) { for (let i = 0; i < this.objects.length; i++) { @@ -159,7 +174,7 @@ // this.addObject(plane); // // const helper = new THREE.PolarGridHelper( 2000, 100 ); - const helper = new THREE.GridHelper( 5000, 300 ); + const helper = new THREE.GridHelper( 8000, 300 ); helper.position.y = - 0; helper.material.opacity = 0.25; helper.material.transparent = true; @@ -167,23 +182,37 @@ } this.initStoreObjects = function (object) { if (this.firstTime === 1) { - // initStore(); + initStore(); if (Store3DData !== null) { - for(let i = 0;i<Store3DData.data.length;i++){ - let optionArea = Store3DData.data[i]; - let area = new Store3DData(optionArea); - object.addObject(area); - for (let j = 0; j<optionArea.store.length;j++){ - let optionStore = optionArea[j]; - optionStore.position=CommonFunction.transPosition(optionStore.position,optionArea.position) - let store =new Store(optionStore); - object.addObject(store); - for (let k = 0; k < optionStore.groups.length;k++){ - let optionGroup = optionStore.groups[k]; - optionGroup.position - } + for(var group of Store3DData.data.store.groups) { + for (var 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); + // } + // } + } } + + + + + + + + + @@ -272,8 +301,11 @@ .setMaterials( materials ) .setPath( '../static/model/obj/' ) .load( '璐у弶.obj', function ( object ) { - object.position.z = -500; - object.position.x = -2060; + // object.position.z = -500; + // object.position.x = -2060; + object.position.z = 0; + object.position.x = 0; + object.position.y = 0; object.scale.set(0.025, 0.025, 0.025); object.rotateY(- Math.PI / 2) that.addObject( object ); @@ -311,9 +343,6 @@ }); } this.modelMove = function () { - - } - this.initStoreData = function () { } }, -- Gitblit v1.9.1