Skip to main content

Create a Dynamic Full-Screen Particle System in Godot | Leaf Falling Overlay Tutorial

Visual effects, or VFX, are an essential part of game development if you want to keep players engaged. One of the most impressive visual effects you can create is a full-screen particle system, like the beautiful leaf falling overlay shown in this video.




In this tutorial, you will learn how to create your own dynamic full-screen particle system in Godot. This method is flexible and will work on any screen size, so you can create stunning effects for your game no matter what device it's played on.

To start, you'll need a leaf image and the Godot engine.

Resource: https://github.com/shashank1q/Godot-leaf_falling

Open up Godot and create a new scene. Add a Particle2D node to the scene, and set the image in the texture property. Next, set the amount to 20 and the lifetime to 5 seconds in the time section. Uncheck the local coordinate option in the drawing section, and add a new particles material in the process material section.

Now set these values to particles material.






Before we move into code, let's first understand what we're going to do. In most games, a Camera2D node is used to show only a small part of the entire world. We need to place the particle system just above the visible screen area so that the leaves fall from above.

Our first task is to get the coordinate of the top-left part of the visible screen and find the size of the visible area. Once we have this information, we can place our Particle2D node just above the screen using the top-left coordinate and expand the particle's emission shape to cover the entire length of the screen.



To do this, we'll create a script with a process function that contains a variable called canvas. This variable contains the canvas transform, which we can use to get the coordinate of the top-left position and the size of the current visible screen.

With this information, we can set the X position of the Particle2D node to the middle of the screen by adding half the screen size in the horizontal direction. For the Y position, we just add 50 to the top-left position to move it above the screen. Finally, we'll set the emission shape's length to equal the screen size, the width to 50, and leave the Z axis unchanged.

Once you've created your script, place the scene anywhere in your tree, and your full-screen leaf falling animation is ready to go!

Comments

Popular posts from this blog

Complete 2D player movement, Beginner to Pro in Godot

 Have you ever wondered why these games feel so good to play? If your answer is visuals then ,  No the key component is their controls. The character movement feels natural, and they move exactly how you want. A good character movement will always make the player feel that they are in total control of the character.  So, you are wondering how to achieve this?  Well, there are some tricks that professional developers use to make their control better. And today we are goanna see what they are and how you can do it in Godot. VIDEO TUTORIAL COMPLETE CODE: extends KinematicBody2D var velocity : Vector2 export var max_speed : int = 1000 export var gravity : float = 55 export var jump_force : int = 1600 export var acceleration : int = 50 export var jump_buffer_time : int = 15 export var cayote_time : int = 15 var jump_buffer_counter : int = 0 var cayote_counter : int = 0 func _physics_process(_delta): if is_on_floor(): cayote_counter = cayote_...

Background Loading in Godot | DICODE

Video Tutorial       

Improve your jumping! | Type of jumps in Godot

Wall jump, Wall climbing, Wall sliding and double jump are some of the most common mechanics for a plat-former game. And on top of that they are super easy to create in Godot. So in this Godot tutorial, I have tried to implement all these things in the simplest way possible. I would highly recommend you to watch the 2-D movement video first, because I am adding wall jumps and other stuff in that same script. So, watch it at 1.5x speed! to get an overview. VIDEO TUTORIAL TEXT TUTORIAL Double Jump For this, create a variable jump_counter. This will keep track of how many jumps we have done, while we're in the air. So by default it will be 0. var jump_counter : int = 0 <------- var jump_buffer_counter : int = 0 var cayote_counter : int = 0 Now if you remember, in the previous video, when we are pressing the jump button. We are setting the jump_buffer_counter. So, when we are not on the ground, we will check if buffer_counter > 0 This will be true, only when we have pressed th...