CocosCreator实战篇 |CocosCreator实现《飞机大战》

2024-03-25 12:40

本文主要是介绍CocosCreator实战篇 |CocosCreator实现《飞机大战》,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 📢博客主页:肩匣与橘

  • 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!

  • 📢本文由肩匣与橘编写,首发于CSDN🙉

  • 📢生活依旧是美好而又温柔的,你也是✨


《飞机大战》

📝前言

一、素材准备

二、场景搭建

①背景

②主角战斗机

③敌方战机生成点

④分数UI

⑤副摄像机

三、脚本编写

Ⅰ主角战斗机

Ⅱ敌方战斗机

Ⅲ子弹

 Ⅳ背景

四、效果展示


📝前言

        飞机大战游戏是一款经典的射击游戏,玩家操控一个飞机进行空战任务,通过不断发射子弹摧毁敌方飞机来增加游戏的分数。本着界面简单,开发容易的原则,这款游戏也成为诸多游戏开发者的第一款上手项目。 本文将系统的介绍《飞机大战》游戏各个模块的实现。


一、素材准备

  1. Cocos Creator:本文展示的是2.4.8版本
  2. Visual Studio Code:脚本语言使用 Type Script
  3. 素材:背景图、己方飞机图、敌方飞机图、发射音效、飞机爆炸音效

二、场景搭建

①背景

游戏的移动展示分为角色移动 背景不动/角色移动 背景移动/角色不动 背景移动

这次项目采用的是角色不动 背景移动,通过背景循环实现无限地图,场景搭建如下:

使用三张背景图衔接

②主角战斗机

将主角战斗机放到场景中,并为其添加碰撞体,添加player脚本

③敌方战机生成点

        为方便初学者理解,本项目将设置一个空节点在场景上方,以此点为基准生成敌方战斗机

④分数UI

        创建文本组件,实现分数的计算

⑤副摄像机

        创建一个单独渲染背景的摄像机,并将背景的分组改为bg,副摄像机渲染选择渲染背景

三、脚本编写

  • 主角战斗机:飞机的位置实时保持鼠标移动的位置;发射子弹
  • 敌方战斗机:随机生成并向下飞行
  • 子弹:生成后自动往上发射
  • 背景:持续滚动

Ⅰ主角战斗机

        在主代码中编写鼠标回调,移动时,飞机的位置等于鼠标按下/滑动的位置

 this.node.on(cc.Node.EventType.TOUCH_MOVE,(event)=>{var pos=new cc.Vec2(event.getLocationX()-240,event.getLocationY()-426);console.log(pos);this.test.setPosition(pos);
});

 飞机自己的代码包含子弹预制体,发射子弹,碰撞回调(撞到敌机爆炸)

 //预制体@property(cc.Prefab)bulletPre: cc.Prefab = null;isDie: boolean = false;// LIFE-CYCLE CALLBACKS:// onLoad () {}start() {if (this.isDie == false) {//攻击  //计时器//参数: 方法   0.5秒调用一次  n次 第一次n个this.schedule(() => {//创建子弹let bullet = cc.instantiate(this.bulletPre);//设置父物体bullet.setParent(this.node.getParent());//设置子弹发射位置bullet.x = this.node.x;bullet.y = this.node.y + 80;let Playe: cc.AudioSource = this.getComponent(cc.AudioSource);cc.loader.loadRes("shot", cc.AudioClip, (res, clip) => {Playe.clip = clip;Playe.play();});}, 0.5);//开启碰撞cc.director.getCollisionManager().enabled = true;}}die() {this.isDie = true;//加载爆炸图cc.loader.loadRes("herodie", cc.SpriteFrame, (err, res) => {this.node.getComponent(cc.Sprite).spriteFrame = res;});cc.loader.loadRes("boom", cc.AudioClip, (res, clip) => {let audioId: number = cc.audioEngine.playMusic(clip, false);});//300毫秒销毁setTimeout(() => {this.node.destroy();}, 500);}update(dt) {}

Ⅱ敌方战斗机

        从生成飞机的点,随机生成敌机

//敌机预设题@property(cc.Prefab)enemyPre: cc.Prefab = null;// LIFE-CYCLE CALLBACKS:// onLoad () {}start () {//每个两秒创建一个敌机this.schedule(()=>{//创建敌机let Enemy = cc.instantiate(this.enemyPre);//设置父物体  场景Enemy.setParent(this.node.getParent());Enemy.y = this.node.y;//20-420  随机生成Enemy.x = Math.random()*400-200;},1.5);}

         敌机生成后,持续往下飞行,撞到子弹销毁,撞到主机游戏失败

  @propertyMovespeed :number = 600;//是否死亡isDie:boolean = false;public dieNum:number=0;// LIFE-CYCLE CALLBACKS:// onLoad () {}start () {}update (dt) {//移动if(this.isDie == false){this.node.y-=300*dt;}if(this.node.y<-850){this.node.destroy();}}die(){this.isDie = true;//加载爆炸图cc.loader.loadRes("enemydie",cc.SpriteFrame,(err,res)=>{this.node.getComponent(cc.Sprite).spriteFrame =res;});//300毫秒销毁setTimeout(() => {this.node.destroy();}, 300);}onCollisionEnter(other){//碰到主机,销毁自己,让主机死亡if(other.tag == 2){//主机销毁other.getComponent(Player).die();//自己销毁this.node.destroy();GameModel._ins.mainGame.gameEnd();}}

Ⅲ子弹

子弹设置为预制体,生成后子弹持续往上飞行,撞到敌机实现加分

 update (dt) {//移动this.node.y+=this.speed*dt;if(this.node.y>850){this.node.destroy();}}onCollisionEnter(other){//碰到敌人,销毁自己,让敌人死亡if(other.tag == 1){//敌人销毁other.getComponent(Enemy).die();//自己销毁this.node.destroy();}GameModel._ins.gameScore++;}

 Ⅳ背景

        背景为3张 持续往屏下方向移动,当移动到一定位置,将位置设置到最上方图片的上面----即可实现背景无限滚动

 update (dt) {//移动//遍历子物体(背景)for(let bgNode of this.node.children){//移动  帧->秒bgNode.y-=50*dt;if(bgNode.y<-852){bgNode.y+=852*3;}}}

四、效果展示

 


        本文我们讨论了使用Cocos Creator制作2D飞机射击游戏的过程。我们从创建项目开始,介绍了游戏场景和UI设计、角色控制、碰撞检测和动画效果等关键技术点,并提供了代码示例和说明。通过这个项目,我们深入了解了Cocos Creator引擎的强大功能和易用性。同时也积累了开发2D游戏所需的实践经验和技能。希望这篇文章对想要学习Cocos Creator游戏开发的读者有所帮助。

这篇关于CocosCreator实战篇 |CocosCreator实现《飞机大战》的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/845046

相关文章

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u