Unity has a function called Animator Controller, which is used to implement animation effects for characters and 3D models.
Animator Controller controls multiple animation clips. By using this function, you can switch animation clips and combine different animations.
data:image/s3,"s3://crabby-images/fb939/fb9390f836b638cafc313042f22b5fbd61f07996" alt="スクリーンショット 2019-08-05 12.29.04 - STYLY"
AnimatorController Settings
In this article, I will introduce how to use Animator Controller to create a rotating cube animation.
Be aware that you need basic knowledge about the animation function beforehand, so if you haven’t read the ‘[Introduction to Unity] Learn Animation System’ article yet, please read this first.
Open the Animator Controller
Before starting, please create a Cube in a Scene.
You can keep the settings as a default.
data:image/s3,"s3://crabby-images/a0918/a0918044e0ae3de3bbd4f7996ed77efc252feffe" alt="スクリーンショット 2019-08-02 20.06.41 - STYLY"
Create a Cube
First, go to the Project view and select「Create」→「Animator Controller」.
data:image/s3,"s3://crabby-images/9d66d/9d66d8fa08bcf7768605094a06027cefdcf67deb" alt="スクリーンショット 2019-08-02 14.50.03 - STYLY"
Creating an animation controller in the Project view
A new file is created in the Assets folder. This is the Animator Controller file.
For this tutorial, I want to create an animation where the object simply rotates, so please change the Animator Controller’s name to ‘Rotate’.
data:image/s3,"s3://crabby-images/57ca5/57ca53e07be2f2e804ef7dd59e1fff88bee581e2" alt="スクリーンショット 2019-08-02 14.50.28 - STYLY"
The created AnimatorController
Double click on the Animator Controller file. The Animator settings window will appear in the Scene.
data:image/s3,"s3://crabby-images/c2c69/c2c698cad20ecd5aed7580bdadabf11699acb4e1" alt="スクリーンショット 2019-08-02 15.02.13 - STYLY"
Animator settings
Creating an Animation
Let’s create a Rotate animation.
In the Project view, right click and select「Create」→「Animation」.
data:image/s3,"s3://crabby-images/2782c/2782c3dae9327feba11e75b7a961ca4b13f50f18" alt="スクリーンショット 2019-08-02 17.30.29 - STYLY"
Create an Animation clip
An animation clip will be created in the Assets folder, so change the file name to ‘Cube Rotate’. Drag and drop the file into the Cube’s Inspector window.
This procedure is needed because the file does not work on it’s own, it needs to be attached to the object it affects (in this case, The Cube).
data:image/s3,"s3://crabby-images/90cbd/90cbdad35669429854b00e6b2fa3b119176b940b" alt="スクリーンショット 2019-08-02 17.38.24 - STYLY"
Adding an animation by drag and drop
An animation has been added to the Cube’s Inspector window.
data:image/s3,"s3://crabby-images/32b87/32b87806b3a923406938d1860c7e14578d535e39" alt="スクリーンショット 2019-08-02 19.16.09 - STYLY"
Animation added to the Inspector
Although the animation is set to the Cube object, the animation is still empty.
We need to add a rotation movement to the animation.
Click the Window menu, select Animation and open the Animation view.
data:image/s3,"s3://crabby-images/f212e/f212e2fc2d8940b2f3a7dcdb113828b74cda4403" alt="スクリーンショット-2019-06-12-17.05.41-e1560326778191 - STYLY"
Animation view
In the Animation view, select「Add Property」→「Transform」→「Rotation」, and click the + button.
data:image/s3,"s3://crabby-images/7a5fa/7a5fa127d6042cef7e15515b0926aec9f1e0a68b" alt="スクリーンショット 2019-08-02 19.40.23 - STYLY"
Add properties to Rotate
As in the image below, a timeline will be displayed. You change the keyframe value of Rotation.y to 1:00 to 360.
data:image/s3,"s3://crabby-images/2d0f0/2d0f0c53f56829898c787691e57634d5cacf99cf" alt="スクリーンショット 2019-08-02 19.39.48 - STYLY"
Settings to rotate once every second around the Y-axis
These settings make the Cube rotate once (for 360 degrees) around the Y-axis in one second.
Running the Scene looks like the animation below.
data:image/s3,"s3://crabby-images/5a484/5a484d08e5c87b55f4d967a8506273bd7e33ac4a" alt="回転1 - STYLY"
The Cube rotates only once
As designed, the Cube rotates once around the Y-axis. But the animation stops after one rotation.(The above is a GIF image, so it will rotate continuously)
Create a State
Next, I will explain how to use the Animator Controller.
Right click in the Animator window, and select「Create State」→「Empty」.
data:image/s3,"s3://crabby-images/46c68/46c681a91b72e20d3f808df75f82edd7655f8726" alt="スクリーンショット 2019-08-02 15.08.51 - STYLY"
Select Empty
A rectangle called ‘New State’ has been created.
data:image/s3,"s3://crabby-images/83820/838207461dbc7b36b6c7184c4c93cd5a2db6a5bf" alt="スクリーンショット 2019-08-02 15.09.04 - STYLY"
New State is created
The rectangles in the Animator window are called ‘States’, which includes ‘New State’.
A State is a function that can store and set parameters for animation clips. By adjusting the settings of each State you can change the animation’s characteristic.
Currently, an arrow has been drawn from the ‘Entry’ State and heads toward the ‘New State’. This arrow is called a Transition.
A transition is used to define the execution order of animations. In the above image, the ‘Entry’ animation runs first and then the ‘New State’ animation runs second.
Role of Each State
I will explain the basic roles of each default State.
Entry
The Entry State is the first State that is called and transitions start from here.
You need to set a transition from Entry to the animation if you want to run it first.
data:image/s3,"s3://crabby-images/971c3/971c3dc44b8d63df0035ec302f0c91a6936b10b5" alt="スクリーンショット 2019-08-02 16.24.03 - STYLY"
Entry
Any State
The Any State functions to transition from State to State.
data:image/s3,"s3://crabby-images/efe5d/efe5df0984804c816319804337b09cd1c4f93fa9" alt="スクリーンショット 2019-08-02 16.20.12 - STYLY"
Any State
So, if you set a transition as in the image below, then you can set any transitions you want to.
data:image/s3,"s3://crabby-images/01f86/01f86373d539753b90a97b7ca7caf064a01f4ed6" alt="スクリーンショット 2019-08-02 17.00.55 - STYLY"
Any transitions can be set
Exit
If you transition to the Exit State, the transition resets to the Entry State.
data:image/s3,"s3://crabby-images/001a7/001a7d267f4a1218b7baf21b1651a9647b93fb46" alt="スクリーンショット 2019-08-02 16.20.23 - STYLY"
Exit
So, if you set the last transition to the Exit State, then you can loop your animations.
How to Use Animator Controller
Once we have learned about each State, let’s select the ‘New State’ we created in the previous step and change the name to ‘Cube Rotate’.
data:image/s3,"s3://crabby-images/ba6e8/ba6e8bf693088863e10f744b8e0baa2708bfb378" alt="スクリーンショット 2019-08-02 17.06.35 - STYLY"
Changing the State name
Looping the Animation
Next, let’s set a loop for the animation by editing the State settings.
Right click the ‘Cube Rotate’ State, and then click ‘Make Transition’.
data:image/s3,"s3://crabby-images/c0f62/c0f62945e8a0ee4bfdd5566ac7e2804a627e0f6b" alt="スクリーンショット 2019-08-05 12.03.17 - STYLY"
Select Make Transition
A white arrow will emerge. Attach this arrow to the ‘Exit’ State.
data:image/s3,"s3://crabby-images/a49e7/a49e7e7e38d2a2b759649b333258a549de64844d" alt="スクリーンショット 2019-08-05 12.03.25 - STYLY"
Transition to the Exit State
The transition will return (reset) to the Entry State after the Exit State. The animation will loop with this setting.
Run the Scene and check the animation.
data:image/s3,"s3://crabby-images/d1799/d17994d8bdb328cd693e64e32704b27f80def039" alt="連続回転 - STYLY"
Looping Rotate animation
You can see the animation is looping now.
Conclusion
In this tutorial, I introduced how to set an animation in Unity.
If an animation looks complicated, then it is because there are many objects included with many associated movements and transitions.
I hope you make good use of the Animator Controller in Unity.