003InputSystem新输入系统学习工作笔记

embedded/2024/11/14 13:15:22/

InputSystem新输入系统学习工作笔记

一、概述及理论学习

一种新的输入系统,可以用作UnityEngine.Input 中针对 Unity 典型输入系统的更具扩展性和可自定义的替代方案。

二、Demo案例学习

1**、首先是导入InputSystem包**

打开Package Manager面版,面版左上角选择“Unity Registry”选项,并在右上角搜索框架中输入插件名称“InputSystem”,如下图

点击“Install”进行安装

打开Unity的”Project”面版的“Packages”文件夹,InputSystem包已经安装好了,如下图

Unity支持通过两个独立的系统输入,一个旧的,一个新的。可以选择旧的,也可以选择新的,或者全都支持,通过面版“Project Settings”的Player项的Other Settings项目的“Active Input Handling*”指定三种选项进行支持,如下图

我们可以选择”Both”,让项目同时支持两种输入系统

2**、建立DEMO场景进行演示**

Unity建立一个简单的场景,中间建了一个雪人作为我们的主角,如下图

3**、创建并分配默认的项目范围操作project-wide actions**

input system将你的输入配置存储在Actions Asset中。首次安装输入系统包时,必须创建此Actions Asset。你可以通过转到Edit > Project Settings > Input System Package > Input Actions,然后单击”Create settings asset”按钮来完成此操作。

4**、默认****Action Maps and Actions**

Action Maps允许您将actions组织成组,这些组代表一组动作在一起有意义的特定情况。 Input System的默认配置有两个Action Maps: “Player” 和“UI”。这些都包含默认操作,通常分别对游戏和用户界面交互有用。

“Player”Action Maps定义了几个与游戏相关的动作,如“移动”、“看”、“跳跃”和“攻击”动作。“UI”Action Maps定义了几个与用户界面相关的动作,如“导航”、“提交”和“取消”。

每个默认操作都绑定到几种不同类型的控件。例如:

“移动”动作绑定到“WSAD”键盘键和箭头键、游戏手柄棒、XR控制器上的主2D轴

“跳跃”动作绑定到空格键、游戏手柄上的“南”按钮和XR控制器上的辅助按钮。

我们开始建立Action Maps

在“Project”面版新建一个文件夹”Input SystemDemo”作为DEMO的演示目录,右键点击 Create->Input Actions建立我们的Input Actions,如下图

然后将建立的Input Actions重命名为“InputControls”,然后在”InputControls”选中的情况下点击”Generate C# Class”复选框可以生成相应的C#代码,点击“Apple”才能生成代码,如下图

可以看到在“InputControls”同级目录下会生成同名的代码“InputControls.cs”,这个代码后面我们会用到。

然后点击“Inspector”面版的“Edit asset”按钮,打开“Player (Input Actions)”面版,在上面面版的左边“Action Maps”处点击“+”按钮生成一个“Action Maps”,并重命名为“Player”,将默认生成的Actions重命名为LeftMove,如下图

选择”LeftMove”下面的“”,然后映射它的按键,我们设置为“A”,如下图

重复以上步骤建立三个Actions即“RightMove”、“UpMove”和“DownMove”,分别对应“D”、“W”和“S”,如下图

然后我写个测试代码,邦定上面的四个按钮的响应函数,建立脚本“SnowManTest.cs”,将移动上面场景中的“snowman”对象上,双击脚本进行编辑,代码如下

using System.Collections;

using System.Collections.Generic;

using UnityEngine;

using UnityEngine.InputSystem;

public class SnowManTest : MonoBehaviour

{

private InputControls m_InputControls;

private bool m_LeftMove = false;

private bool m_RightMove = false;

private bool m_UpMove = false;

private bool m_DownMove = false;

private void OnEnable()

{

m_InputControls = new InputControls();

m_InputControls.Enable();

m_InputControls.Player.LeftMove.started += OnLeftMove;

m_InputControls.Player.LeftMove.canceled += OnLeftCancel;

m_InputControls.Player.RightMove.started += OnRightMove;

m_InputControls.Player.RightMove.canceled += OnRightCancel;

m_InputControls.Player.UpMove.started += OnUpMove;

m_InputControls.Player.UpMove.canceled += OnUpCancel;

m_InputControls.Player.DownMove.started += OnDownMove;

m_InputControls.Player.DownMove.canceled += OnDownCancel;

}

// Start is called before the first frame update

void Start()

{

}

private void OnLeftMove(InputAction.CallbackContext Obj)

{

m_LeftMove = true;

}

private void OnLeftCancel(InputAction.CallbackContext Obj)

{

m_LeftMove = false;

}

private void OnRightMove(InputAction.CallbackContext Obj)

{

m_RightMove = true;

}

private void OnRightCancel(InputAction.CallbackContext Obj)

{

m_RightMove = false;

}

private void OnUpMove(InputAction.CallbackContext Obj)

{

m_UpMove = true;

}

private void OnUpCancel (InputAction.CallbackContext Obj)

{

m_UpMove = false;

}

private void OnDownMove(InputAction.CallbackContext Obj)

{

m_DownMove = true;

}

private void OnDownCancel(InputAction.CallbackContext Obj)

{

m_DownMove = false;

}

// Update is called once per frame

void Update()

{

float horizontal = 0;

float vertical = 0;

if(m_LeftMove && m_RightMove)

{

horizontal = 0;

}

else if(m_LeftMove)

{

horizontal = -0.5f;

}

else if(m_RightMove)

{

horizontal = 0.5f;

}

if(m_UpMove && m_DownMove)

{

vertical = 0;

}

else if(m_UpMove)

{

vertical = 0.5f;

}

else if(m_DownMove)

{

vertical = -0.5f;

}

// 计算移动量

Vector3 movement = new Vector3(horizontal, 0.0f, vertical) * 5 * Time.deltaTime;

// 移动物体

transform.Translate(movement);

if (Keyboard.current.spaceKey.wasPressedThisFrame)

{

Debug.Log(“Space key was pressed”);

}

}

}

注意上面的代码行m_InputControls.Enable(); 如果没有这行是不起作用的

然后,我们运行DEMO,当我们点击W,S,A,D四个键时“snowman”就会前后左右的移动。


http://www.ppmy.cn/embedded/114163.html

相关文章

滚雪球学SpringCloud[6.2讲]: Zipkin:分布式追踪系统详解

全文目录: 前言Zipkin的工作原理与性能优化1. Zipkin的详细工作机制a. Span和Trace的底层逻辑b. Zipkin中的采样机制c. Zipkin的数据传输与存储 2. 性能优化:如何利用Zipkin定位系统瓶颈a. 请求延迟分布分析b. 请求链路优化c. 错误定位与异常检测 Zipkin…

分享一个 在线拍卖系统 商品竞拍平台Java、python、php三个技术版本(源码、调试、LW、开题、PPT)

💕💕作者:计算机源码社 💕💕个人简介:本人 八年开发经验,擅长Java、Python、PHP、.NET、Node.js、Android、微信小程序、爬虫、大数据、机器学习等,大家有这一块的问题可以一起交流&…

Kubernetes故障排除全面指南

Kubernetes故障排除全面指南 引言 在Kubernetes(K8s)环境中,故障排除是一项关键技能。本文将深入探讨K8s故障排除的各个方面,包括集群和节点、集群组件、资源监控、容器日志管理以及服务和网络问题。我们将通过具体案例来说明每个方面的故障排除过程。 1. 对集群和节点进行故…

PyTorch中的学习率预热(warmup)

PyTorch提供了学习率调度器(learning rate schedulers),用于在训练过程中实现各种调整学习率的方法。实现在torch.optim.lr_scheduler.py中,根据epoch数调整学习率。大多数学习率调度器可以称为背对背(back-to-back),也称为链式调度器&#x…

spark 读es

idea maven 依赖 <dependency> <groupId>org.elasticsearch</groupId> <artifactId>elasticsearch-hadoop</artifactId> <version>7.11.1</version> </dependency> <dependency> <groupId>org.elasticsearch.cl…

Python和C++气候模型算法模型气候学模拟和统计学数据可视化及指标评估

&#x1f3af;要点 贝叶斯推理气候模型辐射对流及干湿能量平衡模型时间空间气象变化预测模型评估统计指标气象预测数据变换天气和气象变化长短期影响预估降低气候信息尺度评估算法气象行为模拟&#xff1a;碳循环、辐射强迫和温度响应温室气体排放碳循环温室诱导气候变化评估气…

企业微信应用消息收发实施记录

一、前置配置 1.1 进入我的企业页面&#xff0c;记录下企业ID。 1.2 创建企微应用&#xff0c;记录下应用的 AgentId 和 Secret。 1.3 设置应用的企业可信IP&#xff0c;将服务器公网 IP 填入即可。 1.4 设置应用接收消息API 填入服务器 API 地址&#xff0c;并记录下随机获取…

oracle查询历史操作记录

示例&#xff1a; SELECTsubstr( a.sql_text, 1, 256 ) "SQL Text",( SELECT b1.username FROM all_users b1 WHERE b1.user_id a.parsing_user_id ) "Parsing User Name",a.users_executing "Users Executing",a.rows_processed "Rows P…