この記事ではUnityのPlaymakerを使用してStylyのVR空間でスローモーションを作る方法を紹介します。 マウスのボタンとHTC Viveのコントローラでの操作になります。
data:image/s3,"s3://crabby-images/574f7/574f79e77a1ff3ef36bbe6177be86207896d22ff" alt="Slowmotion_fin - STYLY 完成データのプレー動画"
完成データのプレー動画
完成のイメージはこのようになります。 トリガーを押しているときだけ時間がスローモーションになります。
サンプル
STYLY GALLERYからサンプル空間を体験できます。
記事で紹介しているUnityプロジェクトのダウンロードはこちらからできます。 Slowmotion_Sample プロジェクトデータには各種プラグインは入っていませんので使用する際はご自身でインストールしてからご利用ください。 Playmaker SteamVR Plugin
PlaymakerとSteam VR Plugin
アセットストアからそれぞれダウンロードしてUnityで使用できる状態にします。
data:image/s3,"s3://crabby-images/f19e0/f19e0235b275a98db682c4eb5f2ea0b1f5a626b5" alt="SM_01 - STYLY"
アセットストアにあるPlaymaker
Playmakerは有料アセットです。 Playmaker
data:image/s3,"s3://crabby-images/8c51d/8c51d4002c96955e8ba2039f55fab060bedcaf23" alt="SM_03 - STYLY"
Steam VR プラグイン
Steam VRは無料で使用できます。 SteamVR Plugin
Bulletの作成
スローモーションを感じるための動くアセットとして弾丸を作ります。
data:image/s3,"s3://crabby-images/ed522/ed522e7690cfd137d09f0f1aba09fc07c829eff2" alt="SM_04 - STYLY"
弾となるSphere
Sphereの名前を”Bullet”としてスケールをそれぞれ0.1にしました。 Bulletを選んだ状態でPlaymaker Editorを開きます。
data:image/s3,"s3://crabby-images/82be5/82be5f7c5af0c4a0b062265dbf4dccefb7f17182" alt="SM_05 - STYLY"
FSMの追加
右クリックから”Add FSM”を選びます。
data:image/s3,"s3://crabby-images/13e16/13e16ead9733a9d7417463bcf676c82bd6b9f68a" alt="SM_07 - STYLY"
FSMの名前を変更
新しくStateが作られました。 FSMの名前をBulletspeedに変更しました。 続いてBulletへのActionを追加していきます
data:image/s3,"s3://crabby-images/e1f7e/e1f7e2a603f850fe23f37e6ee5ef7b96ab1e0970" alt="SM_09 - STYLY"
Actionを追加
Action Browserをクリックします。
data:image/s3,"s3://crabby-images/4be7f/4be7f731fc1ad823adcc22731f3e2f6f44566490" alt="SM_10 - STYLY"
Action Browserから選択
BrowserからTransformのTranslateを選択してAdd Action To Stateをクリックします。 これでActionが追加されました。 弾丸のスピードを設定します。
data:image/s3,"s3://crabby-images/d0ed3/d0ed3448e03c016fddd5b79fbef589bac39a1596" alt="SM_11 - STYLY"
Translateの設定
ここではZに7を設定しました。
data:image/s3,"s3://crabby-images/1a7ff/1a7ff39b27910c9bdb0ca8ddefcbb89e20df031e" alt="SM_12 - STYLY"
Prefabにする
これをPrefabにします。
弾丸が出る場所を作る
Bulletspawnという名前のCubeを作りMesh Rendererのチェックを外します。
data:image/s3,"s3://crabby-images/68464/6846473acab5caf0292cd44e4ed85bf098170b28" alt="SM_13 - STYLY"
Bulletspawnの設定
BulletspwanにもPlaymakerでFSMを作成します。
data:image/s3,"s3://crabby-images/dbdf4/dbdf497af8f1745c731183f8533044aa52e3d95c" alt="SM_14 - STYLY"
BulletspawnのAction Browser
Add ActionからFind Game Objectを追加します。
data:image/s3,"s3://crabby-images/dea73/dea73e0daa5dfa770ece47f47f045de344203e53" alt="SM_15 - STYLY"
MainCameraをFind
With TagからMainCameraを選択してMainCameraのタグを持ったオブジェクトをFindします。
data:image/s3,"s3://crabby-images/882f3/882f373a7d9fad8bd49928b781342a0d81d697d4" alt="SM_16 - STYLY"
新規に変数を作る
New Variableから新規の変数を作りそこに格納します。
data:image/s3,"s3://crabby-images/12617/126173d2199b4f73a455149f61dffd4f425ae0b9" alt="SM_17 - STYLY"
変数を作って格納
ここではmainCameraという変数名にしました。 Add Stateをして新たにStateを作ります。
data:image/s3,"s3://crabby-images/65149/65149ac68c0a564b5d483ea1bf6492536b89790d" alt="SM_19 - STYLY"
State2ができた
TransformからLook Atを追加します。
data:image/s3,"s3://crabby-images/978a6/978a61bbb7db750dd05062d45dce6bbdf5a7505b" alt="SM_20 - STYLY"
Look Atを追加
data:image/s3,"s3://crabby-images/1f163/1f16314eb6d62a1f9d068586ca005db1770022fa" alt="SM_21 - STYLY"
Target Objectを選ぶ
data:image/s3,"s3://crabby-images/ab8f0/ab8f0109c159eb384fa5e48fee201565ba6df626" alt="SM_22 - STYLY"
TargetをmainCameraに
Look Atのターゲットを先ほど作ったMainCameraにしてKeep Verticalのチェックを外します。 State1のTransitionをFINISHEDにします。
data:image/s3,"s3://crabby-images/34224/342240faef968546e3815cea50d01b7ec4b39e58" alt="SM_23 - STYLY"
TransitionをFINISHEDに
そこからState2につないでいきます。
data:image/s3,"s3://crabby-images/2251a/2251a924e89e70c1af161458e73d8f24ca0b0628" alt="SM_24 - STYLY"
State2につなぐ
次にState3を作り、Create ObjectのActionを追加します。
data:image/s3,"s3://crabby-images/5cc32/5cc324fe5332638953c0792f58c8e50cc8a5cfef" alt="SM_25 - STYLY"
Create ObjectのActionを追加
Createするオブジェクトを指定します。
data:image/s3,"s3://crabby-images/b7601/b760156e7b5a9fc667aa010f31f90b6c627ece58" alt="SM_26 - STYLY"
BulletとBulletspawnの追加
Game Objectには”Bullet”をSpawn Pointには”Bulletspawn”を指定します。
data:image/s3,"s3://crabby-images/1fce1/1fce11f3651158b7b9a5ad9df86ca80c3cdcab3f" alt="SM_27 - STYLY"
Send EventからFINISHED
Send EventのActionを追加してTransitionをFINISHEDにします。 State2からState3につなぎます。
data:image/s3,"s3://crabby-images/008eb/008ebe1647ea971d81345b8e3d866d6592ae31ce" alt="SM_28 - STYLY"
State3につなぐ
繰り返しになるようにState3からState2にもつなぎます。
data:image/s3,"s3://crabby-images/bce9d/bce9d8559229f14578f3e82424db64d6cece993a" alt="SM_29 - STYLY"
State3からState2につなぐ
1秒ごとに発射されるようにWaitを追加します。
data:image/s3,"s3://crabby-images/93100/931003f0c90053850ffdb75b5de18969e3e105fa" alt="SM_30 - STYLY"
Waitの追加
時間は1秒にしました。 Finish EventはFINISHEDにします。 このままだと弾丸がずっと飛び続けてしまうので適当なところでDestroyします。
data:image/s3,"s3://crabby-images/fa7dd/fa7dd43de20afebd0b67641d03ff54ea206838c7" alt="SM_31 - STYLY"
DestroyとDelayの時間
Destroy ObjectでBulletを指定してDelayする時間を4秒にしました。 この記事ではUnityのPlaymakerを使って弾丸を自動生成する方法を紹介しました。 次の記事ではこの弾丸の動きをスローモーションにする方法を紹介します。 続き
UnityからSTYLYにアセットをアップロードする方法