In this article, I’ll show you how to implement an animation of the camera moving in space in Unity using PlayMaker and upload it to STYLY. If you can understand the flow of this article, you can create an animation that looks like the following
data:image/s3,"s3://crabby-images/76544/765446b68bef1bc15640e15325363987ae34d35b" alt="レムGIF-3 - STYLY"
Sample GIFs
At the end of this article, I’ve attached a Unity package for camera detection for those with time constraints and already understand how Playmaker works.
That Unity package allows you to easily create features like moving and rotating the camera, as described in this article.
Sample.
You can experience “REM” in VR, which is an evolution of the camera movement function from STYLY GALLERY.
Preparation.
Import Playmaker (paid).
Playmaker 1.9.0 https://assetstore.unity.com/packages/tools/visual-scripting/playmaker-36
Once you’ve imported Playmaker, open a new project in Unity and install PlayMaker.
The Asset named iTween used this time is mentioned here but is not included in PlayMaker version 1.9 or later, it is necessary to import iTween manually.
If you are using a PlayMaker version anterior to v1.9, you can skip the following “Import of iTween (direction of using PlayMaker 1.9 or later)” because it is included when you install PlayMaker. You can check if iTween is included or not from the Assets in the Project window.
data:image/s3,"s3://crabby-images/913b8/913b84402c5773829c83d4247e22cdf1da6d79fb" alt="スクリーンショット 2018-08-28 16.48.00 - STYLY"
Project window (with iTween)
If you don’t see iTween in Assets, you need to import it, so read the next chapter to import it.
Importing iTween (for users with PlayMaker 1.9 or later)
First, import iTween in the Asset.https://assetstore.unity.com/packages/tools/animation/itween-84
data:image/s3,"s3://crabby-images/a4ad0/a4ad0756a073dafc0d3f05af4f152efd3da1eeef" alt="スクリーンショット 2018-08-28 18.09.46 - STYLY"
iTween import screen
Click on “Add to My Assets” and you will be prompted to enter your Unity account information and sign in with your email address and password.
data:image/s3,"s3://crabby-images/e8359/e8359a76a938bc441f11de35b45c1898232be034" alt="スクリーンショット 2018-08-28 18.12.27 - STYLY"
sign-in screen
Check out Unity’s Asset Store. Make sure that iTween is installed from “My Assets” under “Asset Store” and click “Import”.
data:image/s3,"s3://crabby-images/60a35/60a357ce08fed97fd06152aba973d12ee2a764ec" alt="スクリーンショット 2018-08-28 18.21.09 - STYLY"
Asset Store
Next, go to “PlayMaker” in the menu bar and select “Welcome Screen”.
data:image/s3,"s3://crabby-images/d378c/d378c6463eb05cf2334ad2dd78cc6c80b7c2448f" alt="スクリーンショット 2018-08-28 18.26.23 - STYLY"
Welcome Screen
Next, click on “Add-Ons”.
data:image/s3,"s3://crabby-images/cfd0a/cfd0a535bcba3c95021ab5a511714e66767ee4e8" alt="スクリーンショット 2018-08-28 18.29.27 - STYLY"
Add-On selection screen
Click on “Import iTween Support” at the bottom and select “Yes” once an alert is displayed to start importing.
data:image/s3,"s3://crabby-images/c01f8/c01f802d6112614ac25a23e54bf816c169763699" alt="スクリーンショット 2018-08-28 18.31.12 - STYLY"
iTween import screen
Check Assets in the Project window. iTween should be in the PlayMaker folder.
data:image/s3,"s3://crabby-images/109a5/109a583ff505b0959cab3e47d7018283b9ba2906" alt="スクリーンショット 2018-08-28 18.05.21 - STYLY"
iTween
Settings to support various headsets.
In this article, we will create an animation that moves the camera between two blocks, as shown below.
data:image/s3,"s3://crabby-images/ae23c/ae23c9960ae317d070aaa9bd89725c64382d2beb" alt="動くGIF-2 - STYLY"
Finished GIFs
Create two cubes in the Hierarchy window with Create and name them “block1” and “block2” respectively. The settings in the Inspector view of block1 and block2 should be as shown in the following image.
data:image/s3,"s3://crabby-images/db8ff/db8ffed2109f5b7df4c5eea8fc65ddae69d9a45a" alt="スクリーンショット 2019-09-27 15.44.40 - STYLY"
Configuration of block1 and block2
Next, in the Hierarchy window, right-click on CreateEmpty and name the object “CameraController”.
This CameraController is the object used to run the camera.
Create one more “Cube_target” in CreateEmpty. The setting of the Inspector view of Cube_target will be explained later with the purpose, so please skip it for now.
data:image/s3,"s3://crabby-images/ea161/ea161175354260d406e3ccfeeaf10b9c121ee7cd" alt="スクリーンショット 2018-08-28 22.34.20 - STYLY"
Hierarchy Window
With CameraController selected, click [PlayMaker] and [PlayMaker Editor] in the menu bar.
In PlayMaker, right-click on “Add State”.
data:image/s3,"s3://crabby-images/55615/55615e83f469df0f955a25a3d9bffcfe488c396e" alt="スクリーンショット 2018-08-28 18.56.32 - STYLY"
Add State Transition Screen
Add a variable in the Variables tab.
Set the name of the variable to “camera” and the type of the variable to “Game Object” and click “Add”.
data:image/s3,"s3://crabby-images/33db3/33db3390e8c10e0ac55b5dc3825b5c0df6e2aa36" alt="スクリーンショット 2018-08-28 20.56.23 - STYLY"
Add Variable Screen
Next, in the Events tab, enter “CHECK_CAMERA_NEXT” and add it with the Enter key.
data:image/s3,"s3://crabby-images/0b93b/0b93b2615d86478050f4798c2ce6323e346be2c1" alt="スクリーンショット 2018-08-28 20.59.26 - STYLY"
Add Event Screen
Once the event is created, select “Add Transitions” – CHECK_CAMERA_NEXT.
data:image/s3,"s3://crabby-images/1fc50/1fc50b5e715df8c69a7072983c545cb0127981d2" alt="スクリーンショット 2018-08-28 21.01.28 - STYLY"
transition addition screen
Similarly, FINISHED should be added under “Add Transitions”.
data:image/s3,"s3://crabby-images/90b4a/90b4a6b91460d928a12a19d714486ff230be402e" alt="スクリーンショット 2019-09-27 16.36.08 - STYLY"
Add FINISHED
Then rename State1 to “Check VIVE”.
Next, from the Action Browser on the Status tab, add two actions, “Find Game Object” and “Game Object Is Null”.
The settings for each action should be as shown in the image below.
data:image/s3,"s3://crabby-images/4ba0c/4ba0c70b580d91991d392e546fdbdc73f1687f50" alt="スクリーンショット 2019-09-27 18.00.28 - STYLY"
Setting the status of “Check VIVE”.
This completes the configuration of Check VIVE.
Check “VIVE” but with this setting, not only VIVE but also Meta Quest will work.
Next, create a new state, change the state name to “Check Studio” and add a “FINISHED” transition.
data:image/s3,"s3://crabby-images/a10de/a10de9eb6295921c3d665f74cb652d18311f20c9" alt="スクリーンショット 2019-09-27 21.38.07 - STYLY"
Change the state name
Add “Get Main Camera” from the Action Browser on the Status tab.
Store the camera in the Store Game Object.
data:image/s3,"s3://crabby-images/4ed2b/4ed2bbbdc6a042454e5caff24331bc543f181e0d" alt="スクリーンショット 2019-09-27 21.41.43 - STYLY"
Configuring Check Studio
Connect to Check WebEditor from “CHECK_CAMERA_NEXT” of Check VIVE with the arrow.
Now, if the headset is not detected, it will go to WebEditor.
The next step is to implement the animation that moves the camera.
Settings for moving the camera
Add a new “Move State” state.
Add an “iTween Move to” action on the Status tab.
This iTween Move to is the action to add the animation. Please configure the iTween Move to as follows.
data:image/s3,"s3://crabby-images/2612d/2612d0203787a2f94d1a1894a747936d52d9d250" alt="スクリーンショット 2018-08-28 22.22.23 - STYLY"
iTween Settings Screen
Here, we briefly explain the meaning and purpose of each of the iTween Move to settings, which are particularly important.
Game Object | The GameObject to add movement to. |
Transform Position | Move the GameObject. |
Time | Time for the animation to complete. |
Delay | Time to wait for the animation before starting. |
Speed | This can be used as the speed of the GameObject instead of the time specified in Speed Time. If you define a speed, the Time variable is ignored |
Ease Type | Easing curve trajectories applied to Ease Type animation. |
Loop Type | The type of loop to apply after the animation is complete. |
Move To Path | Whether to automatically generate a curve from the current position of the Move To Path GameObject to the beginning of the path. True by default. |
Look Ahead | To show how strictly Look Ahead Orient To Path is affected, what percentage (0 to 1) is shown on the path. |
Start Event | The event to be fired when the iTween is started. |
Finish Event | The event to be fired when the iTween is finished. |
Stop On Exit | When the current state is finished, stop the iTween. |
Loop Dont Finish | Set whether the looping iTween will send anexit event or not. |
So, in order to move the camera between the two blocks, we need to place the Cube target between the two blocks as seen from the main camera.
Let’s also set up the Inspector view of Cube_Target, while confirming the settings in the Inspector view of block1 and block mentioned above.
The author set it up like this.
data:image/s3,"s3://crabby-images/d0953/d0953d5b2d1cebca1e4c85da37f68f16cd488574" alt="スクリーンショット 2018-08-28 22.38.03 - STYLY"
Cube_target setting screen
Once the configuration is complete, connect the five states of Check with the arrows to “Move State”.
Let’s save it and run the Scene.
data:image/s3,"s3://crabby-images/ae23c/ae23c9960ae317d070aaa9bd89725c64382d2beb" alt="動くGIF-2 - STYLY"
Finished GIFs
You were able to move it so that it passed between the two blocks. You are now set up with PlayMaker.
Upload and place on STYLY
Download and import the UnityPlugin from STYLY’s Download site.
Refer to the download site for the initial settings of UnityPlugin. In order to upload the “Camera Controller” object to STYLY, it needs to be a Prefab. Please store block1, block2, and Cube_target in CameraController.
data:image/s3,"s3://crabby-images/7720a/7720a784e07592cdb9f73f48952e474ea77bb726" alt="スクリーンショット 2018-08-28 22.51.14 - STYLY"
Prefabrication screen
Create a Prefab in the Project view using Create→Prefab and insert the Camera Controller object in the Hierarchy window by dragging and dropping it there.
Right-click on Camera Controller Prefab→STYLY→Upload prefab or scene to STYLY.
After a while, the Upload Success pop-up will appear.
data:image/s3,"s3://crabby-images/14592/145928edabfb2e59f615d8ad3ed8cdaa6bd0207e" alt="スクリーンショット 2018-08-21 17.56.05 - STYLY"
Upload Success Screen
Open the STYLY Studio in your browser and open the 3D Model > My Models tab in your asset selection to see your uploaded assets.
data:image/s3,"s3://crabby-images/4a551/4a5512c47d01b97c3d60da6300b326e48b2256ad" alt="スクリーンショット 2018-08-29 0.57.10 - STYLY"
My Models
Click on it to place it in the Scene.
If you feel sick while wearing the headset, please take off the headset immediately and take a rest, because you will get VR sickness if you are not careful about moving the camera.
That’s the end of how to implement the camera moving animation in PlayMaker and upload it to STYLY.
Once you understand the flow of this article, you’ll be able to achieve It’s a Small World-like camerawork on your own, so give it a try.
Unity package for camera detection
The camera detection feature described above is shared with the Unity package. You can download it from the link.
https://drive.google.com/file/d/1FbmGCSooFsbrsfyedj9LZXlg0p8W4z1I/view
If you want to create a function to detect the camera, such as moving or rotating the camera, we will explain how to use it.
Open Unity and go to the menu bar, “Assets”, “Import Package”, “Custom Package” and wash the Unity package you just downloaded.
data:image/s3,"s3://crabby-images/e387b/e387b2a8e5d848ce35a54a0af566f913748ea2fc" alt="スクリーンショット 2019-09-27 20.58.26 - STYLY"
Importing Unity packages
You will see the contents of the Unity package (2 items), so make sure both items are checked before importing.
data:image/s3,"s3://crabby-images/d6239/d62394222ccb63cb625995a13789a709aec0020c" alt="スクリーンショット 2019-09-27 20.58.47 - STYLY"
Check the package contents
You’ll see the imported Unity package in the Project view, so open the “Move Template” scene.
data:image/s3,"s3://crabby-images/ad28c/ad28cfe15329460c9f39fd8c9109927204860a02" alt="スクリーンショット 2019-09-27 20.59.02 - STYLY"
Open a scene.
The “CameraCotroller” is supposed to have PlayMaker, but I haven’t imported PlaMaker into my Unity project yet, so I’m going to import PlayMaker and iTween.
Before importing PlayMaker, it is set to “Nothing Selected” and no objects are selected as shown in the image below.
data:image/s3,"s3://crabby-images/29e22/29e226c29064c2b2dc2e1067481dfdbf3afa128d" alt="スクリーンショット 2019-09-27 20.59.19 - STYLY"
Before importing PlayMaker
Follow the article above to import PlayMaker and iTween.
The procedure for importing is exactly the same.
data:image/s3,"s3://crabby-images/1aefd/1aefdaaf7ad8a9e873460b8f6f06b4aaa8c2eb63" alt="スクリーンショット 2019-09-27 21.01.31 - STYLY"
After importing PlayMaker
An object has been selected for the CameraController.
Right now the camera moves in a straight line, but if you edit Move State, you can change it to adjust the speed, rotate it, etc.
data:image/s3,"s3://crabby-images/8ca56/8ca5661952930de33de260d22e86dd3b7798f9ae" alt="スクリーンショット 2019-09-27 21.32.47 - STYLY"
finished product