VUE+WebPack前端游戏设计:实现外星人攻击建筑物时的冒烟效果

本文主要是介绍VUE+WebPack前端游戏设计:实现外星人攻击建筑物时的冒烟效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

玩过红警或是星际的玩家都知道,当子弹或对手攻击建筑物时,建筑物会产生冒烟效果,并且逐步变形,当攻击足够大后,建筑物会爆炸毁灭,这种动态特效极大的增强了游戏的视觉观赏性和娱乐性,本节我们就实现外星人与玩家的道具碰撞时所产生的冒烟效果,这种效果提醒玩家道具正在遭受攻击,完成本节后,效果如下:

这里写图片描述

文本难以观看动态效果,更详细的讲解和代码调试演示过程,请点击链接

我们看看上图效果是如何实现的。我们先修改建筑物的属性,使得它具有能量值,一旦能量值降为0后,它就相当于被外星人摧毁:

building () {var b = new this.cjs.Container()b.cost = 0// change hereb.shield = 10b.damageDeal = 0b.attackSpeed = 9999return b},

每种具体的建筑物会根据自身特点修改上面代码添加的属性值。当建筑物受到攻击时,它要掉血,一旦掉血过多就得从页面上被抹除,实现代码如下:

 buildingDamage (building, damage) {var realDamage = Math.max(damage, building.shield, 0)building.hp -= realDamageif (building.hp <= 0 && building.parent) {this.removeBuilding(building)}},
removeBuilding (building) {this.boardLayer.buildingMap[building.col][building.row] = undefinedthis.boardLayer.removeChild(building)},

代码中的hp值对应的就是建筑物的能量,传入的参数damage是外星人的攻击力,sheild对应的是建筑物的抵抗力,如果攻击力大于抵抗力,那么建筑物就会收到打击,于是hp的值就会减少,一旦该值减少到小于0后,建筑物就会被从页面上清除。建筑物在拖动到页面上时,会根据它所在的行和列将建筑物对应的对象记录在数组buildingMap里,这个数组在后面会用来判断建筑物和外星人是否产生碰撞,当建筑物从页面上消除时,数组对应的位置设置成undefined,然后建筑物从板块图层对象中删除掉。

外星人有两种状态,一是正在发动攻击,一是正在从上往下落,因此我们要增加外星人对象的相关属性用于标记这两种状态:

enemy () {var enemyObj = new this.cjs.Container()enemyObj.originalSpeed = 0.5enemyObj.deceleration = 0.4enemyObj.hp = 10enemyObj.damageDeal = 10enemyObj.attackSpeed = 100enemyObj.speed = enemyObj.originalSpeed// change hereenemyObj.isAttacking = falseenemyObj.attackingTarget = undefinedenemyObj.attackingSmoke = new this.assetsLib.Explode()enemyObj.attackingSmoke.y = 50return enemyObj},

isAttacking用于记录外星人是否处于攻击状态,attackingTarget用于记录被攻击的建筑物,当攻击发生时会产生出冒烟的动画效果,冒烟效果其实是一种动态的图片资源,这个资源我们调用assetsLib.Explode()加载到页面,而attackingSmoke属性对应的就是冒烟图片资源,attackingSmoke.y表示冒烟特效图片在页面上的y坐标,这个在后面代码中会有所改变。

外星人对象对应着一个时钟回调函数,在这个函数里会修改外星人在页面上的y坐标,使得外星人产生从高处往下落的动态效果,我们利用这个回调函数来检测外星人是否属于攻击状态,代码如下:

enemyTick (enemyObj) {....// change hereif (this.cjs.Ticker.getTicks() % enemyObj.attackSpeed === 0) {if (enemyObj.isAttacking && enemyObj.attackingTarget) {this.buildingDamage(enemyObj.attackingTarget, enemyObj.damageDeal)}}}

在修改外星人属性时,我们增加一个attackSpeed属性,该属性用于设置检测外星人是否处于攻击状态的频率,这个值设置的是100,也就是主循环没经过100个ticks就去检测外星人对象是否跟道具相碰撞了。如果isAttacking属性为真,并且它对应的attackingTarget指向具体的对象,这个对象就是外星人要攻击的道具,于是调用buildingDamage函数实现道具的hp值减少。

接着我们实现外星人与道具碰撞的检测,一旦两者遇上,我们在页面上释放出冒烟特效。添加如下代码:

enemyAttackBuilding () {// 当外星人与道具相遇时,攻击道具for (var i = this.enemyList.length - 1; i >= 0; i--) {var enemy = this.enemyList[i]var row = enemy.rowvar col = enemy.colvar targetif (this.boardLayer.buildingMap[col][row] !== undefined) {target = this.boardLayer.buildingMap[col][row]} else if (this.boardLayer.buildingMap[col][row + 1] !== undefined) {target = this.boardLayer.buildingMap[col][row]}if (target !== undefined) {enemy.speed -= enemy.decelerationthis.enemyStartAttack(enemy, target)} else {this.enemyStopAttack(enemy)}target = undefined}},

当道具拖动到页面上时,我们会计算道具在板块图层行和列,根据它所在的行和列把道具对象存储在buildingMap数组里。在外星人从上外下坠落的过程中,代码也随着根据外星人所在的坐标计算其在板块图层上的行和列,然后用计算的行和列到数组buildingMap里面查询,一旦查询到的对象不为空,那意味着外星人当前所在的位置有一个道具对象,于是两种就相遇了,然后代码调用enemyStartAttack()接口启动攻击流程,如果当前位置没有道具对象,或者说原来这个位置有道具对象,由于道具对象的hp值减少为0然后从页面上抹除后,那么就调用enemyStopAttack()接口停止攻击流程。我们看看这两个函数的实现:

enemyStartAttack (enemy, target) {if (!enemy.isAttacking) {enemy.isAttacking = trueenemy.addChild(enemy.attackingSmoke)}enemy.attackingTarget = target},// change hereenemyStopAttack (enemy) {if (enemy.isAttacking) {enemy.removeChild(enemy.attackingSmoke)}enemy.isAttacking = falseenemy.attackingTarget = undefinedenemy.speed = enemy.originalSpeed},

当调用enemyStartAttack时,它会把外星人的isAttacking属性设置为True,然后将attackingSmoke对象通过addChild加载到页面上,前面我们说过,这个对象对应的是冒烟的动画资源,当加载到页面上时,我们就可以看到冒烟动画呈现出来了。enemyStopAttack调用时,代码会通过removeChild把冒烟动画资源从页面上去除,这样页面上就不再显示冒烟的动画。

最后我们在boardTick函数里调用上面的enemyAttackingBuilding函数:

boardTick() {
....
this.enemyAttackBuilding()
}

完成上面的代码后,本节的功能就完成了,外星人会徐徐往下落,一旦途中遇到道具对象,那么它就启动冒烟动画,一旦道具的hp值减少为0,程序会消除冒烟动画,同时外星人继续往下回落。

更详细的讲解和代码调试演示过程,请点击链接

欢迎关注公众号,让我们一起学习,交流,成长:
文章公众号.jpg

这篇关于VUE+WebPack前端游戏设计:实现外星人攻击建筑物时的冒烟效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu