| The Input Manager is where you define all the different input axes and game actions for your project. 输入管理器可以设置项目的各种输入和操作。  The Input Manager 输入管理器
To see the Input Manager choose: Edit->Project Settings->Input. 输入管理器位于菜单的Edit->Project Settings->Input.Properties 属性 Details 细节
 
 
 Axes 轴Contains all the defined input axes for the current project: Size is the number of different input axes in this project, Element 0, 1, ... are the particular axes to modify.
 设置当前项目中的所有输入轴:size为轴的数量。0,1…元素可以对每个轴进行修改。
Name 名称The string that refers to the axis in the game launcher and through scripting.
 轴的名称,用于游戏加载界面和脚本中。
Descriptive Name 描述A detailed definition of the Positive Button function that is displayed in the game launcher.
 游戏加载界面中,轴的正向按键的详细描述。
Descriptive Negative Name反向描述
 A detailed definition of the Negative Button function that is displayed in the game launcher.
 游戏加载界面中,轴的反向按键的详细描述。
Negative Button 反向按钮The button that will send a negative value to the axis.
 该按钮会给轴发送一个负值 。
Positive Button 正向按钮The button that will send a positive value to the axis.
 该按钮会给轴发送一个正值 。
Alt Negative Button 备选反向按钮The secondary button that will send a negative value to the axis.
 给轴发送负值的另一个按钮。
Alt Positive Button 备选正向按钮The secondary button that will send a positive value to the axis.
 给轴发送正值的另一个按钮。
Gravity 重力How fast will the input recenter. Only used when the Type is key / mouse button.
 输入复位的速度,仅用于类型为 键/鼠标 的按键。
Dead 阈Any positive or negative values that are less than this number will register as zero. Useful for joysticks.
 任何小于该值的输入值(不论正负值)都会被视为0,用于摇杆。
Sensitivity灵敏度
 For keyboard input, a larger value will result in faster response time. A lower value will be more smooth. For Mouse delta the value will scale the actual mouse delta.
 对于键盘输入,该值越大则响应时间越快,该值越小则越平滑。对于鼠标输入,设置该值会对鼠标的实际移动距离按比例缩放。
Snap 对齐If enabled, the axis value will be immediately reset to zero after it receives opposite inputs. Only used when the Type is key / mouse button.
 如果启用该设置,当轴收到反向的输入信号时,轴的数值会立即置为0,仅用于键/鼠标 输入。
Invert 反转If enabled, the positive buttons will send negative values to the axis, and vice versa.
 启用该参数可以让正向按钮发送负值,反向按钮发送正值。
Type 类型Use Key / Mouse Button for any kind of buttons, Mouse Movement for mouse delta and scrollwheels, Joystick Axis for analog joystick axes and Window Movement for when the user shakes the window.
 所有的按钮输入都应设置为 键/鼠标 (Key / Mouse) 类型,对于鼠标移动和滚轮应设为 鼠标移动(Mouse Movement)。摇杆设为摇杆轴 (Joystick Axis),用户移动窗口设为窗口移动 (Window Movement)。
Axis 轴Axis of input from the device (joystick, mouse, gamepad, etc.)
 设备的输入轴(摇杆,鼠标,手柄等)
Joy Num 摇杆编号Which joystick should be used. By default this is set to retrieve the input from all joysticks. This is only used for input axes and not buttons.
 设置使用哪个摇杆。默认是接收所有摇杆的输入。仅用于输入轴和非按键。
 
 All the axes that you set up in the Input Manager serve two purposes: 在输入管理器中设置的轴有2个目的: 
 
 
 They allow you to reference your inputs by axis name in scripting 让你可以在脚本中通过轴的名称来使用输入。
They allow the players of your game to customize the controls to their liking 让游戏玩家可以自定义游戏的输入。
 
 All defined axes will be presented to the player in the game launcher, where they will see its name, detailed description, and default buttons. From here, they will have the option to change any of the buttons defined in the axes. Therefore, it is best to write your scripts making use of axes instead of individual buttons, as the player may want to customize the buttons for your game. 在游戏加载界面中,玩家可以看到所有定义的轴,包括名称,详细说明,默认按键,他们可以通过选项改变轴的按键。因此,在脚本中你最好也使用轴而不是单独的按键,这样玩家就可以在你的游戏中自定义按键。 
 You map each axis to two buttons on a joystick, mouse, or keyboard keys. 
 | 
 | 
 |  | Name | The name of the string used to check this axis from a script. |  | Descriptive Name | Positive value name displayed in the input tab of the Configuration dialog for standalone builds. |  | Descriptive Negative Name | Negative value name displayed in the Input tab of the Configuration dialog for standalone builds. |  | Negative Button | The button used to push the axis in the negative direction. |  | Positive Button | The button used to push the axis in the positive direction. |  | Alt Negative Button | Alternative button used to push the axis in the negative direction. |  | Alt Positive Button | Alternative button used to push the axis in the positive direction. |  | Gravity | Speed in units per second that the axis falls toward neutral when no buttons are pressed. |  | Dead | Size of the analog dead zone. All analog device values within this range result map to neutral. |  | Sensitivity | Speed in units per second that the the axis will move toward the target value. This is for digital devices only. |  | Snap | If enabled, the axis value will reset to zero when pressing a button of the opposite direction. |  | Invert | If enabled, the Negative Buttons provide a positive value, and vice-versa. |  | Type | The type of inputs that will control this axis. |  | Axis | The axis of a connected device that will control this axis. |  | Joy Num | The connected Joystick that will control this axis. | 
 Use these settings to fine tune the look and feel of input. They are all documented with tooltips in the Editor as well. Using Input Axes from Scripts
 You can query the current state from a script like this: value = Input.GetAxis ("Horizontal"); An axis has a value between -1 and 1. The neutral position is 0. This is the case for joystick input and keyboard input. However, Mouse Delta and Window Shake Delta are how much the mouse or window moved during the last frame. This means it can be larger than 1 or smaller than -1 when the user moves the mouse quickly. It is possible to create multiple axes with the same name. When getting the input axis, the axis with the largest absolute value will be returned. This makes it possible to assign more than one input device to one axis name. For example, create one axis for keyboard input and one axis for joystick input with the same name. If the user is using the joystick, input will come from the joystick, otherwise input will come from the keyboard. This way you don't have to consider where the input comes from when writing scripts. Button Names
 To map a key to an axis, you have to enter the key's name in the Positive Button or Negative Button property in the Inspector. The names of keys follow this convention: 
 
 Normal keys: "a", "b", "c" ...Number keys: "1", "2", "3", ...Arrow keys: "up", "down", "left", "right"Keypad keys: "[1]", "[2]", "[3]", "[+]", "[equals]"Modifier keys: "right shift", "left shift", "right ctrl", "left ctrl", "right alt", "left alt", "right cmd", "left cmd"Mouse Buttons: "mouse 0", "mouse 1", "mouse 2", ...Joystick Buttons (from any joystick): "joystick button 0", "joystick button 1", "joystick button 2", ...Joystick Buttons (from a specific joystick): "joystick 1 button 0", "joystick 1 button 1", "joystick 2 button 0", ...Special keys: "backspace", "tab", "return", "escape", "space", "delete", "enter", "insert", "home", "end", "page up", "page down"Function keys: "f1", "f2", "f3", ...
 The names used to identify the keys are the same in the scripting interface and the Inspector. value = Input.GetKey ("a");Mobile Input On iOS and Android, the Input class offers access to touchscreen, accelerometer and geographical/location input. Access to keyboard on mobile devices is provided via the iOS keyboard.Multi-Touch Screen The iPhone and iPod Touch devices are capable of tracking up to five fingers touching the screen simultaneously. You can retrieve the status of each finger touching the screen during the last frame by accessing the Input.touches property array. Android devices don't have a unified limit on how many fingers they track. Instead, it varies from device to device and can be anything from two-touch on older devices to five fingers on some newer devices. Each finger touch is represented by an Input.Touch data structure: | 
 | 
 |  | fingerId | The unique index for a touch. |  | position | The screen position of the touch. |  | deltaPosition | The screen position change since the last frame. |  | deltaTime | Amount of time that has passed since the last state change. |  | tapCount | The iPhone/iPad screen is able to distinguish quick finger taps by the user. This counter will let you know how many times the user has tapped the screen without moving a finger to the sides.Android devices do not count number of taps, this field is always 1. |  | phase | Describes so called "phase" or the state of the touch. It can help you determine if the touch just began, if user moved the finger or if he just lifted the finger. | 
 Phase can be one of the following: | Began | A finger just touched the screen. |  | Moved | A finger moved on the screen. |  | Stationary | A finger is touching the screen but hasn't moved since the last frame. |  | Ended | A finger was lifted from the screen. This is the final phase of a touch. |  | Canceled | The system cancelled tracking for the touch, as when (for example) the user puts the device to her face or more than five touches happened simultaneously. This is the final phase of a touch. | 
 Following is an example script which will shoot a ray whenever the user taps on the screen: Mouse Simulation复制代码var particle : GameObject;
function Update () {
for (var touch : Touch in Input.touches) {
if (touch.phase == TouchPhase.Began) {
// Construct a ray from the current touch coordinates
var ray = Camera.main.ScreenPointToRay (touch.position);
if (Physics.Raycast (ray)) {
// Create a particle if hit
Instantiate (particle, transform.position, transform.rotation);
}
}
}
}
On top of native touch support Unity iOS/Android provides a mouse simulation. You can use mouse functionality from the standard Input class.Accelerometer As the mobile device moves, a built-in accelerometer reports linear acceleration changes along the three primary axes in three-dimensional space. Acceleration along each axis is reported directly by the hardware as G-force values. A value of 1.0 represents a load of about +1g along a given axis while a value of -1.0 represents -1g. If you hold the device upright (with the home button at the bottom) in front of you, the X axis is positive along the right, the Y axis is positive directly up, and the Z axis is positive pointing toward you. The following is an example script which will move an object using the accelerometer: Low-Pass Filter复制代码var speed = 10.0;
function Update () {
var dir : Vector3 = Vector3.zero;
// we assume that the device is held parallel to the ground
// and the Home button is in the right hand
// remap the device acceleration axis to game coordinates:
// 1) XY plane of the device is mapped onto XZ plane
// 2) rotated 90 degrees around Y axis
dir.x = -Input.acceleration.y;
dir.z = Input.acceleration.x;
// clamp acceleration vector to the unit sphere
if (dir.sqrMagnitude > 1)
dir.Normalize();
// Make it move 10 meters per second instead of 10 meters per frame...
dir *= Time.deltaTime;
// Move object
transform.Translate (dir * speed);
}
Accelerometer readings can be jerky and noisy. Applying low-pass filtering on the signal allows you to smooth it and get rid of high frequency noise. The following script shows you how to apply low-pass filtering to accelerometer readings: I'd like as much precision as possible when reading the accelerometer. What should I do?The greater the value of LowPassKernelWidthInSeconds, the slower the filtered value will converge towards the current input sample (and vice versa).复制代码var AccelerometerUpdateInterval : float = 1.0 / 60.0;
var LowPassKernelWidthInSeconds : float = 1.0;
private var LowPassFilterFactor : float = AccelerometerUpdateInterval / LowPassKernelWidthInSeconds; // tweakable
private var lowPassValue : Vector3 = Vector3.zero;
function Start () {
lowPassValue = Input.acceleration;
}
function LowPassFilterAccelerometer() : Vector3 {
lowPassValue = Mathf.Lerp(lowPassValue, Input.acceleration, LowPassFilterFactor);
return lowPassValue;
}
Reading the Input.acceleration variable does not equal sampling the hardware. Put simply, Unity samples the hardware at a frequency of 60Hz and stores the result into the variable. In reality, things are a little bit more complicated -- accelerometer sampling doesn't occur at consistent time intervals, if under significant CPU loads. As a result, the system might report 2 samples during one frame, then 1 sample during the next frame. You can access all measurements executed by accelerometer during the frame. The following code will illustrate a simple average of all the accelerometer events that were collected within the last frame: iOS Game Controller support复制代码var period : float = 0.0;
var acc : Vector3 = Vector3.zero;
for (var evnt : iPhoneAccelerationEvent in iPhoneInput.accelerationEvents) {
acc += evnt.acceleration * evnt.deltaTime;
period += evnt.deltaTime;
}
if (period > 0)
acc *= 1.0/period;
return acc;
Starting with OS 7 standardized Game Controller Input API is provided by Apple. Unity support for this API comes as part of standard Unity Input API.Detecting attached Game Controllers Calling Input.GetJoystickNames() will enumerate attached controller names. Names follow this pattern: �[$profile_type,$connection_type] joystick $number by $model�. $profile_type might be either �basic� or �extended�, $connection_type is either �wired� or �wireless�. It could be used to detect the kind of connected controller. It�s worth re-checking this list every several seconds to detect if controllers have been attached/detached. Here�s an example how to do it in C#: When controllers are detected you can either hide on-screen touch controls or amend them to supplement controller input. The next task is to check for Game Controller input.复制代码 private bool connected = false;
IEnumerator CheckForControllers()
{
while(true)
{
var controllers = Input.GetJoystickNames();
if (!connected && controllers.Length > 0)
{
connected = true;
Debug.Log("Connected");
}
else if (connected && controllers.Length == 0)
{
connected = false;
Debug.Log("Disconnected");
}
yield return new WaitForSeconds(1f);
}
}
void Awake()
{
StartCoroutine(CheckForControllers());
}
 |