🐛🔨
This commit is contained in:
		| @@ -4,31 +4,36 @@ const LASER_SIZE = 0.5; | |||||||
| const BULLET_SPREAD = 0.1; | const BULLET_SPREAD = 0.1; | ||||||
|  |  | ||||||
| const geometry = new THREE.BoxGeometry( | const geometry = new THREE.BoxGeometry( | ||||||
| 	LASER_SIZE * 0.03, | 	LASER_SIZE * 0.3, | ||||||
| 	LASER_SIZE * 0.03, | 	LASER_SIZE * 0.3, | ||||||
| 	LASER_SIZE | 	LASER_SIZE | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  | const badLaserMat = new THREE.MeshStandardMaterial(0xffffff, { | ||||||
|  | 	flatShading: true, | ||||||
|  | 	color: new THREE.Color(`hsl(0,100%,70%)`), | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | const goodLaserMat = new THREE.MeshStandardMaterial(0xffffff, { | ||||||
|  | 	flatShading: true, | ||||||
|  | 	color: new THREE.Color(`hsl(180,100%,70%)`), | ||||||
|  | }); | ||||||
|  |  | ||||||
| export class Laser { | export class Laser { | ||||||
| 	constructor(ship) { | 	constructor(ship, count) { | ||||||
| 		const position = new THREE.Vector3(); | 		const position = new THREE.Vector3(); | ||||||
| 		this.direction = ship.direction; | 		this.direction = ship.direction; | ||||||
| 		this.kill = false; | 		this.kill = false; | ||||||
|  | 		this.life = 20; | ||||||
|  |  | ||||||
| 		this.stepX = (Math.random() - 0.5) * BULLET_SPREAD; | 		this.stepX = (Math.random() - 0.5) * BULLET_SPREAD; | ||||||
| 		this.stepY = (Math.random() - 0.5) * BULLET_SPREAD; | 		this.stepY = (Math.random() - 0.5) * BULLET_SPREAD; | ||||||
|  |  | ||||||
| 		ship.mesh.getWorldPosition(position); | 		ship.mesh.getWorldPosition(position); | ||||||
|  |  | ||||||
| 		const material = new THREE.MeshStandardMaterial(0xffffff, { | 		this.mesh = new THREE.InstancedMesh(geometry, badLaserMat, count); | ||||||
| 			flatShading: true, |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		this.mesh = new THREE.Mesh(geometry, material); | 		this.mesh.instanceMatrix.setUsage(THREE.DynamicDrawUsage); | ||||||
|  |  | ||||||
| 		this.mesh.material.color.set( |  | ||||||
| 			new THREE.Color(`hsl(${ship.direction > 0 ? 0 : 180},100%,70%)`) |  | ||||||
| 		); |  | ||||||
|  |  | ||||||
| 		this.mesh.position.set(position.x, position.y, position.z); | 		this.mesh.position.set(position.x, position.y, position.z); | ||||||
| 	} | 	} | ||||||
| @@ -37,9 +42,8 @@ export class Laser { | |||||||
| 		this.mesh.position.x += this.stepX; | 		this.mesh.position.x += this.stepX; | ||||||
| 		this.mesh.position.y += this.stepY; | 		this.mesh.position.y += this.stepY; | ||||||
| 		this.mesh.position.z += 0.5 * this.direction; | 		this.mesh.position.z += 0.5 * this.direction; | ||||||
|  | 		this.life -= deltaTime; | ||||||
|  |  | ||||||
| 		if (Math.abs(this.mesh.position.z > 475 / 2)) { | 		if (this.life < 0) this.kill = true; | ||||||
| 			this.kill = true; |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -54,6 +54,8 @@ export const scene = ({ ref }) => { | |||||||
| 		camera.lookAt(new THREE.Vector3(0, 0, 0)); | 		camera.lookAt(new THREE.Vector3(0, 0, 0)); | ||||||
| 	}); | 	}); | ||||||
|  |  | ||||||
|  | 	let boltCount = 0; | ||||||
|  |  | ||||||
| 	const animate = () => { | 	const animate = () => { | ||||||
| 		const deltaTime = 0.075; | 		const deltaTime = 0.075; | ||||||
| 		t += deltaTime; | 		t += deltaTime; | ||||||
| @@ -71,7 +73,10 @@ export const scene = ({ ref }) => { | |||||||
| 			ship.update({ deltaTime }); | 			ship.update({ deltaTime }); | ||||||
|  |  | ||||||
| 			if (ship.firing) { | 			if (ship.firing) { | ||||||
| 				const bolt = new Laser(ship); | 				const bolt = new Laser(ship, boltCount + 1); | ||||||
|  | 				boltCount += 1; | ||||||
|  |  | ||||||
|  | 				console.log('pew', boltCount); | ||||||
| 				bolts.push(bolt); | 				bolts.push(bolt); | ||||||
| 				scene.add(bolt.mesh); | 				scene.add(bolt.mesh); | ||||||
| 				ship.firing = false; | 				ship.firing = false; | ||||||
| @@ -86,6 +91,7 @@ export const scene = ({ ref }) => { | |||||||
| 			bolt.update({ deltaTime }); | 			bolt.update({ deltaTime }); | ||||||
|  |  | ||||||
| 			if (bolt.kill) { | 			if (bolt.kill) { | ||||||
|  | 				boltCount -= 1; | ||||||
| 				scene.remove(bolt.mesh); | 				scene.remove(bolt.mesh); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user