In this article, I will introduce how to create a scene where objects appear in the sky, drop down, and keep on piling up on each other.
I will use Unity PlayMaker to create this scene.
- 1 Sample
- 2 Preparation
- 3 Create a Floor
- 4 Create the Objects That You are Going to Drop
- 5 Creating a Vending Machine
- 6 Dropping an Object
- 7 Looping the Drop Action
- 8 Randomizing the Spawn Position
- 9 Prevent the Vending Machine from Passing Through the Floor
- 10 Set a Parent to the Vending Machine
- 11 Upload to STYLY
Sample
Preparation
Download a FBX file from Google Poly
Download a FBX file from Google Poly. In this tutorial, I downloaded a FBX file of a vending machine.
data:image/s3,"s3://crabby-images/359c4/359c459bfb8a87aab57e6dc3dc0e2ff3d523a3a1" alt="自販機fbx - STYLY Google PolyからFBXファイルをダウンロードする"
Downloading a FBX file from Google Poly
Import the Downloaded FBX File to Unity
Next, we need to import the downloaded FBX file to Unity.
data:image/s3,"s3://crabby-images/cd1a5/cd1a5e5616d762d4754340f977a61a2c5a891d3f" alt="import_new_asset_project - STYLY ダウンロードしたFBXファイルをインポートする"
Importing the downloaded FBX file
Create a Floor
We need to create a floor, that the objects will drop on to.
data:image/s3,"s3://crabby-images/e949d/e949d2713f5e2451b174c7459f4a292c99d3386e" alt="create_plane - STYLY 床を作る"
Creating a floor
Create the Objects That You are Going to Drop
Next, we want to set the scene so that the vending machines drop from the sky. In order to do so, we need to create a manager which will control the dropping motion.
Let’s create that manager.
Use Create Empty to create an object, and set the name to ‘vending create’.This vending create will act as the manager for the movements.
data:image/s3,"s3://crabby-images/f20fb/f20fb3b9f43bd9ab6cfe7c7eea98aa2747a05bc3" alt="create_empty - STYLY Create Emptyをクリックする"
Click Create Empty
Creating a Vending Machine
Create a Vending Machine Prefab
Let’s create a vending machine. First, we need to change it into a prefab.
Drag and drop the vending machine (model) into the Hierarchy, then return it to the Project tab again.
data:image/s3,"s3://crabby-images/3f45d/3f45d01cd78d587cc95a874be95661a600826950" alt="model_panel copy - STYLY プレハブ化"
Create a prefab
This time, change the vending machine (model) name to ‘vending_machine’.
Do not delete the original imported vending machine. You will still need it.
The result should be as shown in the image below.
data:image/s3,"s3://crabby-images/2bf61/2bf616841b80dfd118eec8903900f36cbc6d9952" alt="model_with_allow - STYLY 最終的なProjectビュー"
Final Project view
Create an Event with PlayMaker
Select vending_create, then choose add state from the PlayMaker window.
data:image/s3,"s3://crabby-images/19f77/19f7797353f0c12212054538ed07ab0c824660d4" alt="add_fsm - STYLY Stateを追加する"
Add a State
Click add state, and the screen will look like this. Select the Events tab and create a ‘create vending machine’ event.
data:image/s3,"s3://crabby-images/9d95d/9d95d55b418d4e9e0baf01e1baec77ca1ff75b82" alt="自販機生成action - STYLY 自販機生成イベントを作成する"
Create a create vending machine event
Add a Create Object action.
data:image/s3,"s3://crabby-images/5da75/5da75ca80e436d47a958417c8e6cf84bec9752b4" alt="create_obj - STYLY Create Objectアクションを追加する"
Add a Create Object action
Then, add the vending machine prefab to the Create Object action.
Drag and drop the vending_machine to the Game Object column.
data:image/s3,"s3://crabby-images/9e072/9e07206e10176379f50a5881c03b45cd9210fe40" alt="create_obj_to_action copy - STYLY vending_machineをGame Objectに追加する"
Add vending_machine to Game Object
We want the vending machine to spawn slightly above the ground, so set the Position to (0, 2, 0).
data:image/s3,"s3://crabby-images/24f59/24f597a5faf531d8240a489ddb00f839f554c25d" alt="change_pos - STYLY Create ObjectのPositionを変更する"
Change the Position of the Create Object
Click the Play button and you will see a floating vending machine appear.
data:image/s3,"s3://crabby-images/57540/57540e3260e2bdb5fcd3113f2102752c7274ece7" alt="floating_vending - STYLY 自販機が生成されるか確認"
Check if the vending machine spawns
Dropping an Object
We were able to create a vending machine in the air.
But it is currently just floating, so we need to change settings so it will drop to the ground.
Click vending_machine, and choose the Add Component in the Inspector tab, then add a Rigidbody component to the vending machine prefab.
Click the Play button, and the vending machine will drop from the sky.
data:image/s3,"s3://crabby-images/a8b49/a8b4919fc4cb702cbcf7dac7098e91c276a0563a" alt="rididbody - STYLY Rididbodyコンポーネントを追加する"
Add a Rigidbody component
Looping the Drop Action
All we need to do now is to loop the vending machine drop action.
Let’s set it so that the drop action will take place every 2 seconds.
In order to loop the create vending machine event, create an arrow starting from State 1 and returning to State 1, as in the image below.
Then, create a Wait action, and set the Time to 2. Set the Finish Event to ‘Create Vending Machine’.
This setting will loop the create vending machine event every 2 seconds.
A vending machine will appear in the air and drop to the ground every 2 seconds now.
data:image/s3,"s3://crabby-images/7783b/7783b3bdf996651ba229395c5f755f2e2a4f32f8" alt="wait - STYLY Waitアクションを追加する"
Add a Wait action
Randomizing the Spawn Position
Since the spawn position is the same, the vending machines will be created on top of each other, and will become some sort of tower. We need to use Random Float and Set Vector3 XYZ to randomize the spawn position.
Create Random Float and Set Vector3 XYZ, and then set the following values to them.
Random Float will create a random value between -2 and 2, and store that value in the ‘random_pos’ variable.
Setting Vector3 XYZ will set the X-axis, Y-axis, and Z-axis.
In the image below, random_pos is applied to X, 5 is applied to Y, and random_pos is applied to Z. The XYZ-axis will get stored in the variable pos.
data:image/s3,"s3://crabby-images/2b067/2b06759be55e94c1059b37d9dc7563d4b57e5848" alt="random_set_vector3 - STYLY Random FloatとSet Vector3 XYZアクションを追加する"
Add Random Float and Set Vector3 XYZ action
With these settings, the vending machine spawn position is now randomized.
Prevent the Vending Machine from Passing Through the Floor
Currently, the vending machine will just pass through the floor, so we need to use Physic Material to prevent that.
First, we need to create a Physic Material. Name it ‘plane_physic_material’.
data:image/s3,"s3://crabby-images/861be/861be81823253996a3e67b6ba1ee0ef1de00dd64" alt="create_physic_m - STYLY Physic Materialを作成する"
Create Physic Material
Set the values as in the image below.
data:image/s3,"s3://crabby-images/cfc35/cfc3506296bacc820d1d4462ae87fb212b139999" alt="plane_physic - STYLY Physic MaterialのInspector数値の変更"
Changing the Inspector values for Physic Material
Set it to the Material of the Plane Mesh Collider.
data:image/s3,"s3://crabby-images/fcb6a/fcb6a3a24c74544fc987bb6372650c08a4c3daa3" alt="plane_ins - STYLY Planeにplane_physic_materialを追加する"
Add plane_physic_material to the Plane
Then add a Box Collider component to the vending_machine, and add plane_physic_material to the Box Collider material.
With these settings, the vending machine will not pass through the ground anymore.
data:image/s3,"s3://crabby-images/9b2f7/9b2f7eff5cd1c50dc67641483dd5878510b138af" alt="vending_ins - STYLY Box Colliderにplane_physic_materialを追加する"
Add plane_physic_material to the Box Collider
Set a Parent to the Vending Machine
It isn’t neat or clean for vending machines to be created right under Hierarchy, so use the Set Parent action to set a parent.
With this setting, the created vending machines will be created under vending_create, and will look more organized.
Create a Set Parent action under the Create Object action.
Set the values as in the image below.
Add the object created by the Create Object action to the ‘created_obj’ variable.
We will use that variable in Set Parent.
data:image/s3,"s3://crabby-images/7e5e7/7e5e750fae9190c8e2004a11e84d434a0d8156b8" alt="create_obj_set_parent - STYLY Set Parentアクションを追加する"
Add a Set Parent action
Click the Play button, and you will see that the created vending machines will be created under vending_create.
data:image/s3,"s3://crabby-images/db0c8/db0c8ac75d47369fcd21681459d1010720aeb4f8" alt="created_clones - STYLY Set Parentの動作確認"
Checking Set Parent settings
Upload to STYLY
How to upload an asset from Unity to STYLY
In this article, we created a scene where objects are continuously created and piled up on each other.
You can change the object, or how many objects spawn at once, or change the loop time to create a scene that you want.
I hope you use this technique for your future creations.