芝麻web文件管理V1.00
编辑当前文件:/home/qrafawbu/thefirstcookout.com/canvas/src/js/SceneHinge.js
import * as THREE from 'three' import C from 'cannon' import OrbitControls from 'three-orbitcontrols' import MenuHinge from './MenuHinge' import CannonDebugRenderer from './utils/CannonDebugRenderer' const distance = 15 export default class Scene { constructor() { this.$stage = document.getElementById('stage') this.setup() this.bindEvents() } bindEvents() { window.addEventListener('resize', () => { this.onResize() }) } setup() { // Init Physics world this.world = new C.World() this.world.gravity.set(0, -50, 0) // Init Three components this.scene = new THREE.Scene() this.scene.fog = new THREE.Fog(0x1a1e1c, -10, 100) this.setCamera() this.setLights() this.setRender() this.addObjects() // this.setupDebug() } /* Handlers --------------------------------------------------------- */ onResize() { const { W, H } = APP.Layout this.camera.aspect = W / H this.camera.top = distance this.camera.right = distance * this.camera.aspect this.camera.bottom = -distance this.camera.left = -distance * this.camera.aspect this.camera.updateProjectionMatrix() this.renderer.setSize(W, H) } /* Actions --------------------------------------------------------- */ setCamera() { const { W, H } = APP.Layout const aspect = W / H this.camera = new THREE.OrthographicCamera(-distance * aspect, distance * aspect, distance, -distance, -10, 100) this.camera.position.set(-10, 10, 10) this.camera.lookAt(new THREE.Vector3()) } setLights() { const ambient = new THREE.AmbientLight(0xcccccc) this.scene.add(ambient) const foreLight = new THREE.DirectionalLight(0xffffff, 0.5) foreLight.position.set(5, 5, 20) this.scene.add(foreLight) const backLight = new THREE.DirectionalLight(0xffffff, 1) backLight.position.set(-5, -5, -10) this.scene.add(backLight) } setRender() { this.renderer = new THREE.WebGLRenderer({ antialias: true, canvas: this.$stage, }) this.renderer.setClearColor(0x1a1e1c) this.renderer.setSize(APP.Layout.W, APP.Layout.H) this.renderer.setPixelRatio(window.devicePixelRatio) this.renderer.setAnimationLoop(() => { this.draw() }) } addObjects() { this.menu = new MenuHinge(this.scene, this.world, this.camera) } setupDebug() { this.dbr = new CannonDebugRenderer(this.scene, this.world) this.controls = new OrbitControls(this.camera, this.renderer.domElement) this.controls.enableKeys = false this.controls.update() } /* Values --------------------------------------------------------- */ draw() { this.updatePhysics() this.renderer.render(this.scene, this.camera) } updatePhysics() { if (this.dbr) this.dbr.update() this.menu.update() this.world.step(1 / 60) } } /* CONSTANTS & HELPERS ---------------------------------------------------------------------------------------------------- */