2022-09-10 12:15:58 +02:00
|
|
|
.. _doc_first_3d_game_player_scene_and_input:
|
|
|
|
|
|
|
|
Player scene and input actions
|
|
|
|
==============================
|
|
|
|
|
|
|
|
In the next two lessons, we will design the player scene, register custom input
|
|
|
|
actions, and code player movement. By the end, you'll have a playable character
|
|
|
|
that moves in eight directions.
|
|
|
|
|
|
|
|
.. TODO: add player animated gif?
|
2023-01-12 20:16:00 +01:00
|
|
|
.. player_movement.gif)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
Create a new scene by going to the Scene menu in the top-left and clicking *New
|
|
|
|
Scene*. Create a *KinematicBody* node as the root and name it *Player*.
|
|
|
|
|
|
|
|
|image0|
|
|
|
|
|
|
|
|
Kinematic bodies are complementary to the area and rigid bodies used in the 2D
|
|
|
|
game tutorial. Like rigid bodies, they can move and collide with the
|
|
|
|
environment, but instead of being controlled by the physics engine, you dictate
|
|
|
|
their movement. You will see how we use the node's unique features when we code
|
|
|
|
the jump and squash mechanics.
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
|
|
|
|
To learn more about the different physics node types, see the
|
2023-01-12 19:29:11 +01:00
|
|
|
`doc_physics_introduction`.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
For now, we're going to create a basic rig for our character's 3D model. This
|
|
|
|
will allow us to rotate the model later via code while it plays an animation.
|
|
|
|
|
|
|
|
Add a *Spatial* node as a child of *Player* and name it *Pivot*. Then, in the
|
2023-01-12 19:43:03 +01:00
|
|
|
FileSystem dock, expand the `art/` folder by double-clicking it and drag and
|
|
|
|
drop `player.glb` onto the *Pivot* node.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
|image1|
|
|
|
|
|
|
|
|
This should instantiate the model as a child of *Pivot*. You can rename it to
|
|
|
|
*Character*.
|
|
|
|
|
|
|
|
|image2|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The `.glb` files contain 3D scene data based on the open-source GLTF 2.0
|
2022-09-10 12:15:58 +02:00
|
|
|
specification. They're a modern and powerful alternative to a proprietary format
|
|
|
|
like FBX, which Godot also supports. To produce these files, we designed the
|
2023-01-12 20:39:50 +01:00
|
|
|
model in `Blender 3D ( https://www.blender.org/ )` and exported it to GLTF.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
As with all kinds of physics nodes, we need a collision shape for our character
|
|
|
|
to collide with the environment. Select the *Player* node again and add a
|
|
|
|
*CollisionShape*. In the *Inspector*, assign a *SphereShape* to the *Shape*
|
|
|
|
property. The sphere's wireframe appears below the character.
|
|
|
|
|
|
|
|
|image3|
|
|
|
|
|
|
|
|
It will be the shape the physics engine uses to collide with the environment, so
|
|
|
|
we want it to better fit the 3D model. Shrink it a bit by dragging the orange
|
2023-01-12 19:43:03 +01:00
|
|
|
dot in the viewport. My sphere has a radius of about `0.8` meters.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
Then, move the shape up so its bottom roughly aligns with the grid's plane.
|
|
|
|
|
|
|
|
|image4|
|
|
|
|
|
|
|
|
You can toggle the model's visibility by clicking the eye icon next to the
|
|
|
|
*Character* or the *Pivot* nodes.
|
|
|
|
|
|
|
|
|image5|
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Save the scene as `Player.tscn`.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
With the nodes ready, we can almost get coding. But first, we need to define
|
|
|
|
some input actions.
|
|
|
|
|
|
|
|
Creating input actions
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
To move the character, we will listen to the player's input, like pressing the
|
|
|
|
arrow keys. In Godot, while we could write all the key bindings in code, there's
|
|
|
|
a powerful system that allows you to assign a label to a set of keys and
|
|
|
|
buttons. This simplifies our scripts and makes them more readable.
|
|
|
|
|
|
|
|
This system is the Input Map. To access its editor, head to the *Project* menu
|
|
|
|
and select *Project Settings…*.
|
|
|
|
|
|
|
|
|image6|
|
|
|
|
|
|
|
|
At the top, there are multiple tabs. Click on *Input Map*. This window allows
|
|
|
|
you to add new actions at the top; they are your labels. In the bottom part, you
|
|
|
|
can bind keys to these actions.
|
|
|
|
|
|
|
|
|image7|
|
|
|
|
|
|
|
|
Godot projects come with some predefined actions designed for user interface
|
|
|
|
design, which we could use here. But we're defining our own to support gamepads.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
We're going to name our actions `move_left`, `move_right`, `move_forward`,
|
|
|
|
`move_back`, and `jump`.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
To add an action, write its name in the bar at the top and press Enter.
|
|
|
|
|
|
|
|
|image8|
|
|
|
|
|
|
|
|
Create the five actions. Your window should have them all listed at the bottom.
|
|
|
|
|
|
|
|
|image9|
|
|
|
|
|
|
|
|
To bind a key or button to an action, click the "+" button to its right. Do this
|
2023-01-12 19:43:03 +01:00
|
|
|
for `move_left` and in the drop-down menu, click *Key*.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
|image10|
|
|
|
|
|
|
|
|
This option allows you to add a keyboard input. A popup appears and waits for
|
|
|
|
you to press a key. Press the left arrow key and click *OK*.
|
|
|
|
|
|
|
|
|image11|
|
|
|
|
|
|
|
|
Do the same for the A key.
|
|
|
|
|
|
|
|
|image12|
|
|
|
|
|
|
|
|
Let's now add support for a gamepad's left joystick. Click the "+" button again
|
|
|
|
but this time, select *Joy Axis*.
|
|
|
|
|
|
|
|
|image13|
|
|
|
|
|
|
|
|
The popup gives you two drop-down menus. On the left, you can select a gamepad
|
|
|
|
by index. *Device 0* corresponds to the first plugged gamepad, *Device 1*
|
|
|
|
corresponds to the second, and so on. You can select the joystick and direction
|
|
|
|
you want to bind to the input action on the right. Leave the default values and
|
|
|
|
press the *Add* button.
|
|
|
|
|
|
|
|
|image14|
|
|
|
|
|
|
|
|
Do the same for the other input actions. For example, bind the right arrow, D,
|
2023-01-12 19:43:03 +01:00
|
|
|
and the left joystick's right axis to `move_right`. After binding all keys,
|
2022-09-10 12:15:58 +02:00
|
|
|
your interface should look like this.
|
|
|
|
|
|
|
|
|image15|
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
We have the `jump` action left to set up. Bind the Space key and the gamepad's
|
2022-09-10 12:15:58 +02:00
|
|
|
A button. To bind a gamepad's button, select the *Joy Button* option in the menu.
|
|
|
|
|
|
|
|
|image16|
|
|
|
|
|
|
|
|
Leave the default values and click the *Add* button.
|
|
|
|
|
|
|
|
|image17|
|
|
|
|
|
|
|
|
Your jump input action should look like this.
|
|
|
|
|
|
|
|
|image18|
|
|
|
|
|
|
|
|
That's all the actions we need for this game. You can use this menu to label any
|
|
|
|
groups of keys and buttons in your projects.
|
|
|
|
|
|
|
|
In the next part, we'll code and test the player's movement.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
.. |image0| image:: img/02.player_input/01.new_scene.png)
|
|
|
|
.. |image1| image:: img/02.player_input/02.instantiating_the_model.png)
|
|
|
|
.. |image2| image:: img/02.player_input/03.scene_structure.png)
|
|
|
|
.. |image3| image:: img/02.player_input/04.sphere_shape.png)
|
|
|
|
.. |image4| image:: img/02.player_input/05.moving_the_sphere_up.png)
|
|
|
|
.. |image5| image:: img/02.player_input/06.toggling_visibility.png)
|
|
|
|
.. |image6| image:: img/02.player_input/07.project_settings.png)
|
|
|
|
.. |image7| image:: img/02.player_input/07.input_map_tab.png)
|
|
|
|
.. |image8| image:: img/02.player_input/07.adding_action.png)
|
|
|
|
.. |image9| image:: img/02.player_input/08.actions_list_empty.png)
|
|
|
|
.. |image10| image:: img/02.player_input/08.create_key_action.png)
|
|
|
|
.. |image11| image:: img/02.player_input/09.keyboard_key_popup.png)
|
|
|
|
.. |image12| image:: img/02.player_input/09.keyboard_keys.png)
|
|
|
|
.. |image13| image:: img/02.player_input/10.joy_axis_option.png)
|
|
|
|
.. |image14| image:: img/02.player_input/11.joy_axis_popup.png)
|
|
|
|
.. |image15| image:: img/02.player_input/12.move_inputs_mapped.png)
|
|
|
|
.. |image16| image:: img/02.player_input/13.joy_button_option.png)
|
|
|
|
.. |image17| image:: img/02.player_input/14.add_jump_button.png)
|
|
|
|
.. |image18| image:: img/02.player_input/14.jump_input_action.png)
|