mirror of
https://github.com/MartinKral/Slash-The-Hordes
synced 2025-10-09 00:26:04 +00:00
Item manager
This commit is contained in:
@@ -1,8 +1,6 @@
|
||||
import { Component, Node, random, randomRange, Vec3, _decorator } from "cc";
|
||||
import { Component, Node, _decorator } from "cc";
|
||||
import { ISignal } from "../../../Services/EventSystem/ISignal";
|
||||
import { EnemyManagerSettings } from "../../Data/GameSettings";
|
||||
import { GoldSpawner } from "../../Gold/GoldSpawner";
|
||||
import { XPSpawner } from "../../XP/XPSpawner";
|
||||
import { Enemy } from "./Enemy";
|
||||
import { EnemyMovementType } from "./EnemyMovementType";
|
||||
import { EnemyMover } from "./EnemyMover/EnemyMover";
|
||||
@@ -20,8 +18,6 @@ const { ccclass, property } = _decorator;
|
||||
@ccclass("EnemyManager")
|
||||
export class EnemyManager extends Component {
|
||||
@property(EnemySpawner) private enemySpawner: EnemySpawner;
|
||||
@property(XPSpawner) private xpSpawner: XPSpawner;
|
||||
@property(GoldSpawner) private goldSpawner: GoldSpawner;
|
||||
|
||||
private movementTypeToMover: Map<EnemyMovementType, EnemyMover> = new Map<EnemyMovementType, EnemyMover>();
|
||||
|
||||
@@ -50,9 +46,6 @@ export class EnemyManager extends Component {
|
||||
this.movementTypeToMover.set(EnemyMovementType.Follow, new FollowTargetEnemyMover(targetNode));
|
||||
this.movementTypeToMover.set(EnemyMovementType.Launch, new WaveEnemyMover(targetNode));
|
||||
this.movementTypeToMover.set(EnemyMovementType.PeriodicFollow, new PeriodicFollowTargetEnemyMover(targetNode, 5, 5));
|
||||
|
||||
this.xpSpawner.init();
|
||||
this.goldSpawner.init();
|
||||
}
|
||||
|
||||
public gameTick(deltaTime: number): void {
|
||||
@@ -74,39 +67,13 @@ export class EnemyManager extends Component {
|
||||
}
|
||||
|
||||
private onEnemyAdded(enemy: Enemy): void {
|
||||
enemy.DeathEvent.on(this.onEnemyDied, this);
|
||||
this.getEnemyMover(enemy).addEnemy(enemy);
|
||||
}
|
||||
|
||||
private onEnemyRemoved(enemy: Enemy): void {
|
||||
enemy.DeathEvent.off(this.onEnemyDied);
|
||||
this.getEnemyMover(enemy).removeEnemy(enemy);
|
||||
}
|
||||
|
||||
private onEnemyDied(enemy: Enemy): void {
|
||||
for (let index = 0; index < enemy.XPReward; index++) {
|
||||
const position: Vec3 = enemy.node.worldPosition;
|
||||
position.x += randomRange(-10, 10);
|
||||
position.y += randomRange(-10, 10);
|
||||
this.xpSpawner.spawnXp(position, 1);
|
||||
}
|
||||
|
||||
if (0 < enemy.GoldReward) {
|
||||
if (enemy.GoldReward < 1) {
|
||||
if (random() < enemy.GoldReward) {
|
||||
this.goldSpawner.spawn(enemy.node.worldPosition);
|
||||
}
|
||||
} else {
|
||||
for (let i = 0; i < enemy.GoldReward; i++) {
|
||||
const position: Vec3 = enemy.node.worldPosition;
|
||||
position.x += randomRange(-10, 10);
|
||||
position.y += randomRange(-10, 10);
|
||||
this.goldSpawner.spawn(position);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private getEnemyMover(enemy: Enemy): EnemyMover {
|
||||
if (this.movementTypeToMover.has(enemy.MovementType)) {
|
||||
return this.movementTypeToMover.get(enemy.MovementType);
|
||||
|
@@ -1,4 +1,5 @@
|
||||
import { Animation, Node, BoxCollider2D, Collider2D, Component, Vec2, Vec3, _decorator, Details } from "cc";
|
||||
import { Animation, Node, BoxCollider2D, Collider2D, Component, Vec2, Vec3, _decorator, Details, Sprite, Color } from "cc";
|
||||
import { delay } from "../../../Services/Utils/AsyncUtils";
|
||||
import { IInput } from "../../Input/IInput";
|
||||
import { UnitHealth } from "../UnitHealth";
|
||||
import { UnitLevel } from "../UnitLevel";
|
||||
@@ -15,6 +16,7 @@ export class Player extends Component {
|
||||
@property(Weapon) private weapon: Weapon;
|
||||
@property(Node) private playerGraphics: Node;
|
||||
@property(Animation) private animation: Animation;
|
||||
@property(Sprite) private sprite: Sprite;
|
||||
|
||||
private input: IInput;
|
||||
private health: UnitHealth;
|
||||
@@ -32,7 +34,7 @@ export class Player extends Component {
|
||||
this.speed = data.speed;
|
||||
|
||||
this.weapon.init(data.strikeDelay, data.damage);
|
||||
|
||||
this.health.HealthPointsChangeEvent.on(this.animateHurt, this);
|
||||
this.playerUI.init(this.health);
|
||||
}
|
||||
|
||||
@@ -91,6 +93,12 @@ export class Player extends Component {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private async animateHurt(): Promise<void> {
|
||||
this.sprite.color = Color.RED;
|
||||
await delay(100);
|
||||
this.sprite.color = Color.WHITE;
|
||||
}
|
||||
}
|
||||
|
||||
export class PlayerData {
|
||||
|
Reference in New Issue
Block a user