如何在不污染代码的情况下给大R玩家定制特殊服务

点击上方亿元程序员+关注和★星标

引言

大家好,我是亿元程序员,一位有着8年游戏行业经验的主程。

本系列是《和8年游戏主程一起学习设计模式》,让糟糕的代码在潜移默化中升华,欢迎大家关注分享收藏订阅。

为了在不污染代码的情况下定制服务,可以选择模板方法模式。

今天,我们就来聊聊 游戏开发中的模板方法模式 ,看看它是如何帮助我们不污染代码的情况下定制服务的。

本文源码和源工程在文末获取,小伙伴们自行前往。

什么是模版方法模式?

模板方法模式 (Template Method Pattern)是一种行为型设计模式 ,它定义了一个算法的骨架 ,将一些步骤延迟到子类 中实现。这样,子类可以在不改变算法结构 的情况下,重新定义 算法中的某些特定步骤 。在游戏开发中,模板方法模式可以帮助我们降低代码的耦合度,提高代码的复用性和可维护性

使用模板方法模式的示例代码

1.基础角色

首先我们定义一个基础的角色类Charater,初始化时添加动画组件 FrameAnim,该组件源码和教程可通过发送"FrameAnim "获取CocosCreator帧动画组件FrameAnim实现与使用,包含一个攻击方法attack,攻击完后待机

2.小R角色

然后我们定义一个小R角色类 继承基础角色,并且通过模板方法模式重写攻击方法 attack,小R角色的攻击方式是先移动再攻击,最后死亡

3.大R角色

最后我们定义一个大R角色类 继承基础角色,并且通过模板方法模式重写攻击方法 attack,大R角色的攻击方式是先移动再攻击,最后切回待机(money的作用是免死?)。

4.测试代码

分别创建三个角色CharaterSmallRCharaterBigRCharater,分别指定蜘蛛、小女孩和石头人

添加键盘事件qwe分别控制蜘蛛、小女孩和石头人攻击

5.结果演示

蜘蛛快速攻击 ,小女孩移动之后攻击 ,但是攻击完成后倒地 ,石头人移动之后攻击 ,攻击后毫发无损切换回待机状态

通过上面的代码,我们可以看到,角色类(Charater)定义了角色的基本行为 (攻击),并提供了一个模板方法 (attack),用于执行这些基本行为。具体的小R和大R角色类 (SmallRCharater,BigRCharater)则实现了自己的特定行为 。这样,我们就可以在不改变算法结构的情况下,轻松地为角色添加新的行为

结语

在哪里 可以看到如此清晰的思路,快跟上我的节奏!关注我 ,和我一起了解 游戏行业最新动态,学习游戏开发技巧。

本系列是《和8年游戏主程一起学习设计模式》,让糟糕的代码在潜移默化中升华,欢迎大家关注分享收藏订阅。

我是"亿元程序员",一位有着8年游戏行业经验的主程。在游戏开发中,希望能给到您帮助, 也希望通过您能帮助到大家。

AD:笔者线上的小游戏《贪吃蛇掌机经典》《重力迷宫球》《填色之旅》大家可以自行点击搜索体验。

实不相瞒,想要个在看 !请把该文章分享给你觉得有需要的其他小伙伴。谢谢!

推荐专栏:

8年主程手把手打造Cocos独立游戏开发框架

从零开始开发贪吃蛇小游戏到上线系列

游戏开发的技巧、心得、资讯

关注我,发送"模板方法模式"获取源码和源工程。

点击下方绿色按钮+关注

相关推荐
qiyi.sky几秒前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~4 分钟前
分析JS Crash(进程崩溃)
java·前端·javascript
安冬的码畜日常13 分钟前
【D3.js in Action 3 精译_027】3.4 让 D3 数据适应屏幕(下)—— D3 分段比例尺的用法
前端·javascript·信息可视化·数据可视化·d3.js·d3比例尺·分段比例尺
l1x1n040 分钟前
No.3 笔记 | Web安全基础:Web1.0 - 3.0 发展史
前端·http·html
昨天;明天。今天。1 小时前
案例-任务清单
前端·javascript·css
zqx_72 小时前
随记 前端框架React的初步认识
前端·react.js·前端框架
惜.己2 小时前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
什么鬼昵称3 小时前
Pikachu-csrf-CSRF(get)
前端·csrf
长天一色3 小时前
【ECMAScript 从入门到进阶教程】第三部分:高级主题(高级函数与范式,元编程,正则表达式,性能优化)
服务器·开发语言·前端·javascript·性能优化·ecmascript
NiNg_1_2343 小时前
npm、yarn、pnpm之间的区别
前端·npm·node.js