Unity Basics Course: Frame-Based Movement Speed Correction

Unity is one of the most widely used game engines today, providing the necessary features for creating games across various platforms. In game development, movement speed is a crucial factor, and understanding how to adjust movement speed to provide a consistent experience across various frame rates is essential. This tutorial will explain frame-based movement speed adjustment in Unity in detail.

Frame-Based Movement Speed and Time

In Unity, movement speed is primarily determined by two criteria: frame-based movement speed and time-based movement speed. Frame-based movement speed determines how much an object’s position will change each frame. However, since games cannot generally guarantee a consistent frame rate, it is challenging to maintain a consistent speed with just this method.

Therefore, we need to adjust speed based on time. Specifically, Unity provides the time interval between frames through Time.deltaTime. This allows us to adjust movement speed according to time. In other words, we can calculate the distance to move each frame based on Time.deltaTime, ensuring that it is not affected by frame rate.

Basic Script Setup

Now let’s apply the concept of movement speed adjustment through a basic movement script example. First, create a new script in Unity and name it PlayerMovement.cs.

using UnityEngine;

public class PlayerMovement : MonoBehaviour
{
    public float moveSpeed = 5f;

    void Update()
    {
        float horizontal = Input.GetAxis("Horizontal");
        float vertical = Input.GetAxis("Vertical");
        
        Vector3 direction = new Vector3(horizontal, 0, vertical).normalized;
        
        if(direction.magnitude >= 0.1f)
        {
            float targetAngle = Mathf.Atan2(direction.x, direction.z) * Mathf.Rad2Deg;
            transform.rotation = Quaternion.Euler(0, targetAngle, 0);

            Vector3 moveDirection = Quaternion.Euler(0, targetAngle, 0) * Vector3.forward;
            transform.position += moveDirection * moveSpeed * Time.deltaTime;
        }
    }
}

The above code is a basic movement script. The moveSpeed variable sets the player’s movement speed, and the Update() method takes input to determine the movement direction. It adjusts the position based on the time difference between frames by multiplying by Time.deltaTime.

Code Explanation

1. User Input Handling

The commands Input.GetAxis("Horizontal") and Input.GetAxis("Vertical") in the provided code are responsible for receiving user input. Each function returns a value between -1 and 1, representing left/right and up/down movement.

2. Direction Vector Calculation

Based on user input, we create a Vector3 object called direction. This vector represents the direction of movement in the form of (x, 0, z). If this vector’s length is greater than 0.1 (i.e., if there is a direction in which the user actually wants to move), the next steps are executed.

3. Rotation and Movement Handling

The player’s rotation is calculated based on the input direction using Mathf.Atan2(). Then, the generated rotation value is used to update the player’s rotation state. Finally, in the actual movement handling part, we update transform.position based on the calculated direction.

Advanced Movement Techniques

In addition to basic movement, various adjustment techniques may be necessary depending on the player’s movement style. For example, to prevent different speeds when moving diagonally, we can maintain a consistent speed through vector normalization.

Diagonal Movement Adjustment

When moving diagonally, the speed increases as inputs are given on both axes. To prevent this, it is necessary to adjust the ratio of the diagonal length. We’ll use a conditional statement to detect diagonal movement and normalize the Vector3 vector to adjust the movement speed.

if (direction.magnitude >= 0.1f)
{
    direction.Normalize(); // Normalize the direction vector
    transform.position += direction * moveSpeed * Time.deltaTime;
}

In the above code, the direction.Normalize(); line normalizes the direction vector, preventing the increase in speed during diagonal movement. Now, the player will move at the same speed regardless of the direction.

Physics-Based Movement (Using Rigidbody)

Movement through physics manipulation can be implemented using Unity’s Rigidbody component. This method can better reflect collisions and physical laws, enhancing realism. To implement physics-based movement, follow these steps.

Adding the Rigidbody Component

First, add a Rigidbody component to the player character object in the Unity Editor. This component allows you to set the object’s physical properties, such as gravity, mass, linear and angular velocity, and various other physical attributes.

Movement Code Using Rigidbody

using UnityEngine;

public class PlayerMovement : MonoBehaviour
{
    public float moveSpeed = 5f;
    private Rigidbody rb;

    void Start()
    {
        rb = GetComponent();
    }

    void Update()
    {
        float horizontal = Input.GetAxis("Horizontal");
        float vertical = Input.GetAxis("Vertical");

        Vector3 direction = new Vector3(horizontal, 0, vertical).normalized;

        rb.MovePosition(transform.position + direction * moveSpeed * Time.deltaTime);
    }
}

In the above code, movement is done through the MovePosition method using the Rigidbody component. In this case, the movement speed adjustment still occurs through Time.deltaTime.

Integration with Animation

After adjusting movement speed, you can integrate animations to create more realistic character movements. In Unity, you can control animations using the Animator component. Animation transitions are usually based on parameters related to movement speed, allowing the character to switch between walking and running animations smoothly.

Setting Animation Parameters

Add a parameter called Speed in the Animator Controller and update this value based on movement speed. This way, you can switch to a running animation when moving above a certain speed.

void Update()
{
    float horizontal = Input.GetAxis("Horizontal");
    float vertical = Input.GetAxis("Vertical");

    Vector3 direction = new Vector3(horizontal, 0, vertical).normalized;

    // Set animation parameters based on movement speed
    animator.SetFloat("Speed", direction.magnitude);

    if (direction.magnitude >= 0.1f)
    {
        rb.MovePosition(transform.position + direction * moveSpeed * Time.deltaTime);
    }
}

In the above code, animator.SetFloat("Speed", direction.magnitude); updates the animation parameter based on the magnitude of the current movement direction. Now the animation will transition smoothly as the player moves.

Performance Optimization

Finally, it is essential to consider performance optimization. Game performance is a critical aspect in Unity, and it is necessary to minimize unnecessary calculations in the movement script.

Update vs FixedUpdate

Physical processes such as movement are typically handled in the FixedUpdate() method. While Update() is called every frame, FixedUpdate() is called at regular time intervals. Therefore, it is recommended to use FixedUpdate() for physics-related code.

void FixedUpdate()
{
    // Place your physics-based movement code here...
}

Additionally, you can further optimize performance by adjusting the physical calculation constants of the physics engine related to movement handling or removing unnecessary components.

Conclusion

In this tutorial, we explored various concepts and implementation methods for frame-based movement speed adjustment in Unity. From basic movement scripts to advanced physics-based movement, animation integration, and performance optimization, we covered many aspects. With these principles, you can provide consistent character movement in your game and it will greatly help in implementing more complex game logic in the future.

Utilize Unity’s various features to embark on your game development journey. Happy Gaming!

Basic Unity Course: Displaying the Network Room List

1. Introduction

In game development, multiplayer features provide a variety of experiences. In this tutorial, we will learn how to display a network room list using Unity. This tutorial is written for beginners and is based on an understanding of basic Unity usage and C# programming.

2. Unity and Networking

Unity offers various networking solutions. UNet (Unity Network) is one of them, useful for setting up basic multiplayer environments. As of Unity 2020.1, UNet has been deprecated, and the new networking framework MLAPI has been introduced. This tutorial will focus on MLAPI.

3. Preparation

3.1. Installing Unity

To install Unity, download Unity Hub and install the desired version of Unity. MLAPI is supported on Unity version 2019.4 and above.

3.2. Adding the MLAPI Package

To add MLAPI to your project, use the Unity Package Manager. In the Unity editor, select ‘Window’ -> ‘Package Manager’, then select ‘Add package from git URL…’ and enter https://github.com/Unity-Technologies/Mirror.git.

4. Creating a New Unity Project

Create a new Unity project and select the 3D template. Once the project is created, you will be ready to add all necessary assets and networking-related scripts.

5. Setting Up the Scene

Create a new scene and add a basic camera and lighting. Add a skybox and a few 3D objects to create a test environment.

6. Adding a Network Manager

To manage the network, add a NetworkManager component to the scene. The NetworkManager is responsible for creating and managing network rooms. After creating the game object, set it up as follows:

NetworkManager manager = gameObject.AddComponent<NetworkManager>();

7. Setting Up UI to Display Room List

7.1. Adding UI Elements

To display the room list in the UI, add a Canvas and use Text and Button elements to construct the UI that will display the room list.

7.2. Writing UI Scripts

Write a script to display the room list. Below is an example of the basic code to retrieve room information.


using UnityEngine;
using UnityEngine.UI;
using UnityEngine.Networking;
using System.Collections.Generic;

public class RoomList : MonoBehaviour
{
    public GameObject roomButtonPrefab;
    public Transform roomListContainer;

    void Start()
    {
        NetworkManager.singleton.OnMatchList += OnMatchList;
        NetworkManager.singleton.ListMatches(0, 20, "", OnMatchList);
    }

    void OnMatchList(bool success, string extendedInfo, List matches)
    {
        foreach (Transform child in roomListContainer)
        {
            Destroy(child.gameObject);
        }

        if (success)
        {
            foreach (var match in matches)
            {
                Instantiate(roomButtonPrefab, roomListContainer).GetComponentInChildren().text = match.name;
            }
        }
    }
}

8. Creating a Room

Additional functionality is needed to allow users to create a room by clicking a button. Implement room creation by adding the following function.


public void CreateRoom()
{
    NetworkManager.singleton.StartMatchMaker();
    NetworkManager.singleton.matchMaker.CreateMatch("RoomName", 2, true, "", "", "", 0, 0, OnMatchCreate);
}

void OnMatchCreate(bool success, string extendedInfo, MatchInfo match)
{
    if (success)
    {
        NetworkManager.singleton.StartHost();
    }
}

9. Joining a Room

Add a UI button to allow users to join a room and implement the functionality to join a room with the following code.


public void JoinRoom(MatchInfoSnapshot match)
{
    NetworkManager.singleton.StartMatchMaker();
    NetworkManager.singleton.matchMaker.JoinMatch(match.networkId, "", OnMatchJoin);
}

void OnMatchJoin(bool success, string extendedInfo, MatchInfo match)
{
    if (success)
    {
        NetworkManager.singleton.StartClient();
    }
}

10. Testing and Debugging

Once all scripts and UI are complete, test the multiplayer functionality in the Unity editor. Create a room and check the room list from another client to verify everything is working correctly.

11. Conclusion

This tutorial taught you how to display a network room list in Unity. Additional features such as room deletion, modifying room information, and UI improvements can provide a better user experience. We plan to continue covering in-depth topics on Unity and networking.

12. References

Unity Basics Course: Bullet Impact Effects

Unity is a powerful platform for game development. In this tutorial, we will explore how to implement bullet impact effects in Unity.
This tutorial will cover all the steps necessary to complete the bullet impact effect, including project setup, preparing required assets, coding, and optimizing effects.
By following this tutorial, you will learn how to utilize various features of Unity to create a more dynamic and engaging gameplay experience.

1. Project Setup

The first step is to create and set up a new Unity project. Launch Unity, select “New Project,”
and choose the 3D template to set up the project. Let’s name the project “BulletImpactEffects.”

  • Project Type: 3D
  • Rendering: Use URP (Universal Render Pipeline)
  • Project Name: BulletImpactEffects

1.1 Importing Unity Package

To add the necessary assets, download 3D models and effects from the Unity Asset Store.
It is recommended to use both free and paid assets to import models for guns and target objects.
Download assets that include basic sprites, particles, and effects. This tutorial will utilize free assets and built-in effects.

2. Setting Up Bullets and Targets

Prepare the bullet prefab mounted on the gun and the target object.
The bullet and target must have the Rigidbody and Collider components for physical interaction.

2.1 Creating Bullet Prefab

  1. Select GameObject > 3D Object > Sphere to create the bullet object.
  2. Scale the Sphere to (0.1, 0.1, 0.1).
  3. Add the Rigidbody component and disable Kinematic.
  4. Save this object as a prefab named “Bullet.”

2.2 Creating Target Object

  1. Select GameObject > 3D Object > Cube to create the target object.
  2. Set the Scale of the Cube to (1, 1, 1) by default.
  3. A Collider is included by default.
  4. Save this object as a prefab named “Target.”

3. Writing Code

To implement the effect of shooting a bullet and hitting a target, we will write a C# script.
Create a new script named “Bullet” and add the following code.

    
    using UnityEngine;

    public class Bullet : MonoBehaviour
    {
        public float speed = 20f;

        void Start()
        {
            Rigidbody rb = GetComponent();
            rb.velocity = transform.forward * speed;
        }

        private void OnCollisionEnter(Collision collision)
        {
            if (collision.gameObject.CompareTag("Target"))
            {
                // Implement effect when hitting the target
                // Code to instantiate the effect
                Destroy(gameObject);
            }
        }
    }
    
    

3.1 Bullet Shooting Script

Write a script to add the shooting functionality of the gun.
Create a new script named “Gun” and add the following code to make the bullet shoot.

    
    using UnityEngine;

    public class Gun : MonoBehaviour
    {
        public GameObject bulletPrefab;
        public Transform bulletSpawn;

        void Update()
        {
            if (Input.GetButtonDown("Fire1"))
            {
                Shoot();
            }
        }

        void Shoot()
        {
            Instantiate(bulletPrefab, bulletSpawn.position, bulletSpawn.rotation);
        }
    }
    
    

4. Adding Effects

Add the effect to be used when the bullet hits the target.
Look for and download particle effects such as “Blood Splatter” from the Unity Asset Store.

4.1 Writing Effect Script

Add a script that creates effects when hit by the bullet.

    
    using UnityEngine;

    public class BulletImpact : MonoBehaviour
    {
        public GameObject impactEffect;

        private void OnCollisionEnter(Collision collision)
        {
            if(collision.gameObject.CompareTag("Target"))
            {
                Instantiate(impactEffect, transform.position, Quaternion.identity);
                Destroy(gameObject);
            }
        }
    }
    
    

5. Testing and Adjustments

Run the project to shoot the gun and check the effect when it hits the target.
Adjust the size, duration, and direction of the effects to achieve optimal results.

5.1 Debugging

If issues arise, check the console for error messages and review the code for corrections.
Ensure that the tags and names of each object are matching.

6. Conclusion

In this tutorial, you have learned how to implement bullet impact effects in Unity.
I hope you gained knowledge in basic C# scripting, managing game objects, and using effects during this process.
Now, try to add more complex effects and game mechanics to further enhance the quality of your game.
A wonderful world of game development awaits you through Unity.

7. Additional Resources

– Unity Official Documentation: Unity Manual
– C# Programming Guide: C# Documentation
– Unity Forum and Community: Unity Forum

Unity Basics Course: Visualizing Enemy Character Health

The health system is very important in game development. Visually representing how much health an enemy character has remaining when the player engages in combat provides an effective gameplay experience. In this tutorial, we will delve into how to visualize the health of enemy characters in Unity.

1. Introduction to Unity

Unity is a powerful game engine that helps develop games and simulations across various platforms. Unity supports both 2D and 3D game development and offers a variety of features such as visual scripting, a physics engine, and an animation system.

2. Project Setup

Before starting the project, first install Unity and create a new 3D project. By setting up the project, you can efficiently structure the basic foundation of the game. After preparing the basic scene and the necessary resources, you will be ready to create the enemy character and the health bar.

2.1 Create a Project

Run Unity and click the “New” button to create a new project. Select the “3D” template to set up your workspace in a 3D environment. Name the project “EnemyHealthVisualization” and choose a save location before clicking “Create”.

2.2 Configure the Basic Scene

Once the project is created, the default scene opens. Here, you will set up a simple environment that includes the enemy character and health bar. Add basic 3D objects and configure the lighting and camera to visually complete the scene.

3. Enemy Character Script

To visualize the health, you will create an enemy character script. The script updates the current health status of the enemy character and reflects it on the health bar.

3.1 Create Enemy Class

using UnityEngine;

    public class Enemy : MonoBehaviour {
        public float maxHealth = 100f;
        private float currentHealth;

        void Start() {
            currentHealth = maxHealth;
        }

        public void TakeDamage(float damage) {
            currentHealth -= damage;
            if (currentHealth < 0) {
                currentHealth = 0;
                Die();
            }
        }

        void Die() {
            // Code to handle when the enemy dies
            Destroy(gameObject);
        }

        public float GetHealthPercentage() {
            return currentHealth / maxHealth;
        }
    }

The code above defines the Enemy class for the enemy character. It sets the maximum health value maxHealth and allows damage to be taken through the TakeDamage() function. The GetHealthPercentage() function returns the current health ratio.

4. Create Health Bar

To visualize the health, you will create a health bar. Using UI elements, you can create a bar that represents the current health.

4.1 Add Health Bar UI Element

Right-click in the Hierarchy window and select UI > Image. This image will become the health bar. Set the Source Image of the Image component to design the default appearance of the health bar. Afterward, make the parent object of the health bar a child of the enemy character.

4.2 Write Health Bar Script

using UnityEngine;
    using UnityEngine.UI;

    public class HealthBar : MonoBehaviour {
        public Enemy enemy;
        public Image healthBarImage;

        void Update() {
            float healthPercentage = enemy.GetHealthPercentage();
            healthBarImage.fillAmount = healthPercentage;
        }
    }

Here, the HealthBar class serves to visualize the health of the enemy character. In the Update() method, it calls GetHealthPercentage() to set the ratio of the health bar.

5. Test Health Visualization

After implementing the health system, test to see if the health bar functions correctly. Deal damage to the enemy character to check if the health bar updates. To test, add the Enemy script to the game object and properly connect the HealthBar.

5.1 Add Test Code

void Update() {
        if (Input.GetKeyDown(KeyCode.Space)) {
            enemy.TakeDamage(10f);
        }
    }

Add the above code to the enemy character to decrease health each time the space bar is pressed. This allows you to observe changes in the health bar.

6. Optimization and Improvement

After implementing the health visualization system, you should consider how to optimize performance and enhance user experience. For instance, adding animations or various effects can visually highlight changes in the health bar’s status.

6.1 Add Health Bar Animation

When health decreases, provide an animated effect so that the player can more intuitively understand the situation. Use UI animations to achieve a smooth transition.

6.2 Change Color and Add Effects

Set the color to change when the health drops below a certain threshold. For example, implement it to change to Color.red when health is below 50%.

void Update() {
        float healthPercentage = enemy.GetHealthPercentage();
        healthBarImage.fillAmount = healthPercentage;
        healthBarImage.color = Color.Lerp(Color.red, Color.green, healthPercentage);
    }

7. Conclusion

In this tutorial, we explained how to visualize the health of enemy characters in Unity. Through the process of implementing and testing the health system, we learned how to utilize various features of Unity. This not only enhances the immersion of the game but also provides clear information to the player.

8. Additional Resources

If you are looking for more advanced features or techniques, we recommend referring to the materials below.

Refer to the above resources to learn the techniques for visualizing enemy character health in Unity and apply them to your own games. Thank you!

Unity Basic Course: C# Boolean

In game development, programming languages are a very important element. C# is the main programming language used in Unity, supports object-oriented programming, and is essential for utilizing various features of Unity. In this course, we will take a closer look at one of the basic data types in C#, the boolean type. The boolean type plays a very important role in programming logic and is essential particularly in conditionals and loops.

1. Understanding Boolean Type

The boolean type is a data type that can only have two values: true and false. In programming, the boolean type is used in various situations, mainly to determine the truth value of conditions in statements. For example, if a condition is true, a specific piece of code is executed, and if not, a different piece of code is executed.

2. Declaring Boolean Type in C#

In C#, the boolean type is declared using the bool keyword. Here is an example of declaring and initializing a boolean variable:

bool isGameRunning = true;
bool hasPlayerWon = false;

In the above example, the isGameRunning variable indicates that the game is in progress, while the hasPlayerWon variable indicates that the player has not won.

3. Utilizing Boolean Type

The boolean type is very useful in various situations. Here are a few examples of utilizing boolean variables:

3.1 Boolean Type in Conditionals

You can use statement (if statement) to check the value of a boolean variable. For example:

if (isGameRunning)
{
    Debug.Log("The game is in progress.");
}
else
{
    Debug.Log("The game has ended.");
}

In the above code, if the isGameRunning variable is true, the message “The game is in progress.” will be output. Conversely, if false, the message “The game has ended.” will be output.

3.2 Boolean Type in Loops

The boolean type can also be used in loops. For example, you can continue looping while a certain condition is true:

bool isPlayerAlive = true;

while (isPlayerAlive)
{
    // Proceed with the game while the player is alive
    if (playerHealth <= 0)
    {
        isPlayerAlive = false;
        Debug.Log("The player has died.");
    }
}

In the above example, the game continues while the isPlayerAlive variable is true. If the player’s health drops to 0 or below, the isPlayerAlive variable is set to false, ending the loop.

4. Boolean Type and Logical Operators

The boolean type can be used with logical operators to create complex conditions. C# provides logical operators such as AND (&&), OR (||), and NOT (!). Here is an example:

bool isDoorOpen = true;
bool isKeyInInventory = false;

if (isDoorOpen && isKeyInInventory)
{
    Debug.Log("The door is open and the key is in possession.");
}
else
{
    Debug.Log("Cannot open the door.");
}

In the above code, access is granted only when the door is open and the key is in possession.

5. Writing Game Logic with Boolean Type

The boolean type is used to implement various logic in game development. Here, we will look at an example of setting a win condition for a simple game:

bool hasPlayerWon = false;

if (playerScore >= winningScore)
{
    hasPlayerWon = true;
}

if (hasPlayerWon)
{
    Debug.Log("Congratulations! You've won.");
}
else
{
    Debug.Log("Unfortunately, try again.");
}

This example checks if the player’s score has reached the win condition and outputs a win message accordingly.

6. Boolean Type and Events

The boolean type is also useful for managing events and states in the game. For example, you can track whether a specific event has occurred:

bool isGamePaused = false;

public void TogglePause()
{
    isGamePaused = !isGamePaused;

    if (isGamePaused)
    {
        Debug.Log("The game has been paused.");
    }
    else
    {
        Debug.Log("The game has resumed.");
    }
}

In the above code, the TogglePause method toggles the paused state of the game and displays a message based on the current state.

7. Debugging and Boolean Type

The boolean type is also very helpful during the debugging process. By using boolean variables to track specific conditions or states, bugs can be easily located. For example:

bool isPlayerJumping = false;

if (isPlayerJumping)
{
    Debug.Log("The player is jumping.");
}
else
{
    Debug.Log("The player is on the ground.");
}

As shown above, boolean variables can be used to check the current state.

8. Optimization of Boolean Type

When using the boolean type, optimization can be done by avoiding unnecessary operations. For instance, removing duplicate checks or unnecessary conditionals for boolean variables can improve execution performance. Additionally, when changing the value of a boolean type, it is important to use a single variable to maintain readable code.

9. Conclusion

In this course, we took a detailed look at the boolean type, a basic data type in C#. The boolean type is utilized in various situations such as conditionals, loops, and event handling and is one of the key elements of game logic. I want to emphasize that understanding and properly utilizing the boolean type enables more effective game development.

I hope this course helps you understand the boolean type in C# for Unity development and allows you to create better games. Please continue to show interest in upcoming courses on various topics regarding Unity and C#.