虚幻UE 增强输入-第三人称模板增强输入分析与扩展

2024-01-05 01:04

本文主要是介绍虚幻UE 增强输入-第三人称模板增强输入分析与扩展,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇是增强输入模块,作为UE5.0新增加的模块。
其展现出来的功能异常地强大!
让我们先来学习学习一下第三人称模板里面的增强输入吧!

文章目录

  • 前言
  • 一、增强输入四大概念
  • 二、使用步骤
    • 1、打开增强输入模块
    • 2、添加IA输入动作
    • 2、添加IMC输入映射内容
    • 3、绑定IMC到EIPS增强输入本地用户子系统
    • 4、具体按键实现逻辑
  • 三、测试其他特性
    • 1、同一按键 不同Map先后
    • 2、不同按键(组合键
    • 3、运行时按键控制
  • 总结
  • 参考


前言

为什么要开发出一个新的输入模式呢?
是因为旧的输入模式不好吗?其实并不是,而是不够灵活、方便,
且一般只能实现简单的功能,如果需要复杂的功能得自己写逻辑了,
比如按住、双击、联合输入等
所以就开发了一个新的输入模式----增强输入(Enhanced Input System)


一、增强输入四大概念

增强输入主要提出了四个概念:

输入动作(UInputAction): 是增强输入系统和项目代码之间的通信链接。
和我们的按键无关,只知道按键的状态,也就是是否按下。 输入修改器(UInputModifier):用于修改来自用户设备的原始输入值。
也就是可以对按键的状态进行修改输入触发器(UInputTrigger): 使用经过修饰器修改的输入值,
或者使用其他输入动作的输出值,来确定是否激活输入动作。输入映射内容(UInputMappingContext): 将用户输入映射到输入动作,
并可以动态地为每个用户添加、移除或安排优先次序。和按键有关。

二、使用步骤

1、打开增强输入模块

开启增强输入插件
在这里插入图片描述
修改默认的输入模式为增强输入
在这里插入图片描述

2、添加IA输入动作

在这里插入图片描述

原先的Action绑定:
在这里插入图片描述
原先的Axis绑定:(也可以把左右移动、上下移动写在一个IA里,用2D来表示在这里插入图片描述

2、添加IMC输入映射内容

在这里插入图片描述

按键绑定:(修改器中Negate是相反的意思,就是把修饰器修改的输入值,
或者使用其他输入动作的输出值进行取反

3、绑定IMC到EIPS增强输入本地用户子系统

在这里插入图片描述

4、具体按键实现逻辑

在这里插入图片描述
在这里插入图片描述
这样一个简单的第三人称模板的输入就搞定了!

注意:我们这里接触到是输入修改器(UInputModifier)暂时只有Negate反向,
但其实在第三人称模板内,还涉及了:


盲区DeadZone为了解决两个问题:
1、如果用户没有按下任何键,系统通常会将输入视为无效或忽略。
2、当用户只是暂时释放了按键,但很快又按下时,系统可能无法正确地响应他们的输入。
解决方式:当用户在一定时间内没有按下任何键时,系统可以忽略他们的输入,以避免误操作或干扰游戏进程。同时,当用户按下某个键时,系统可以快速地响应并执行相应的动作,提供更好的游戏体验。


拌合输入轴值Mixed Axis Values为了解决的问题:
1、将1D输入(例如键盘按键)映射到2D或3D空间的问题。
简单的来说就是同时按下W和A键时,如何判断移动的方向?
拌合输入轴值允许开发者将多个轴值组合在一起,形成更复杂的输入动作。

三、测试其他特性

两份功能一模一样的IA和IMC
在这里插入图片描述

1、同一按键 不同Map先后

结论:后进先出 

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1、改变优先级  优先级越大越优先

在这里插入图片描述

2、consume input为false(默认为true,如果最后mapping的那个为false的话不会影响其他的输入
Consume Input 允许开发者控制输入事件是否被处理或传递给其他系统或组件。
通过使用 Consume Input,开发者可以拦截用户的输入行为,并进行自定义处理,
而不需要将输入传递给其他组件或系统。

在这里插入图片描述
在这里插入图片描述在这里插入图片描述

2、不同按键(组合键

在这里插入图片描述
组合键
1和2一起按才打印
两个IA都要加入到Mapping 此时单独按1 没有用
在这里插入图片描述
此时1和2一起按下
在这里插入图片描述

3、运行时按键控制

运行时加入
刚运行时按2没有反应 当按下1后 2才有反应在这里插入图片描述
运行时离开
1和2随便按 再按3 后来又1和2随便按 最后发现1已经失效在这里插入图片描述


总结

增强输入的功能太强了,远不止我所展示的这么多,
还有很多功能需要再研究,等待后续发掘!!!
关注不迷路!!!


参考

UE5.0官方中文文档:虚幻引擎中的增强输入

这篇关于虚幻UE 增强输入-第三人称模板增强输入分析与扩展的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

poj 2104 and hdu 2665 划分树模板入门题

题意: 给一个数组n(1e5)个数,给一个范围(fr, to, k),求这个范围中第k大的数。 解析: 划分树入门。 bing神的模板。 坑爹的地方是把-l 看成了-1........ 一直re。 代码: poj 2104: #include <iostream>#include <cstdio>#include <cstdlib>#include <al