In this article, I introduce how to pick up a book (PDF) from the book collection placed in the distance and move it in STYLY. I am planning to make a Scene where I can call a book I want closer to me with a magic wand.
data:image/s3,"s3://crabby-images/399c2/399c24bfeee7cb605d568b021572f1a878fb3a84" alt="CB_fin2 - STYLY 完成イメージ"
The completion image
Sample
You can taste the sample space from STYLY GALLERY.
How to use Hold down the right grip button with the pointer kept at a book (PDF) to call it closer to you.
Pull the right trigger with the pointer kept at a book (PDF) to turn a page.
Pull the left trigger with the pointer kept at a book (PDF) to go back to the previous page.
You can download the Unity project introduced in this article. Choose a Book – Sample project
I use a paid asset, PlayMaker, in this article. Playmaker – Asst Store
How to create a wand
Create a wand
Firstly, we create a magic wand. This time, make a simple one from Unity’s Cube object. Change each parameter in the ‘Scale’ field so that the object forms an elongated shape.
data:image/s3,"s3://crabby-images/d83a6/d83a6c109d6655f7f297e75c4f6e504f8172c426" alt="CB01 - STYLY 杖を作る"
Create a wand.
I renamed it ‘Wand’.
Convert it into a Prefab
Convert the created wand into a Prefab. You just need to create the Prefabs folder and drag ‘Wand’ into it.
data:image/s3,"s3://crabby-images/54664/54664eaf75a9aab993d6e7baa979f214d8d7f7e2" alt="CB02 - STYLY プレハブにする"
Convert it into a Prefab.
Next, we add PlayMakerFSM to this Prefab.
Set up the sequences until the grip is held down
Right-click and select ‘Add FSM’ to add an FSM.
data:image/s3,"s3://crabby-images/ff9be/ff9be0d7fc2ef4c3fe4878e79a42b23885e4045f" alt="CB03 - STYLY PlayMakerでの作業"
Working with PlayMaker
We add an action to State1.
data:image/s3,"s3://crabby-images/60b5f/60b5f8b0edb877ce21ecb4decd297e1c63fe4753" alt="CB04 - STYLY アクションを追加"
Add an action.
Add ‘Find Object’ by Action Browser. Firstly, acquire the controller and store it in a variable. Enter ‘Controller (right)’ in the ‘Object Name’ field. Note that there is a space between ‘Controller’ and ‘(right)’. Create a new variable by selecting ‘New Variable…’.
data:image/s3,"s3://crabby-images/d4bc4/d4bc4798e94122a57c0ed377be72b9b39accc048" alt="CB05_a - STYLY 変数の作成"
Create a variable
Name it ‘Controller’ and set it in the ‘Store’ field
data:image/s3,"s3://crabby-images/4a98b/4a98b5c1a7480333ba06fac011fc85a63a8f2925" alt="CB05 - STYLY Find Game Objectの設定"
The setting for Find Game Object.
Next, make the wand created earlier a child of the controller by ‘Set Parent’.
data:image/s3,"s3://crabby-images/ef259/ef259ee4755f203fbeca4c14e1fe5eea0c700734" alt="CB06 - STYLY Set Parentの設定"
The setting for ‘Set Parent’
It creates the wand at the same place as the controller.
Add Raycast
Make the wand cast a Ray so that it acquires the object hit by it.
data:image/s3,"s3://crabby-images/16b70/16b7041c42bf63d051e4a636086ae8f81fb26299" alt="CB07a - STYLY Raycastの設定"
The setting for Raycast
Select ‘Specify game Object’ and specify the ‘Wand’ Prefab in the ‘From Game Object’ field. Set the Z-direction to 1. The object hit by Ray will be stored in ‘Store Hit Object’. Create ‘Hitobject’ by ‘New Variable…’ and specify it in the ‘Store Hit Object’ field.
Add the ‘Global_GripPressDown’ event
Create the ‘Global_GripPressDown_R’ event to trigger a transition when holding down the grip of VIVE controller.
data:image/s3,"s3://crabby-images/69e6c/69e6cd24e008e525664cb53e066bbc80d8d7d352" alt="CB08 - STYLY イベントの追加"
Add an Event.
by ‘Add Transition’, select ‘Global_GripPressDown_R’ created above.
data:image/s3,"s3://crabby-images/42e73/42e732376797a5f81120b199020e5bf340931322" alt="CB09 - STYLY トランジションの設定"
The setting for Transition
data:image/s3,"s3://crabby-images/c0da9/c0da96af9f3207c512c1754d153b9b9b0ceda493" alt="CB10 - STYLY State1の完成"
State1 is completed.
It completes the setting for State1.
Identify the object hit by Ray
Create a State to evaluate whether the object hit by Ray is a book or not. Create State2 and add ‘Get Name’ to it. Store the name of the hit object in a variable. Create a variable by ‘New Variable…’ and name it ‘Book’.
data:image/s3,"s3://crabby-images/b4358/b4358135b1d132ca4ed2cd4e6ea8b7c851cff9a0" alt="CB11 - STYLY Get Nameの設定"
The setting for ‘Get Name’
Add ‘String Compare’ to compare character strings. Set ‘Equal Event’ to ‘True’. Create the ‘False’ event and specify it in the ‘Not Equal Event’ field.
data:image/s3,"s3://crabby-images/e9333/e9333b84c3451609b4788bfa2772304f99bbfd3f" alt="CB13 - STYLY イベントの設定"
The setting for the Event
Specify a character string, ‘Book’, in the ‘Compare To’ field. If the hit object is ‘Book’, it triggers the True event, and If not, triggers the False event. When the False event is triggered, it goes back to State1.
data:image/s3,"s3://crabby-images/f2b4f/f2b4fee539d42e5b0cdc1efb89074df68abc78eb" alt="CB14 - STYLY State1とつなぐ"
Connect it to State1.
The sequence to move ‘Book’
In State3, we set the sequence when State2 triggered the True event. Firstly, create State3 and connect State2’s True to it.
data:image/s3,"s3://crabby-images/8944d/8944d88fe05447f72e64a39083c2aa12a1c04448" alt="CB15 - STYLY State3を作ってつなぐ"
Create and connect Stage3.
When moving ‘Book’, we also want to move the parent object of ‘Book’. Acquire the parent object by using ‘Get Parent’. Create ‘Parent1’ by ‘New Variable…’ and specify it in the ‘Store Result’ field.
data:image/s3,"s3://crabby-images/0d0c5/0d0c58b2febe551ac15b8ab1dd8c384bf355c722" alt="CB16 - STYLY Get Parentの設定"
The setting for ‘Get Parent’.
We also want to acquire the one-higher-level parent object, so add ‘Get Parent’ once more. Create ‘Parent2’ by ‘New Variable…’ and specify it in the ‘Store Result’ field.
data:image/s3,"s3://crabby-images/48da1/48da195064216ceac3f9e478a7571e6b704635ac" alt="CB17 - STYLY さらにGet Parentを追加"
Add another ‘Get Parent’.
Move the parent object acquired to a location by ‘Move Towards’. In the sample Scene, I set it so that the object moves to the location, (0,1,0). Set ‘Finish Distance’ to 0.
data:image/s3,"s3://crabby-images/349ae/349ae4ddd0b9a3a2fd97f7a43ff4853560951c38" alt="CB18 - STYLY Move Towardsの設定"
The setting for ‘Move Towards’.
Add ‘FINISHED’ to State3’s Transition and connect it to State1. It’s completed now.
data:image/s3,"s3://crabby-images/4fb5e/4fb5e221b4e0fd29d6ae7ea2f1d6dc2407f5c3bd" alt="CB19 - STYLY State1につなぐ"
Connect it to State1.
I placed the asset so that the book is put on the desk exactly. Now you can select and call a book in the distance while setting back on the sofa.
data:image/s3,"s3://crabby-images/99322/993226aa315e65583c973250efb6456860383cea" alt="CB_set - STYLY 完成シーン"
The completed Scene.
Please refer to the article below to learn how to import a PDF to a Scene. Read the article How to upload an asset from Unity to STYLY. Read the article In this article, I introduced how to access a remote object by casting a Ray. It would be useful to create the Scenes with the UI for navigation or a game.