2022-09-10 12:15:58 +02:00
|
|
|
.. _doc_your_first_2d_game_player_scene:
|
|
|
|
|
|
|
|
Creating the player scene
|
|
|
|
=========================
|
|
|
|
|
|
|
|
With the project settings in place, we can start working on the
|
|
|
|
player-controlled character.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The first scene will define the `Player` object. One of the benefits of
|
2022-09-10 12:15:58 +02:00
|
|
|
creating a separate Player scene is that we can test it separately, even before
|
|
|
|
we've created other parts of the game.
|
|
|
|
|
|
|
|
Node structure
|
|
|
|
~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
To begin, we need to choose a root node for the player object. As a general
|
|
|
|
rule, a scene's root node should reflect the object's desired functionality -
|
2023-01-12 19:29:11 +01:00
|
|
|
what the object *is*. Click the "Other Node" button and add an `Area2D
|
2022-09-10 12:15:58 +02:00
|
|
|
<class_Area2D>` node to the scene.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/add_node.png)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
Godot will display a warning icon next to the node in the scene tree. You can
|
|
|
|
ignore it for now. We will address it later.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
With `Area2D` we can detect objects that overlap or run into the player.
|
|
|
|
Change the node's name to `Player` by double-clicking on it. Now that we've
|
2022-09-10 12:15:58 +02:00
|
|
|
set the scene's root node, we can add additional nodes to give it more
|
|
|
|
functionality.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Before we add any children to the `Player` node, we want to make sure we don't
|
2022-09-10 12:15:58 +02:00
|
|
|
accidentally move or resize them by clicking on them. Select the node and click
|
|
|
|
the icon to the right of the lock; its tooltip says "Makes sure the object's
|
|
|
|
children are not selectable."
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/lock_children.png)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
Save the scene. Click Scene -> Save, or press :kbd:`Ctrl + S` on Windows/Linux
|
|
|
|
or :kbd:`Cmd + S` on macOS.
|
|
|
|
|
|
|
|
.. note:: For this project, we will be following the Godot naming conventions.
|
|
|
|
|
|
|
|
- **GDScript**: Classes (nodes) use PascalCase, variables and
|
|
|
|
functions use snake_case, and constants use ALL_CAPS (See
|
2023-01-12 19:29:11 +01:00
|
|
|
`doc_gdscript_styleguide`).
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
- **C#**: Classes, export variables and methods use PascalCase,
|
|
|
|
private fields use _camelCase, local variables and parameters use
|
2023-01-12 19:29:11 +01:00
|
|
|
camelCase (See `doc_c_sharp_styleguide`). Be careful to type
|
2022-09-10 12:15:58 +02:00
|
|
|
the method names precisely when connecting signals.
|
|
|
|
|
|
|
|
|
|
|
|
Sprite animation
|
|
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Click on the `Player` node and add an `AnimatedSprite
|
|
|
|
<class_AnimatedSprite>` node as a child. The `AnimatedSprite` will handle the
|
2022-09-10 12:15:58 +02:00
|
|
|
appearance and animations for our player. Notice that there is a warning symbol
|
2023-01-12 19:43:03 +01:00
|
|
|
next to the node. An `AnimatedSprite` requires a `SpriteFrames
|
2022-09-10 12:15:58 +02:00
|
|
|
<class_SpriteFrames>` resource, which is a list of the animations it can
|
2023-01-12 19:43:03 +01:00
|
|
|
display. To create one, find the `Frames` property in the Inspector and click
|
2022-09-10 12:15:58 +02:00
|
|
|
"[empty]" -> "New SpriteFrames". Click again to open the "SpriteFrames" panel:
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/spriteframes_panel.png)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
On the left is a list of animations. Click the "default" one and rename it to
|
|
|
|
"walk". Then click the "New Animation" button to create a second animation named
|
2023-01-12 19:43:03 +01:00
|
|
|
"up". Find the player images in the "FileSystem" tab - they're in the `art`
|
2022-09-10 12:15:58 +02:00
|
|
|
folder you unzipped earlier. Drag the two images for each animation, named
|
2023-01-12 19:43:03 +01:00
|
|
|
`playerGrey_up[1/2]` and `playerGrey_walk[1/2]`, into the "Animation Frames"
|
2022-09-10 12:15:58 +02:00
|
|
|
side of the panel for the corresponding animation:
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/spriteframes_panel2.png)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
The player images are a bit too large for the game window, so we need to scale
|
2023-01-12 19:43:03 +01:00
|
|
|
them down. Click on the `AnimatedSprite` node and set the `Scale` property
|
|
|
|
to `(0.5, 0.5)`. You can find it in the Inspector under the `Node2D`
|
2022-09-10 12:15:58 +02:00
|
|
|
heading.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/player_scale.png)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2023-01-12 19:30:47 +01:00
|
|
|
Finally, add a `CollisionShape2D` as a child of
|
2023-01-12 19:43:03 +01:00
|
|
|
`Player`. This will determine the player's "hitbox", or the bounds of its
|
|
|
|
collision area. For this character, a `CapsuleShape2D` node gives the best
|
2022-09-10 12:15:58 +02:00
|
|
|
fit, so next to "Shape" in the Inspector, click "[empty]"" -> "New
|
|
|
|
CapsuleShape2D". Using the two size handles, resize the shape to cover the
|
|
|
|
sprite:
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/player_coll_shape.png)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
When you're finished, your `Player` scene should look like this:
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/player_scene_nodes.png)
|
2022-09-10 12:15:58 +02:00
|
|
|
|
|
|
|
Make sure to save the scene again after these changes.
|
|
|
|
|
|
|
|
In the next part, we'll add a script to the player node to move and animate it.
|
|
|
|
Then, we'll set up collision detection to know when the player got hit by
|
|
|
|
something.
|