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

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2