Lecture 2 Richard Gesick Interactive Input ch 1 Lecture 2 Richard Gesick
Objectives Creating controls for the Xbox 360 Controller Creating controls for a keyboard Writing a function to detect whether our controller device is plugged in Customizing our controls Letting players switch controls Switching controls with Graphical User Interface (GUI) buttons Resetting controls back to factory settings
Controllers the keyboard/mouse Xbox 360 Controller Ability to switch between the profiles and customize control configurations
Mapping the needed controls Action Keyboard/mouse Xbox 360 Controller Movement WASD keys Left thumbstick Rotate camera Mouse Right thumbstick Item bar buttons 1234 keys Directional pad Inventory The I key The A button Pause game The Esc key The Start button Attack/use an item left mouse button The left trigger Aim right mouse button The right trigger
Checking the Xbox 360 Controller inputs
Adding additional controller inputs To get started, access your input manager by navigating to the Edit menu, hovering over Project Settings, and clicking on Input. Open up the Axes dropdown by clicking on the arrow next to it and change the number in the Size parameter to be a value higher. This will add another input at the bottom of the list, which we can use for one of our types of inputs. By default, by creating a new type of input, the input manager duplicates the bottom input. So open it and we'll make our changes. Follow these steps to create our new input: Change the value of the Name parameter to A_360. Change the value of the Positive Button parameter to joystick button 0.
Adding a start button and trigger inputs 1. Change the value of the Name parameter to Triggers_360. 2. Change the value of the Sensitivity parameter to 0.001. 3. Check the Invert parameter. 4. Change the value of the Type parameter to Joystick Axis. 5. Change the value of the Axis parameter to 3rd Axis (Joysticks and Scrollwheel).
Adding directional pad inputs Change the value of the Name parameter to HorizDpad_360. Change the value of the Sensitivity parameter to 1. Change the value of the Type parameter to Joystick Axis. Change the value of the Axis parameter to 6th Axis (Joysticks). For the vertical directional pad input, you can follow the exact same steps as we did for the horizontal directional pad input; just change the value of Name to VertDpad_360 and change the value of Axis to 7th Axis (Joysticks). This completes the Xbox 360 Controller inputs; all that's left are the PC inputs.
Adding PC control inputs Most of our PC control inputs are already integrated into the input manager; all that is left are the number keys, I key, and Esc key. You can actually follow the same steps as at the beginning of this chapter, when we added the Xbox 360 buttons. For the number keys you'll want to change each of their names to num1, num2, num3, and num4. As for their positive button parameters, change their names to 1, 2, 3, and 4, accordingly.
The device detector bool isControllerConnected = false; public string Controller = ""; void DetectController() { try { if(Input.GetJoystickNames()[0] != null) isControllerConnected = true; IdentifyController(); } } catch { isControllerConnected = false; } } This function uses the GetJoystickNames function of the input, which gets and returns an array of strings, which consists of the names of the connected gamepads.
void IdentifyController() { Controller = Input void IdentifyController() { Controller = Input.GetJoystickNames()[0]; }
Adding variables for each control public string PC_Move, PC_Rotate, …; public string Xbox_Move, Xbox_Rotate, …; void SetDefaultValues() { PC_Move = "WASD"; PC_Rotate = "Mouse"; … if(isControllerConnected) { Xbox_Move = "Left Thumbstick"; Xbox_Rotate = "Right Thumbstick"; … }
Control display function void OnGUI() { GUI.BeginGroup(new Rect( Screen.width /2 - 300, Screen.height / 2 - 300, 600, 400)); GUI.Box(new Rect(0,0,600,400), "Controls"); GUI.Label(new Rect(205, 40, 20, 20), "PC"); GUI.Label(new Rect(340, 40, 125, 20), "Xbox 360 Controller"); GUI.Label(new Rect(25, 75, 125, 20), "Movement: "); GUI.Button(new Rect(150, 75, 135, 20), PC_Move); GUI.Button(new Rect(325, 75, 135, 20), Xbox_Move); … GUI.EndGroup(); }
Creating control profiles public enum ControlProfile { PC, Controller }; public ControlProfile cProfile; Add these lines of code before the line of code where you call the IdentifyController() function in the if statement: cProfile = ControlProfile.Controller; else cProfile = ControlProfile.PC; void SwitchProfile (ControlProfile Switcher) { cProfile = Switcher; }
Switching Control Profiles This block of code would be placed in the OnGUI function GUI.Label(new Rect(450, 345, 125, 20), "Current Controls"); if(GUI.Button(new Rect(425, 370, 135, 20), cProfile.ToString())) { if(cProfile == ControlProfile.Controller) SwitchProfile(ControlProfile.PC); else SwitchProfile(ControlProfile.Controller); }
GUI interaction function add to onGUI(), just before the line where the group ends: GUI.Label(new Rect(450, 345, 125, 20), "Current Controls"); if(GUI.Button(new Rect(425, 370, 135, 20), cProfile.ToString())) { if(cProfile == ControlProfile.Controller) SwitchProfile(ControlProfile.PC); else SwitchProfile(ControlProfile.Controller); }
Swapping control schemes Unity doesn't allow us to edit the input properties while in-game, we will add a function to our script that will allow the player to switch between control schemes.