This article uses Unity’s Button UI and combines it with the Interaction SDK provided by STYLY to create a UI in which interaction occurs.
Like Unity, an interface that uses graphics such as images is called a Graphical User Interface (GUI).
In this article, we will use the Button object of Unity’s GUI. We will begin with basic functions and then explain how to work with the Interaction SDK.
For more information about the Interaction SDK, one can read the following articles in advance to deepen their understanding
Sample Scene
A sample scene follows below. Let’s experience a type of UI to create.
Button UI Basics
This section introduces how to create and configure the Button UI.
The first method of adding a button is to directly add a button.
You can add a button by right-clicking on the Unity hierarchy window and selecting UI > Button.
data:image/s3,"s3://crabby-images/dd0f9/dd0f928b66fa2c59b0ee3d9d04faefa92522b3d5" alt="img_5fa607da8d75c - STYLY"
UI > Button
4 objects will be added to the hierarchy window.
data:image/s3,"s3://crabby-images/719a4/719a45d5431d1dd99f1fa021069d65a45b71c827" alt="img_5fa60826a0378 - STYLY The 4 objects"
The 4 objects
- Canvas: This is the abstract area in which the UI is placed and drawn. All UI objects must be placed on Canvas to function.
- Button: The button object itself. Button: The button object itself, which sets the image data, etc.
- Text: Text. This is displayed on the button.
- EventSystem: System for sending UI events.
The button UI has now been added.
The button is pre-configured to cause interaction when one left-clicks the mouse.
This occurs because the Button component has a pre-configured “On-Click” event. By combining this event with the Interaction SDK, one can create a mechanism where the action of the Interaction SDK is triggered when the button is clicked.
Detail will follow later.
First, let’s customize the Button component by changing its color.
Customizing the Button
Select the Button object. Let’s set up the “Button” in the inspector window.
data:image/s3,"s3://crabby-images/5e246/5e24630c7145df786e59dd5d092742fe6a004330" alt="img_5fa60e9b4d9eb - STYLY Button Components"
Button Components
In the button component “Transition”, one can set the change when the button is pressed.
data:image/s3,"s3://crabby-images/1590e/1590ee2e353e653d4a246fa05fa5d8b2452b7527" alt="img_5fa6109ccb25b - STYLY"
Transition
- None: Nothing changes.
- Color Tint: The color changes.
- Sprite Swap: Sprite switches.
- Animation: The animation is played.
In this tutorial, we will use a Color Tint as a basic tool.
The Color Tint is used to set up a color change when the button is pressed.
data:image/s3,"s3://crabby-images/804f7/804f74279e700ceebc790cfe845362e2c2186052" alt="img_5fa623c842540 - STYLY Color Tint Setting Items"
Color Tint Setting Items
Each setting item is described.
- Target Graphic: The object whose color is to be changed. The default is the Button object.
- Normal Color: The color of the normal state.
- Highlighted Color: The color when the mouse is hovering over the button.
- Pressed Color: The color when the mouse is pressed on the button.
- Disabled Color: Color when the button is disabled.
- Color Multiplier: Multiplies the color of the transition by this value.
- Fade Duration: The duration of time to change the color.
Let’s actually change the color.
Leave Target Graphic as is.
Change Normal Color to light yellowish green.
data:image/s3,"s3://crabby-images/c8d0b/c8d0b89fd78f2084d43009dd297070ee63c11e36" alt="img_5fa624e7bc36e - STYLY Light yellow-green"
Light yellow-green
Highlighted Color to light blue
data:image/s3,"s3://crabby-images/74328/7432894b6a639f5c190602fc4e5733e0c45a1ab7" alt="img_5fa625937a03a - STYLY Light blue"
Light blue
Pressed Color to red.
data:image/s3,"s3://crabby-images/c7ba3/c7ba357ae776a0da0e5c9c5418e7ab646d26e0c4" alt="img_5fa625e1b9294 - STYLY Red"
Red
Disabled Color, Color Multiplier, and Fade Duration are left unchanged.
The result is as follows.
data:image/s3,"s3://crabby-images/ef26a/ef26afd7ea27fa7b23c731ec09241c2254ff8118" alt="img_5fa626da50b87 - STYLY Color Tint setting of Button"
Color Tint setting of Button
Now let’s play the scene. Play it and click the button in the game window.
The color of the button has changed, but it turns white after the click. This is a result of an activated navigation mode.
Change the navigation setting from Automatic to None.
data:image/s3,"s3://crabby-images/aa9a3/aa9a3c5c5b6d1ac4a8aa94d030bd03ef8d8e35bf" alt="img_5fa62a5ecbf8f - STYLY"
None
Let’s play it.
Now the color changes as intended.
This is how one can set the action of the button.
We have only written about this color setting, but you can also set the image of the button.
We will discuss that in other article.
Button Placement
In its current position, the button is in the middle and somewhat obstructs manipulating the screen.
Let’s set the position of the button.
Select the Button object to view the Inspector window.
To set its position, size, etc., we can change the Rect Transform.
data:image/s3,"s3://crabby-images/fc2b6/fc2b6549b08dce04d0543bbc8f2b818af1adf4b0" alt="img_5fa8be61a9570 - STYLY"
Rect Transform
You can adjust the position of the buttons by changing the topmost Pos X, Y, and Z values.
In this case, let’s increase the size of the buttons slightly and place them at the bottom of the screen.
Set the Width to -320, the Height to 60, and Pos Y to -400.
data:image/s3,"s3://crabby-images/4370e/4370eaa6f53107d22971844373e82c8c078aed24" alt="img_5fa8bf8baffc1 - STYLY"
Rect Transform
Set the size of the game window to 1920 x 1080.
data:image/s3,"s3://crabby-images/4962b/4962b6cdb017c1a68b1557e9d659e2287dde747f" alt="img_5fa8bfe25ed79 - STYLY Game Window"
Game Window
One then has the following.
data:image/s3,"s3://crabby-images/b0dc4/b0dc4708c93f286c266bc8b2a15d80660ecacac5" alt="img_5fa8bf9fa3403 - STYLY The game window"
The game window
Now you can set the position!
Combining Button and Interaction SDK
Adding the Interaction SDK
Add the Interaction SDK.
Refer to the following article to learn how to add the Interaction SDK.
Making an Interaction Object
In this article, we will use the interaction SDK “STYLY_Action_Spawner” to create an interaction that generates an object when a button is pressed.
Creating the Spawn object
Create an object generated by Spawner.
Right-click in the hierarchy window to create a Sphere object.
data:image/s3,"s3://crabby-images/dbcee/dbceea8c7698b241d88be1a620979f111cc9d6ab" alt="img_5fa8c566274a1 - STYLY Create a Sphere"
Create a Sphere
The name should be Spawn and the Transform should look like the following.
data:image/s3,"s3://crabby-images/e2bf0/e2bf0cbd041ddb1445b099d20a9113807da971ad" alt="img_5fa8c754c282d - STYLY"
Transform
Attach Rigidbody and, when it spawns, set it to generate gravity.
data:image/s3,"s3://crabby-images/08f53/08f53389dea6f7b3c2cde06ed92013aebb66ff3d" alt="img_5fa8d00bc1462 - STYLY"
Rigidbody
Finally, prefabricate the Spawn object.
Drag and drop the Spawn object from the Project window to the Hierarchy window.
Remove Spawn on the hierarchy window.
data:image/s3,"s3://crabby-images/c49f2/c49f2f8db79c37fd8be31fc3b135b15bc4a44438" alt="img_5fa8c8661dfc4 - STYLY Removed from the hierarchy window."
Removed from the hierarchy window.
Making Spawner Objects
Create a Spawner object to generate Spawn.
data:image/s3,"s3://crabby-images/12c74/12c74f271519216ca82a99510f25d991db2511e8" alt="img_5fa8c3f0d46cd - STYLY Create a Cube"
Create a Cube
Let the name be Spawner and the Transform be
data:image/s3,"s3://crabby-images/4d368/4d36897985b978d45f65c05dd619ee4be09de8d9" alt="img_5fa8c4a51dcee - STYLY"
Spawner
Add the script STYLY_Action_Spawner in the Interaction SDK to this Spawner object.
Add it from the Inspector window.
data:image/s3,"s3://crabby-images/fc8d8/fc8d8a3e9f0d9567716e70ed74247aa1c2dec6e3" alt="img_5fa8cf19bb41b - STYLY Add the script"
Add the script
Let’s set up STYLY_Action_Spawner.
Add a prefabricated Spawn object in the Prefab column.
Make Spawn Transform a Spawner. Drag and drop it from the hierarchy window.
You are now ready to set up Spawner.
Button and Interaction SDK settings
Pressing the left mouse button creates a mechanism that generates a Spawn object from Spawner.
Click Button in the hierarchy window to bring up the inspector window.
data:image/s3,"s3://crabby-images/cb292/cb2926cfd1d576a846764bd6806200aa35b7017f" alt="img_5fa8d787d740e - STYLY"
Button
Configure the On-Click settings for the Button object.
Add the List first.
Let’s add a List by pressing the “+” button in the bottom right corner.
data:image/s3,"s3://crabby-images/b56aa/b56aa861af328d978d33e654cce969e2b7621177" alt="img_5fa9e0dfb96a8 - STYLY Add a List"
Add a List
After the List is added, drag and drop Spawner from the hierarchy window to the “None (Object)” field.
Set the No Function field to STYLY_Action_Spawner > Spawn().
data:image/s3,"s3://crabby-images/38202/382028758906000940093195fdfe3a64dd1ea07e" alt="img_5fa9e18e879e0 - STYLY"
STYLY_Action_Spawner > Spawn()
You have now completed the configuration.
data:image/s3,"s3://crabby-images/9b9b2/9b9b2f86837793d37263f20a71036815f62d3edd" alt="img_5fa9e1d5eab2e - STYLY The setting"
The setting
Let’s play it back to observe.
Press the button and Spawn from Spawner has occurred. It is now complete!
Upload to STYLY
Upload to STYLY. This time, we’ll upload it in a scene.
If your scene is too large to upload to STYLY, please see this article.
Upload your scene from your timeline to STYLY.
How to create an account
How to upload a prefab from Unity to STYLY
Introduction to NEWVIEW SCHOOl ONLINE
NEWVIEW SCHOOl ONLINE, where you can learn the basics of Unity and PlayMaker necessary for creating VR/AR content, from the basics to the application of PlayMaker, and learn the process of creating the fascinating content available on STYLY (we’ll also expose the production techniques).