Files
pixelheros/assets/script/game/map/CardUseComp.ts
walkpan 2f1af99a1b feat: 添加卡牌使用组件并集成至卡牌系统
- 新增 CardUseComp 组件,用于处理卡牌使用逻辑和效果分发
- 在 CardComp 中集成 CardUseComp,卡牌使用时触发效果事件
- 修改 MissionCardComp,任务开始时自动发牌至槽位
- 更新预制体资源,修复卡牌 UI 节点引用
2026-03-14 13:07:26 +08:00

68 lines
1.9 KiB
TypeScript

import { mLogger } from "../common/Logger";
import { _decorator } from "cc";
import { ecs } from "../../../../extensions/oops-plugin-framework/assets/libs/ecs/ECS";
import { CCComp } from "../../../../extensions/oops-plugin-framework/assets/module/common/CCComp";
import { CardType } from "../common/config/CardSet";
const { ccclass, property } = _decorator;
interface CardUsePayload {
uuid: number
type: CardType
cost: number
slotName?: string
}
/** 视图层对象 */
@ccclass('CardUseComp')
@ecs.register('CardUseComp', false)
export class CardUseComp extends CCComp {
private debugMode: boolean = true;
private useCount: number = 0;
onLoad() {
}
start() {
}
onCardUsed(payload: CardUsePayload) {
this.useCount += 1;
mLogger.log(this.debugMode, "CardUseComp", "onCardUsed", {
useCount: this.useCount,
...payload
});
this.executeCardEffectEntry(payload);
}
private executeCardEffectEntry(payload: CardUsePayload) {
const effectTag = this.getEffectEntryTag(payload.type);
mLogger.log(this.debugMode, "CardUseComp", "executeCardEffectEntry", payload);
mLogger.log(this.debugMode, "CardUseComp", "effect entry tag", effectTag);
}
private getEffectEntryTag(type: CardType): string {
switch (type) {
case CardType.Hero:
return "hero";
case CardType.Skill:
return "skill";
case CardType.Special:
return "special";
case CardType.Buff:
case CardType.Debuff:
return "buff";
default:
return "unknown";
}
}
/** 视图对象通过 ecs.Entity.remove(ModuleViewComp) 删除组件是触发组件处理自定义释放逻辑 */
reset() {
this.node.destroy();
}
}