From 6d594993f0bb8c941633197fbad6e24bfd718990 Mon Sep 17 00:00:00 2001 From: kdrzazga Date: Fri, 20 Dec 2024 22:44:42 +0100 Subject: [PATCH] Electrician 7 (#87) --- other/electrician/files/classdef.js | 101 +++++++++++++++---------- other/electrician/files/electrician.js | 29 ++++++- 2 files changed, 87 insertions(+), 43 deletions(-) diff --git a/other/electrician/files/classdef.js b/other/electrician/files/classdef.js index 7677ccc..50609a7 100644 --- a/other/electrician/files/classdef.js +++ b/other/electrician/files/classdef.js @@ -4,7 +4,7 @@ class Constants{ } const WireSlot = Object.freeze({ - EMPTY: {imageId: ''}, + EMPTY: {imageId: 'empty-wire-section'}, WIRE_STRAIGHT: {imageId: 'wire-section'}, WIRE_UP: {imageId: 'wire-section-up'}, WIRE_DOWN: {imageId: 'wire-section-down'}, @@ -145,7 +145,7 @@ class Building { if (currentFloorNumber == 0) return; const upperFloor = this.floors[currentFloorNumber-1]; - const index = Math.floor((player.x - currentFloor.getLeftPosition()) / Wire.SIZE); + const index = Math.floor((player.x - currentFloor.getLeftPosition()) / Wire.SLOT_SIZE); const match = upperFloor.bottomConnectors.filter(cnctr => cnctr == index); if (match.length > 0){ this.wires[currentFloorNumber].place(currentFloor, player, WireSlot.WIRE_UP); @@ -156,7 +156,7 @@ class Building { if (currentFloorNumber > this.floors.length - 1) return; const lowerFloor = currentFloor; - const index = Math.floor((player.x - currentFloor.getLeftPosition()) / Wire.SIZE); + const index = Math.floor((player.x - currentFloor.getLeftPosition()) / Wire.SLOT_SIZE); const match = lowerFloor.ceilingConnectors.filter(cnctr => cnctr == index); if (match.length > 0){ this.wires[currentFloorNumber].place(currentFloor, player, WireSlot.WIRE_DOWN); @@ -165,7 +165,7 @@ class Building { } else { this.wires[currentFloorNumber].place(currentFloor, player, WireSlot.WIRE_STRAIGHT); - const index = Math.floor((player.x - currentFloor.getLeftPosition()) / Wire.SIZE); + const index = Math.floor((player.x - currentFloor.getLeftPosition()) / Wire.SLOT_SIZE); if (this.wires[currentFloorNumber].actualFloorConnections.has(index)) { this.wires[currentFloorNumber].actualFloorConnections.delete(index); } @@ -183,14 +183,14 @@ class PowerLine { } class Wire { - static SIZE = 20; + static SLOT_SIZE = 20; constructor(id, physics, floor1, floor2, expectedFloorConnectionsCnt) { this.id = id; this.physics = physics; this.x = floor1 ? floor1.sprite.x : 0; this.y = this.calculateY(floor1, floor2); - this.slots = Array(Math.ceil(Floor.WIDTH / Wire.SIZE)).fill(WireSlot.EMPTY); + this.slots = Array(Math.ceil(Floor.WIDTH / Wire.SLOT_SIZE)).fill(WireSlot.EMPTY); this.sprites = []; this.expectedFloorConnectionsCnt = expectedFloorConnectionsCnt; this.actualFloorConnections = new Set(); @@ -208,8 +208,8 @@ class Wire { const extraInfoDiv = document.getElementById('extra-info'); extraInfoDiv.innerText = `${floor.id} ${floor.floorLevel}`; - const index = Math.floor((sprite.x - floor.getLeftPosition()) / Wire.SIZE); - const x = floor.getLeftPosition() + index * Wire.SIZE; + const index = Math.floor((sprite.x - floor.getLeftPosition()) / Wire.SLOT_SIZE); + const x = floor.getLeftPosition() + index * Wire.SLOT_SIZE; if (this.slots[index] !== WireSlot.EMPTY) { this.removeOldWireSprite(index); @@ -236,6 +236,11 @@ class Wire { const wireDiv = document.getElementById(`wire${this.id}`); wireDiv.innerText = percentage === 100 && this.expectedFloorConnectionsCnt == this.actualFloorConnections.size ? 'CONNECTED' : `${percentage} %`; } + + getSlotAtCoordinateX(floor, x) { + const index = Math.floor((x - floor.getLeftPosition()) / Wire.SLOT_SIZE); + return {'index' :index, 'slot': this.slots[index]}; + } } class Enemy { @@ -270,7 +275,7 @@ class Enemy { } class Bat extends Enemy{ - static MOVE_RADIUS = 230; + static MOVE_RADIUS = 280; constructor(id){ super(id); @@ -286,6 +291,8 @@ class Bat extends Enemy{ move(){ const centerY = Floor.BUILDING_HEIGHT / 2; + const upperVerticalLimit = Floor.HEIGHT -16; + const lowerVerticalLimit = 2 * Floor.BUILDING_HEIGHT/ 3 + Floor.HEIGHT - 10 - 9 * this.id; this.currentAngle = this.currentAngle + this.angularSpeed; if (this.currentAngle > 2* Math.PI){ @@ -295,12 +302,18 @@ class Bat extends Enemy{ this.sprite.x = this.centerX + Bat.MOVE_RADIUS * Math.cos(this.currentAngle); this.sprite.y = centerY + Bat.MOVE_RADIUS * Math.sin(this.currentAngle); - //console.log(`${this.sprite.x}, ${this.sprite.y} angle = ${this.currentAngle}`); + if (this.sprite.y < upperVerticalLimit) this.sprite.y = upperVerticalLimit; + if (this.sprite.y > lowerVerticalLimit) this.sprite.y = lowerVerticalLimit; } } class Rat extends Enemy{ + constructor(id){ + super(id); + this.wireId = undefined; + } + init(physics, y){ this.sprite = physics.add.sprite(180 + (this.id + 1)*44, y, 'rat' + this.id); this.sprite.velocity = { x: this.speed }; @@ -312,6 +325,10 @@ class Rat extends Enemy{ this.sprite.velocity.x *= -1; } } + + getWireId(){ + return this.wireId; + } } class Creator { @@ -320,46 +337,50 @@ class Creator { building.init(3, physics); building.includeWiresInInfoFrame(); + const atticCeilingLevel = 104; + const livingRoomCeilingLevel = 328 - Floor.HEIGHT / 2; + const groundFloorLevel = 589; //under kitchen + const ratsData = [ - { id: 1, y: 589 }, - { id: 2, y: 104, minX: 2 * 6 * Wire.SIZE, maxX: (6 + 22) * Wire.SIZE }, - { id: 3, y: 589, velocity: { x: 1.2 } }, - { id: 4, y: 589, velocity: { x: 1.4 } }, - { id: 5, y: 328 - Floor.HEIGHT / 2, minX: 2 * Floor.WIDTH / 3 + 18, velocity: { x: 1.4 } }, - { id: 6, y: 328 - Floor.HEIGHT / 2, minX: 2 * Floor.WIDTH / 3 + 18, velocity: { x: 0.8 } }, + { id: 1, y: groundFloorLevel }, + { id: 2, y: atticCeilingLevel, minX: Floor.WIDTH / 3 + 30, maxX: 1.15*Floor.WIDTH, wireId: 2 }, + { id: 3, y: groundFloorLevel, velocity: { x: 1.2 } }, + { id: 4, y: groundFloorLevel, velocity: { x: 1.4 } }, + { id: 5, y: livingRoomCeilingLevel, minX: 2 * Floor.WIDTH / 4, maxX: 1.15*Floor.WIDTH, velocity: { x: 1.4 }, wireId: 1 }, + { id: 6, y: livingRoomCeilingLevel, minX: 2 * Ladder.WIDTH, velocity: { x: 0.85}, wireId: 1 }, ]; - const createRat = (data) => { - const rat = new Rat(data.id); - rat.init(physics, data.y); - if (data.minX) rat.minX = data.minX; - if (data.maxX) rat.maxX = data.maxX; - if (data.velocity) rat.sprite.velocity = data.velocity; - return rat; - }; - - const rats = ratsData.map(createRat); - const batsData = [ - { id:0, speed: -0.017}, - { id:1, currentAngle: Math.PI/2} + { id: 0, speed: -0.017 }, + { id: 1, currentAngle: Math.PI / 2, /*speed: 0.001*/ } ]; - const createBats = (data) =>{ - const bat = new Bat(data.id); - bat.init(physics, 555 + 3*data.id); - if (data.speed) bat.angularSpeed = data.speed; - if (data.currentAngle) bat.currentAngle = data.currentAngle; + const createEnemy = (EnemyClass, data, physics, positionAdjustment = 0) => { + const enemy = new EnemyClass(data.id); + const y = EnemyClass === Rat ? data.y : 555 + 7 * data.id + positionAdjustment; + enemy.init(physics, y); + + Object.assign(enemy, { + minX: data.minX || enemy.minX, + maxX: data.maxX || enemy.maxX, + angularSpeed: data.speed || enemy.angularSpeed, + currentAngle: data.currentAngle || enemy.currentAngle, + wireId: EnemyClass === Rat ? data.wireId : undefined + }); + + if (EnemyClass === Bat) { + enemy.centerX = Constants.SCREEN_WIDTH / 2 + 50 - 39 * data.id; + } - bat.centerX = Constants.SCREEN_WIDTH/2 + 50 - 39 * data.id; + if (data.velocity) enemy.sprite.velocity = data.velocity; - return bat; + return enemy; }; - const bats = batsData.map(createBats); + const rats = ratsData.map(data => createEnemy(Rat, data, physics)); + const bats = batsData.map(data => createEnemy(Bat, data, physics)); - building.enemies.push(...rats); - building.enemies.push(...bats); + building.enemies.push(...rats, ...bats); return building; } @@ -391,7 +412,7 @@ class FloorBuilder { } withLampInCenter() { - const lampConnectorX = Math.floor(Floor.WIDTH/Wire.SIZE /2); + const lampConnectorX = Math.floor(Floor.WIDTH/Wire.SLOT_SIZE /2); this.withCeilingConnector(lampConnectorX); return this; } diff --git a/other/electrician/files/electrician.js b/other/electrician/files/electrician.js index 2c50858..65c0653 100644 --- a/other/electrician/files/electrician.js +++ b/other/electrician/files/electrician.js @@ -20,13 +20,13 @@ class MainScene extends Phaser.Scene { this.load.image('floor0', 'files/attic.png'); const ladderTexture = this.textures.get('floor0'); - this.load.image('floor1', 'files/livingRoom.png'); this.load.image('floor2', 'files/kitchen.png'); this.load.image('power-line-left', 'files/powerlineL.png'); this.load.image('power-line-right', 'files/powerlineR.png'); + this.load.image('empty-wire-section', 'files/wire.png'); this.load.image('wire-section', 'files/wire.png'); this.load.image('wire-section-up', 'files/wireUp.png'); this.load.image('wire-section-down', 'files/wireDown.png'); @@ -111,7 +111,7 @@ class MainScene extends Phaser.Scene { flrs += " " + f.floorLevel; if (f.onFloor(this.player.x, this.player.y) && !this.building.ladder.onLadder(this.player.x)){ - console.log('Floor met on y= ' + this.player.y); + //console.log('Floor met on y= ' + this.player.y); velocity = 0; //Floor under feet prevents from falling this.player.spriteCanJump = true; return; @@ -165,7 +165,26 @@ class MainScene extends Phaser.Scene { } handleEnemyMovement(){ - this.building.enemies.forEach(enemy => enemy.move()); + this.building.enemies.forEach(enemy => { + enemy.move(); + if (enemy instanceof Rat){ + if (enemy.wireId === undefined) return; + + const wireId = enemy.wireId; + const wire = this.building.wires[wireId]; + const anyFloor = this.building.floors[0]; + const wireSlotIndexPair = wire.getSlotAtCoordinateX(anyFloor, enemy.sprite.x); + if (wireSlotIndexPair.slot === WireSlot.WIRE_DOWN){ + const i = wireSlotIndexPair.index; + const currentFloor = this.building.floors[wireId]; + this.building.wires[wireId].place(currentFloor, enemy.sprite ,WireSlot.EMPTY); + if (this.building.wires[wireId].actualFloorConnections.has(i)) { + this.building.wires[wireId].actualFloorConnections.delete(i); + } + console.log(`Rat ${enemy.id} bit thru wire ${wireId}.`); + } + } + }); } writeFloorInfo(){ @@ -196,3 +215,7 @@ const config = { }; const game = new Phaser.Game(config); +/* +game.scene.scenes[0].building +game.scene.scenes[0].player +*/