用23种设计模式打造一个cocos creator的游戏框架----(十一)桥接模式

1、模式标准

模式名称:桥接模式

模式分类:结构型

模式意图:将抽象部分与其实现部分分离,使它们都可以独立地变化。

结构图:

适用于:

1、不希望在抽象和它的实现部分之间有一个固定的绑定关系。例如,这种情况可能是因为,在程序运行时刻实现部分应可以被选择或者切换。

2、类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充。这是 Bridge 模式使得开发者可以对不同的抽象接口和实现部分进行组合,并分别对它们进行扩充。

3、对一个抽象的实现部分的修改应对客户不产生影响,即客户代码不必重新编译

4、想在多个对象间共享实现 (可能使用引用计数),但同时要求客户并不知道这一点

主要成员:

  • 抽象类(Abstraction):定义和保存客户端的引用,维护与实现对象之间的关联关系。
  • 扩展抽象类(Refined Abstraction):扩展和精化抽象类中的接口定义。
  • 实现类接口(Implementor):定义实现类的接口,可以与抽象类的接口相互独立。
  • 具体实现类(Concrete Implementor):具体实现接口,在不同的实现类中提供基本操作的不同实现。

2、分析与设计

桥接模式,通俗点讲就如同嫁接,比如有一个树,会开花结果,我给它嫁接苹果枝,在开花结果后,长的是苹果。如果嫁接橘子枝,在开花结果后,长的是橘子。

在游戏开发中,可能会用在角色的武器切换上,不同的武器拥有不同的攻击方式。拥有剑就拥有了剑的攻击效果,拥有弓箭就拥有弓的攻击效果。下面我们来描述一下新的意图

意图:将抽象部分(攻击)与其实现部分(剑攻击还是弓箭攻击)分离,使它们都可以独立地变化(剑有剑的攻击效果,弓有弓的攻击效果)。

3、开始打造

TypeScript 复制代码
// 武器接口
export interface IWeapon {
    attack()
}
TypeScript 复制代码
// 剑
export class Sword implements IWeapon {
    attack(): void {
        console.log("攻击使用了剑");
    }
}
TypeScript 复制代码
// 弓
export class Bow implements IWeapon {
    attack(): void {
        console.log("攻击使用了弓");
    }
}
TypeScript 复制代码
// 抽象攻击者
export abstract class Fighter {
    protected weapon: IWeapon;

    constructor(weapon: IWeapon) {
        this.weapon = weapon;
    }

    attack(): void {
        this.weapon.attack();
    }

    setWeapon(weapon: IWeapon): void {
        this.weapon = weapon;
    }
}
TypeScript 复制代码
// 骑兵
export class Cavalry extends Fighter {
    constructor(weapon: IWeapon) {
        super(weapon);
    }
}

4、开始使用

TypeScript 复制代码
export class UnitItem extends Component implements IItem, IUnitItem {

    private ad: number = 100;
    private role: Fighter;

    accept(visitor: IAttackVisitor) {
        visitor.visitUnitItem(this)
    }

    async attack(unitItem: UnitItem<T>) {
        this.role.attack(); // 攻击

        let damage = this.ad
        let attackVisitor = new MonomerAttackVisitor(damage)
        unitItem.accept(attackVisitor)
    }

    setRole(role: Fighter): void {
        this.role = role;
    }
}
TypeScript 复制代码
let unitItem001 = xhgame.itemFactory.createUnitItem('shibing_001')
let unitItem002 = xhgame.itemFactory.createUnitItem('shibing_002')

unitItem001.setRole(new Cavalry(new Sword()));
console.log('unitItem001(骑兵)使用【剑】对unitItem001发起了攻击')
unitItem001.attack(unitItem002)

unitItem001.setRole(new Cavalry(new Bow()));
console.log('unitItem001(骑兵)使用【弓】对unitItem001发起了攻击')
unitItem001.attack(unitItem002)
相关推荐
ujainu8 小时前
Flutter + OpenHarmony 游戏开发进阶:用户输入响应——GestureDetector 实现点击发射
flutter·游戏·openharmony
ujainu9 小时前
Flutter + OpenHarmony 实现无限跑酷游戏开发实战—— 对象池化、性能优化与流畅控制
flutter·游戏·性能优化·openharmony·endless runner
呆呆敲代码的小Y10 小时前
【Unity工具篇】| 超实用工具LuBan,快速上手使用
游戏·unity·游戏引擎·unity插件·luban·免费游戏·游戏配置表
我的offer在哪里11 小时前
用 Unity 从 0 做一个「可以玩的」游戏,需要哪些步骤和流程
游戏·unity·游戏引擎
串流游戏联盟11 小时前
启程!手机也能邂逅暖暖万相奇观
游戏·远程工作
User_芊芊君子12 小时前
HCCL高性能通信库编程指南:构建多卡并行训练系统
人工智能·游戏·ai·agent·测评
J_liaty12 小时前
23种设计模式一代理模式
设计模式·代理模式
前端不太难15 小时前
HarmonyOS 游戏里,Ability 是如何被重建的
游戏·状态模式·harmonyos
灵狐数据FoxData17 小时前
QQ农场今日回归,我们想“偷”回的到底是什么?
游戏·社交电子·业界资讯·娱乐·玩游戏
微祎_17 小时前
Flutter for OpenHarmony:构建一个 Flutter 平衡球游戏,深入解析动画控制器、实时物理模拟与手势驱动交互
flutter·游戏·交互