延边朝鲜族自治州网站建设_网站建设公司_模板建站_seo优化
2026/1/1 17:05:43 网站建设 项目流程

一、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. 支持多设备、多玩家扩展

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询