尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

Unity Input System 技术文档(系统整理)

Unity Input System 技术文档(系统整理)
📅 发布时间:2026/6/19 18:25:58

一、Input Actions 配置文件基础

1. Input Actions 是什么

Input Actions(.inputactions 文件)是 Unity 新 Input System 的核心配置文件,用于描述:

  • 行为(Action)
  • 行为映射(Action Map)
  • 控制方案(Control Scheme)
  • 设备与按键绑定

其目标是:行为驱动输入,而不是按键驱动输入。


2. Input Actions 的基本结构

  • Action Maps:一组输入行为(如 Player、UI)
  • Actions:具体行为(Move / Look / Fire / Jump 等)
  • Bindings:某个行为对应的输入设备与按键

二、方式一:生成 C# 类并手动监听

1. 根据 Input Actions 生成 C# 代码

操作步骤:

  1. 选中 .inputactions 文件

  2. 在 Inspector 中设置:

    • Generate C# Class
    • 类名(如 Lesson9_Input)
    • 命名空间(可选)
  3. Apply,生成对应的 C# 输入封装类

生成后:

  • 每个 Action Map → 一个属性
  • 每个 Action → 一个 InputAction

2. 使用生成的 C# 类监听输入

Lesson9_Input input;void Start()
{input = new Lesson9_Input();input.Enable();input.Action1.Fire.performed += (c) =>{Debug.Log("开火");};input.Action2.Space.performed += (c) =>{Debug.Log("跳跃");};
}void Update()
{Vector2 move = input.Action1.Move.ReadValue<Vector2>();Debug.Log(move);
}

3. 特点分析

优点:

  • 代码可控性最高
  • 适合底层框架 / 输入系统封装

缺点:

  • 需要手动 Enable / Disable
  • 事件注册与解绑需要自行管理

三、方式二:PlayerInput 组件概述

1. PlayerInput 是什么

PlayerInput 是 Input System 提供的高级输入组件,用于:

  • 自动解析 Input Actions
  • 自动管理设备分配
  • 自动调用响应函数

核心思想:配置驱动逻辑调用。


2. PlayerInput 的基本使用流程

  1. 创建 Input Actions 文件
  2. 在玩家对象上添加 PlayerInput 组件
  3. 绑定 Input Actions
  4. 选择输入通知方式(Behavior)
  5. 编写对应的响应逻辑

3. PlayerInput 核心参数说明

Actions

  • 关联的 Input Actions 文件
  • Default Action Map:默认启用的行为映射
  • Default Control Scheme:默认控制方案

Camera

  • 本地多人分屏时用于指定摄像机

Behavior(重点)

决定 输入事件如何通知代码逻辑。


四、PlayerInput 的四种事件通知模式

方式一:Send Messages

使用规则

  • 函数命名必须为:On + ActionName

  • 函数参数:

    • 无参数
    • 或 InputValue
  • 脚本必须挂在 PlayerInput 同一对象 上

public void OnMove(InputValue value)
{Vector2 dir = value.Get<Vector2>();
}

特点

  • 最简单
  • 通过反射调用
  • 性能一般

⚠️ 注意:

  • InputValue 只有值发生变化时才会回调
  • 持续按键(如一直按 W)不会持续触发

方式二:Broadcast Messages

  • 规则与 SendMessage 完全一致

  • 区别:

    • 脚本可挂在 PlayerInput 对象 或其子对象 上

适合:

  • 角色逻辑分层的场景

方式三:Invoke Unity Events

使用方式

  • 在 PlayerInput 中选择 Invoke Unity Events
  • 在 Inspector 中拖拽方法
  • 方法参数必须是:
InputAction.CallbackContext
public void MyFire(InputAction.CallbackContext context)
{Debug.Log("Fire");
}

特点

  • 无反射
  • 可视化配置
  • 适合策划 / 非程序人员

方式四:Invoke C# Events(最强)

使用方式

PlayerInput input = GetComponent<PlayerInput>();input.onActionTriggered += OnActionTrigger;
input.onDeviceLost += OnDeviceLost;
input.onDeviceRegained += OnDeviceRegained;
input.onControlsChanged += OnControlsChanged;
public void OnActionTrigger(InputAction.CallbackContext context)
{switch (context.action.name){case "Move":Vector2 dir = context.ReadValue<Vector2>();break;case "Fire":Debug.Log("开火");break;}
}

特点

  • 不依赖字符串反射
  • 性能最好
  • 可集中处理所有输入
  • 工程级推荐方案

InputValue vs CallbackContext

对比项 InputValue CallbackContext
使用场景 Send / Broadcast UnityEvent / C# Event
是否持续 否 是
可读信息 少 多
推荐程度 一般 强烈推荐

五、PlayerInputManager(本地多人)

1. PlayerInputManager 的作用

  • 管理 本地多人输入

  • 处理:

    • 玩家加入
    • 玩家离开
    • 设备分配

常用于:

  • 本地合作游戏
  • 本地对战游戏

2. 核心参数说明

Join Behavior

  • Join Players When Button Is Pressed
  • Join Players When Join Action Is Triggered
  • Join Players Manually

Player Prefab

  • 必须挂载 PlayerInput 组件

Split Screen

  • Enable Split Screen
  • Maintain Aspect Ratio
  • Fixed Number

3. 使用示例

PlayerInputManager.instance.onPlayerJoined += (player) =>
{Debug.Log("创建一个玩家");
};PlayerInputManager.instance.onPlayerLeft += (player) =>
{Debug.Log("离开一个玩家");
};

六、推荐使用方案总结

场景 推荐方案
单人游戏 PlayerInput + Invoke C# Events
本地多人 PlayerInputManager + PlayerInput
框架层 生成 C# 类手动监听
快速原型 Send / Unity Events

七、核心设计思想总结

  1. 行为优先,而不是按键优先
  2. 配置驱动,而不是代码硬编码
  3. 输入与逻辑解耦
  4. 支持多设备、多玩家扩展

相关新闻

  • YOLOFuse交互式教程开发:Jupyter Notebook形式推出
  • 网络工程毕业设计简单的开题指导
  • YOLOFuse WebAssembly尝试:浏览器内运行的可能性探讨

最新新闻

  • 深度解析macOS滚动事件拦截:构建专业级定制插件的完整指南
  • 常州多年黄金回收攻略,三十年实体经营,收的顶本地口碑有保障 - 奢侈品回收测评
  • 01_系统架构设计
  • 如何免费实现专业级直播抠像:obs-backgroundremoval插件完全指南
  • 新手必看!抖音保存视频到相册的详细步骤技巧 - 工具软件使用方法推荐
  • LaTeX长表格排版进阶:如何用longtable宏包实现跨页表格的精细控制?

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号