Unity Basics
  • Welcome
  • Getting Started with Unity Software
  • Helpful Shortcuts
  • The Unity Software Interface
    • The Default Interface
    • The Windows (Tabs)
      • Hierarchy Window
      • Scene Window
      • Project Window
      • Inspector Window
      • Game Window
      • Console Window
    • Other Layouts
      • Create a Custom Layout
  • Create
    • Creating Game Objects
      • 3D Primitives
      • Creating Game Objects in the Editor
      • Spawning Objects
      • Unhiding/Hiding Objects During Gameplay
      • Parenting
    • Creating Assets
    • Creating Components and Scripts
      • Adding Components in the Inspector
      • Creating Custom Components and Scripts
    • Creating Prefabs
  • Select and Update
    • General Selection
    • Search and Focus
    • Updating Game Objects
      • Updating Game Objects in the Editor
      • Updating Prefabs
    • Updating Assets
    • Updating Components
      • Update Components in the Inspector
      • Accessing Components Through Scripts
  • Delete
    • Deleting Game Objects
      • Deleting and Disabling Objects in the Editor
      • Using the Destroy() Function
    • Deleting Components and Scripts
      • Disabling and Removing Components in the Editor
      • Disabling and Removing Components During Gameplay
  • Translate, Rotate, and Scale
    • Intro to Transforms
    • Handy Transform Shortcuts
    • Translate
      • Positioning Game Objects in the Editor
      • Updating Position Through Script Code
      • Using the Transform.Translate() Function
    • Rotate
      • Rotating Game Objects in the Editor
      • Updating Rotation Through Script Code
      • Using the Transform.Rotate() Function
    • Scale
      • Resizing/Scaling Objects in the Editor
      • Updating Scale Through Script Code
    • Controlling Speed
    • Common Issues with Transforms
  • Materials
    • Material Basics
      • Creating and Applying Materials
      • Accessing Materials Through Code
  • Physics
    • Physics Basics
    • Colliders and Triggers
      • Collider Component Overview
      • Accessing Colliders Through Scripts
      • Common Issues: Colliders and Triggers
    • Rigidbody Component
      • Rigidbody Component Overview
      • Accessing the Rigidbody Component Through Scripts
      • Common Issues: Rigidbody Components
    • Common Issues: Physics and Velocity
  • Interaction
    • Interaction Basics
    • Keyboard Controls
    • Mouse Controls
  • Coding Basics
    • Intro to Scripts
    • Variables
    • Conditionals (If / Then / Else)
    • Arrays
    • Loops
    • Functions
Powered by GitBook
On this page
  • Overview
  • Resize Objects by Updating the Local Scale Smoothly Through Code

Was this helpful?

  1. Translate, Rotate, and Scale
  2. Scale

Updating Scale Through Script Code

PreviousResizing/Scaling Objects in the EditorNextControlling Speed

Last updated 4 years ago

Was this helpful?

Overview

When the game is running, you will not be able to resize objects as you can within the editor, so one way to update the size or scale an object is by updating the object's scale in game units.

The scale values are stored in a vector3 variable with read-only parts, so you cannot update just one axis at a time through transform.localScale.y = 10.0F or something similar. You need to use the keyword new followed by a complete Vector3. Here's an example:

// Makes the object 10 game units tall
transform.localScale = new Vector3(0, 10.0F, 0);

Here, the game object becomes 10 game units tall. If it starts at 1 x 1 x 1, it appears to jump to that size in one frame and stays at that size until it's resized again.

Resize Objects by Updating the Local Scale Smoothly Through Code

Avoid using Transform.lossyScale. It controls the global scale of an object, so child objects can be skewed.

Example codes:

  • Each example should be placed within the Update() or FixedUpdate() function so that it runs once per frame

  • Each example grows the object it is attached to along the y-axis (gets taller from the center)

transform.localScale += new Vector3(0, 1.0F, 0) * Time.deltaTime;

The code above:

  1. Accesses the object's transform and then its local scale in game units

  2. Uses the += shortcut to add values to itself

  3. new Vector3(float x, float y, float z) is a way to tell it to add the matching variables

  4. Time.deltaTime adjusts for varying computer

transform.localScale += Vector3.up * Time.deltaTime;

The code above:

  1. Accesses the object's transform and then its local scale in game units

  2. Uses the += shortcut to add values to itself

  3. Time.deltaTime adjusts for varying computer speeds

Vector3.up is a for Vector3(0.0F, 1.0F, 0.0F);

speeds
shortcut