refactor(mission): 优化肉鸽关卡及怪物生成逻辑
- 将出战英雄配置由数组改为单个英雄编号,简化相关接口和数据结构 - 统一出战英雄设置和获取方法,移除冗余多英雄管理逻辑 - 增加怪物生成时的强度倍率参数,支持怪物属性随关卡进度递增调整 - 扩展肉鸽模式配置,实现关卡类型区分及怪物数量动态计算 - 新增随机事件系统,支持事件关卡随机触发宝箱、陷阱、增益、减益等事件 - 优化怪物生成流程,整合怪物配置、等级和强度倍率信息,增强游戏体验
This commit is contained in:
@@ -9,7 +9,9 @@ import { GameEvent } from "../common/config/GameEvent";
|
||||
import {
|
||||
getStageMonsterConfigs,
|
||||
MonsterType,
|
||||
getStageType
|
||||
getStageType,
|
||||
EventType,
|
||||
getRandomEvent
|
||||
} from "./RogueConfig";
|
||||
import { MonModelComp } from "../hero/MonModelComp";
|
||||
|
||||
@@ -24,7 +26,8 @@ export class MissionMonCompComp extends CCComp {
|
||||
uuid: number,
|
||||
position: number,
|
||||
type: MonsterType,
|
||||
level: number
|
||||
level: number,
|
||||
strengthMultiplier: number
|
||||
}> = [];
|
||||
private isSpawning: boolean = false;// 是否正在生成怪物
|
||||
private spawnInterval: number = 0.1; // 每个怪物生成间隔时间
|
||||
@@ -32,6 +35,8 @@ export class MissionMonCompComp extends CCComp {
|
||||
private spawnCount: number = 0; // 召唤计数器
|
||||
private pauseInterval: number = 5.0; // 暂停间隔时间(5秒)
|
||||
private isPausing: boolean = false; // 是否正在暂停
|
||||
private currentEvent: EventType | null = null; // 当前关卡的随机事件
|
||||
private eventProcessed: boolean = false; // 事件是否已处理
|
||||
|
||||
|
||||
onLoad(){
|
||||
@@ -54,6 +59,12 @@ export class MissionMonCompComp extends CCComp {
|
||||
protected update(dt: number): void {
|
||||
if(!smc.mission.play||smc.mission.pause) return
|
||||
|
||||
// 处理随机事件
|
||||
if (this.currentEvent && !this.eventProcessed) {
|
||||
this.processRandomEvent();
|
||||
this.eventProcessed = true;
|
||||
}
|
||||
|
||||
// 处理刷怪队列
|
||||
if (this.monsterQueue.length > 0 && !this.isSpawning) {
|
||||
this.spawnTimer += dt;
|
||||
@@ -90,16 +101,51 @@ export class MissionMonCompComp extends CCComp {
|
||||
this.spawnCount = 0;
|
||||
this.isPausing = false;
|
||||
this.spawnTimer = 0;
|
||||
this.eventProcessed = false;
|
||||
|
||||
const currentStage = smc.data.mission;
|
||||
// 使用新的肉鸽关卡配置
|
||||
let level=smc.vmdata.mission_data.level
|
||||
const stageType = getStageType(currentStage,level);
|
||||
|
||||
// 检查是否为事件关卡
|
||||
if (stageType === "event") {
|
||||
this.currentEvent = getRandomEvent();
|
||||
} else {
|
||||
this.currentEvent = null;
|
||||
}
|
||||
|
||||
const monsterConfigs = getStageMonsterConfigs(currentStage,level);
|
||||
// console.log(`[MissionMonComp]:第${currentStage}关 - ${stageType}类型,怪物数量: ${monsterConfigs.length}`);
|
||||
this.generateMonstersFromStageConfig(monsterConfigs);
|
||||
}
|
||||
|
||||
// 处理随机事件
|
||||
private processRandomEvent() {
|
||||
if (!this.currentEvent) return;
|
||||
|
||||
switch (this.currentEvent) {
|
||||
case EventType.TREASURE:
|
||||
// 发送获得奖励事件
|
||||
smc.vmdata.mission_data.gold += 50; // 增加50金币
|
||||
// 可以触发UI提示
|
||||
// oops.message.dispatchEvent("event_treasure");
|
||||
break;
|
||||
case EventType.TRAP:
|
||||
// 对玩家造成伤害
|
||||
// 这里可以实现对玩家英雄造成伤害的逻辑
|
||||
// oops.message.dispatchEvent("event_trap");
|
||||
break;
|
||||
case EventType.BUFF:
|
||||
// 给玩家增加临时增益效果
|
||||
// oops.message.dispatchEvent("event_buff");
|
||||
break;
|
||||
case EventType.DEBUFF:
|
||||
// 给玩家增加临时减益效果
|
||||
// oops.message.dispatchEvent("event_debuff");
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// 根据新的关卡配置生成怪物
|
||||
private generateMonstersFromStageConfig(monsterConfigs: any[]) {
|
||||
@@ -114,7 +160,7 @@ export class MissionMonCompComp extends CCComp {
|
||||
|
||||
// 为每个怪物配置生成怪物
|
||||
monsterConfigs.forEach((monsterConfig: any, index: number) => {
|
||||
const { uuid, type } = monsterConfig;
|
||||
const { uuid, type, strengthMultiplier } = monsterConfig;
|
||||
|
||||
// 位置循环使用 (0-4)
|
||||
const position = index % 5;
|
||||
@@ -123,7 +169,8 @@ export class MissionMonCompComp extends CCComp {
|
||||
uuid,
|
||||
position,
|
||||
type,
|
||||
1 // 默认等级1
|
||||
1, // 默认等级1
|
||||
strengthMultiplier // 强度倍率
|
||||
);
|
||||
});
|
||||
|
||||
@@ -135,13 +182,15 @@ export class MissionMonCompComp extends CCComp {
|
||||
uuid: number,
|
||||
position: number,
|
||||
type: MonsterType,
|
||||
level: number = 1
|
||||
level: number = 1,
|
||||
strengthMultiplier: number = 1.0
|
||||
) {
|
||||
this.monsterQueue.push({
|
||||
uuid: uuid,
|
||||
position: position,
|
||||
type: type,
|
||||
level: level
|
||||
level: level,
|
||||
strengthMultiplier: strengthMultiplier
|
||||
});
|
||||
}
|
||||
|
||||
@@ -158,7 +207,8 @@ export class MissionMonCompComp extends CCComp {
|
||||
monsterData.position,
|
||||
isBoss,
|
||||
false,
|
||||
monsterData.level
|
||||
monsterData.level,
|
||||
monsterData.strengthMultiplier
|
||||
);
|
||||
|
||||
// 增加召唤计数
|
||||
@@ -172,14 +222,15 @@ export class MissionMonCompComp extends CCComp {
|
||||
i: number = 0,
|
||||
is_boss: boolean = false,
|
||||
is_call: boolean = false,
|
||||
lv: number = 1
|
||||
lv: number = 1,
|
||||
strengthMultiplier: number = 1.0
|
||||
) {
|
||||
let mon = ecs.getEntity<Monster>(Monster);
|
||||
let scale = -1;
|
||||
let pos: Vec3 = v3(MonSet[i].pos);
|
||||
|
||||
// 生成怪物
|
||||
mon.load(pos,scale,uuid,is_boss,is_call);
|
||||
mon.load(pos,scale,uuid,is_boss,is_call,strengthMultiplier);
|
||||
}
|
||||
|
||||
/** 视图对象通过 ecs.Entity.remove(ModuleViewComp) 删除组件是触发组件处理自定义释放逻辑 */
|
||||
|
||||
Reference in New Issue
Block a user