二,升级玩家的技能

news/2025/1/13 3:08:35/
  1. 添加控制

1.1单击虚幻编辑器菜单的编辑——》项目设置(project settings)——》引擎分类——》输入(input)——》绑定(binding)——》action mappings(监听按键和鼠标单击事件触发玩家动作)axis mappings(针对的玩家移动和事件都有个范围)(Action Mapping:动作映射,是一个一次性的输入。包括两个状态,一个是按下按键的状态,一个是释放按键的状态。Axis Mapping:轴映射,是每帧都持续性的输入。向前是正值向后是负值,向右是正值向左是负值。一直按着键盘w前进)——》点击两次操作映射边上加号,将第一个重命名为sprint(冲刺)第二个改为zoom(快速移动),下拉菜单选择左shift键与sprint事件绑定,zoom与鼠标右键绑定

1.2添加冲刺功能

在事件图表空白处单击鼠标右键,搜索sprint,选择输入》动作事件》sprint(input action sprint)

在组件面板拖出character movement(继承),从character movement节点的输出引脚拖出到空白,勾选情境关联,搜索walk speed,找到Max walk speed将,输入动作sprint节点的pressed输出执行引脚与设置Max walk speed节点的输入执行引脚连接,使得按下左shift键时能够修改最大移动速度,将最大行走速度由默认数值0.0改为2200,为了确保松开左shift键时能减速,再从角色移动(charactor movement)拖出移动拖出引线搜索并添加另一个Max walk speed节点,连接输出动作sprint节点的released输出执行引脚,然后将Max walk speed的默认值0.0改为600,添加注释sprint(冲刺)编译保存

  1. 制作瞄准镜效果

2.1减小视野

在时间图标空白区域单击鼠标右键搜索zoom(input action zoom)触发器节点并添加,在组件面板找到first person camera拖出引线搜set field of view(变量)节点,并连接set field of view内的目标(希望改动first person camera组件中的FOV值),默认视野是90,改为45(放大后观看其他物品会产生形变)

2.2使用时间轴使视野平滑转换

断开2.1中的输入操作zoom节点的pressed输出执行引脚的连接,从输入操作zoom节点的pressed拖出引线搜索添加时间轴(Add time line)(时间轴允许在指定的时间内改变一个值比如摄像机的视野)

双击时间轴节点,打开时间编辑器(左上角四个按钮都能添加一个不同类型的并且在时间轴过程中改变的值)(f+是浮点型轨迹(Add float track))

按住shfit在(0,0)点附近单击(或者在(0,0)点附近单击鼠标右键》添加关键帧),图表左上角可以看到时间和数值区域,改为(0.0,90)(时间,值),长度改为0.3(将动画限制在0.3秒内完成),再用shift单击白色区域末端,改为(0.3,45)(代表着此动画被调用时视野会平滑的放大,从90到45)

从时间轴_0节点的field of view输出引脚拖出引线至设置(set),连接时间轴_0的update输出执行和设置的输入执行(将FOV通过新的值给执行函数来随时更新)

从输入动作zoom节点的released引脚引出引线连接至时间轴节点的reverse引脚(松开右键时原来拉近视野的动画倒着播放,起到取消放大视野的效果)

编译,保存

3,加快子弹速度

打开子弹蓝图,组件面板选择projectile,在细节面板更改属性,找到initial speed(初速度)和Max speed(最大速度)都更改为6000

在projectile bounces找到should bounce取消勾选(移除了反弹属性)

编译,保存

4,添加音效和粒子效果

打开cylinder target蓝图,找到事件hit节点组,创建分支(branch)节点,创建一个primed布尔变量(勾选可编辑)拖出选获取,并连接分支的condition,断开类型转换first person projectile节点和set material节点的连接,类型转换first person projectile节点的输出执行引脚和分支的输入执行引脚相连

分支节点以及激活,所以给目标圆柱体一些指令来响应每个状态(默认(default),击中一次(primed),销毁(destroyed)),由于销毁一个actor不能执行任何行为,所以在目标销毁后就不能有任何行为发生,因此只需关注默认、击中一次这两种状态

先完成默认状态(监听当圆柱体每一次被击中后圆柱体上发生的事件),现在被第一次击中,我们要将primed布尔变量设为真(true),当目标再次被击中,分支节点把行为传给其他执行队列,勾选set的primed(保证被二次击中时,分支判定结果为真),节点假的执行队列如下

从分支true拖出引脚搜play sound at location节点(承载一个声音文件和一个位置输入,并在该位置播放声音)(此项目中有几个默认声音文件资源),单击sound输入引脚旁的选择资源,找到并选择Explosion01作为爆炸音效。

本身需要定义在哪里播放这个声音,本身需要将位置向量与声音节点之间连起来,世界Hit

触发器将事情简化了,事件Hit节点的输出引脚之一为Hit location(包含了被事件Hit节点检测到的游戏世界中的两个对象发生碰撞的位置信息),这个位置很好,从事件Hit节点的Hit location引脚拖出引线与play sound at location节点的location引脚相连接。

编译,保存

  1. 触发爆炸、销毁

从play sound at location节点的执行引脚拖出引线搜索并添加spawn emitter at location节点

spawn emitter at location节点和play sound at location节点类似,多了旋转输入引脚和auto destroy开关,在emitter template选择P_Explosion(将在发射器被添加的地方产生一个爆炸效果)

希望爆炸效果和爆炸音效在同一个位置生成,从事件Hit节点的Hit Location引脚拖出引线与spawn emitter at location节点的location引脚相连接,auto destroy开关(决定粒子发生器是否能被多次触发,一旦这个粒子效果被创建,我们就将包含这个粒子发射器的actor销毁,所以勾选auto destroy)从spawn emitter at location节点的输出执行引脚拖出引线,搜索destroy actor节点(可以暂时将情境关联取消)并添加

编译,保存


http://www.ppmy.cn/news/710296.html

相关文章

技能冷却

效果 代码 [csharp] view plain copy print ? using UnityEngine; using System.Collections; public class SkillControl : MonoBehaviour { public UISprite sprite; bool state false; // Use this for initialization void Start () { …

各种技能树

地址: 前端技能图谱 基础 HTML / CSSJavaScriptDOM 中级篇 数据格式(如JSON、XML)RESTful API交互(如jQuery Ajax,Fetch API,ReactiveX)正则表达式HTML语义化命令行Node.jsDIV / CSSSCSS / SAS…

技能冷却功能实现

搭建UI界面 搭建如图所示界面。先创建两个按钮,将text删除即可黄色的作为背景,技能冷却的一栏在背景之上。 将技能冷却的一栏图片透明度调整。 编写代码 using UnityEngine; using UnityEngine.UI;public class L8Jineng : MonoBehaviour {Image mask…

技能冷却: 判断技能 释放技能

技能冷却: 判断技能 释放技能 using System.Collections; using System.Collections.Generic; using UnityEngine; public class skillButton : MonoBehaviour { playernimator playerAnimation; public PosType posType PosType .Basic;//根据这个枚举位置判…

晓月_技能栏(二)显示技能和技能冷却

UI编辑部分: ​上次分析了技能栏的显示层次,今天动手实现以下。本次还是4.6的版本,大家看下思路就好了。 ​1:首先找张技能图片,因为我的是一个拿剑的角色。我找了张剑的icon,然后指定给UITexture ​2:因为…

代理模式:英雄的普攻和技能伤害值统计

一、模式定义 代理模式为另一个对象提供一个替身或占位符以控制对这个对象的访问。相关组件 Subject:Proxy和RealSubject都实现这个接口,以供客户端可以像处理RealSubject一样处理Proxy。RealSubject:真正做事的对象,Proxy会控制…

技能是如何形成

技能是如何形成 前言一、学以致用二、间断复习是形成长期记忆的唯一方法三、长期记忆终点在于形成创造性思维 总结 前言 我们学习目的是为了形成技能,讨论技能如何形成有利于对自身学习方法改造。为了明晰讨论这个问题,这里把本人观点逻辑说明一下。 学…

【技能】前端技能列表

一、基础 1. HTML 相关 2. CSS 相关 3. JavaScript 相关 类别初级高级HTMLHTML5CSSCSS3Less,SassJSJavaScriptES6,TypeScript 二、框架 1. Vue Vue2 一般使用的是Vue2.6.0 版本,此版本为插槽引入了一个新的统一的语法 (即 v-slot 指令…