• Studio

  • Bots

  • Web API

  • Designer Resources

  • Host Resources

  • CREATE

    Scripting

    Lua

    Attributes

    Edit

    Serialized Fields

    Introduction

    In Highrise Studio, Serialized Fields are Lua variables that are visible and editable in the Inspector. By marking a variable as a Serialized Field, you can modify its value directly in the Studio Editor without changing the script code. This feature is useful for tweaking values, testing different configurations, and adjusting properties during runtime.

    What is The Preceding --! in Serialized Fields?

    The --! prefix is a special directive in Lua that indicates a comment recognized by the Studio Editor. By adding --! before a comment, you can specify directives like SerializeField to expose variables in the Inspector. This prefix helps Studio identify specific comments as directives and process them accordingly.

    For example, to define a Serialized Field in Lua, you can use the --!SerializeField directive before the variable declaration:

    --!SerializeField
    local moveSpeed: number = 5
    

    Why Use Serialized Fields?

    Serialized Fields offer several benefits for game development in Highrise Studio:

    1. Interactive Editing: Serialized Fields enable interactive modification of variable values in the Inspector panel, allowing real-time adjustments without script code changes.

    2. Customization: Exposing variables as Serialized Fields enables direct customization of game objects, behaviors, and properties in the Studio Editor, enhancing flexibility and control.

    3. Testing and Debugging: Serialized Fields offer a convenient way to test various configurations, tweak values, and debug scripts during development, streamlining the iteration process.

    4. Runtime Modifications: Serialized Fields facilitate changing variable values during runtime, simplifying experimentation with different settings and behaviors without restarting the game.

    Overall, Serialized Fields are a powerful feature in Highrise Studio that simplifies the process of tweaking variables, adjusting properties, and customizing game elements directly in the Inspector panel.

    How to Define Serialized Fields

    To define a Serialized Field in your Lua script, you need to use the SerializeField attribute followed by the variable declaration. This attribute tells the Studio Editor to display the variable in the Inspector panel, enabling you to edit its value interactively.

    Here's an example of defining Serialized Fields in Lua:

    --!SerializeField
    local myNumber: number = 5
    

    In this example, myNumber is a Serialized Field with an initial value of 5. By adding the SerializeField attribute before the variable declaration, you can modify myNumber directly in the Inspector panel.

    What Types of Variables Can Be Serialized?

    In Highrise Studio, you can serialize various types of variables, including fundamental data types (e.g., numbers, strings, booleans) and Unity-specific types (e.g., GameObject, Transform, Vector3). By marking these variables as Serialized Fields, you can customize and adjust their properties interactively in the Inspector panel.

    Here are examples of different types of Serialized Fields in Lua:

    --!SerializeField
    local myNumber: number = 5
    --!SerializeField
    local myString: string = "Hello, World!"
    --!SerializeField
    local myBool: boolean = true
    --!SerializeField
    local myGameObject: GameObject = nil
    --!SerializeField
    local myTransform: Transform = nil
    --!SerializeField
    local myVector: Vector3 = Vector3.new(1, 2, 3)
    

    When defining Serialized Fields, you can use various data types to represent different values and properties in your Lua scripts. This flexibility allows you to customize game objects, behaviors, and interactions effectively during development.

    Note: when declaring typed variables, the fundamental types are lowercase where the Unity types are PascalCase. To get more supported Unity Types, see Learn>Studio>API>Classes on the Create Portal.

    Fundamental Types Example (lowercase):

    --!SerializeField
    local myString: string = "Hello, World!" -- Lua String Type
    

    Unity Types Example (PascalCase):

    --!SerializeField
    local Vector3Value: Vector3 = Vector3.new(1, 2, 3) -- Unity Vector3 Type
    

    How to Access Serialized Fields

    Once you've defined a Serialized Field in your Lua script, you can access and modify its value in the Inspector panel. To view and edit Serialized Fields, select the game object or script containing the variables, and navigate to the Inspector panel in the Studio Editor.

    In the Inspector panel, you'll see the Serialized Fields listed with their corresponding values. You can click on the value field to edit the variable directly, enter a new value, and press Enter to apply the changes.

    Video Preview

    Conclusion

    Serialized Fields are a valuable feature in Highrise Studio that simplifies the process of tweaking variables, adjusting properties, and customizing game elements interactively. By marking variables as Serialized Fields, you can modify their values directly in the Inspector panel, enabling real-time adjustments without changing the script code. This interactive editing capability enhances flexibility, control, and efficiency in game development, making it easier to test configurations, debug scripts, and customize game objects during development.

    Updated 3 months ago

    PocketWorlds Icon

    © 2024 Pocket Worlds. All rights reserved.