はじめに
data:image/s3,"s3://crabby-images/e45d5/e45d50d508b8d84a708cf4134a17eabfe61e863f" alt="みなため"
どうも! みなため(@MinatameT)です。
この記事では、何か(例えば球体)が入るような四角いカゴを作る方法を解説します。カゴを作った後、カゴに重力を与えます。
座標は細かく指定していますが、完璧にマネする必要はありません。あくまで、ひとつの例です。
動作環境
・Windows 7
・Unity 2019
動画で理解する
動画の前に、カゴを置くための地面(Plane)と、メインカメラの座標の設定をしておきます。
data:image/s3,"s3://crabby-images/78671/786717503471d473c6b389791aa790e2b15c10a6" alt="地面の作成"
ヒエラルキーで右クリックし、「3D Object」>「Plane」を作成します。これで地面の作成ができました。
data:image/s3,"s3://crabby-images/45b28/45b280837adad26893927039a19c5aa7ec6b8459" alt="メインカメラの位置設定"
カメラの位置を変更するために、MainCameraのPositionのXを12に、Yを2に、Zを0に変更します。さらに、Field of Viewを30に変更します。
これはあくまで一例ですので、各自で微調整をしていただいても構いません。
さて、これで下準備は完了です。動画では謎の黒い球体が浮かんでいますが、これは無視してください。また、地面の色を変えていますが、これも無視してください。なお、動画の音声は出ません。
左クリックのエフェクトは水色で、右クリックのエフェクトはオレンジ色です。
画像で理解する
下準備
data:image/s3,"s3://crabby-images/78671/786717503471d473c6b389791aa790e2b15c10a6" alt="地面の作成"
ヒエラルキーで右クリックし、「3D Object」>「Plane」を作成します。
※Planeの大きさや色は任意で変更してください。例えば、この動画ではScaleのXが10、Yが1、Zが10になっています。
data:image/s3,"s3://crabby-images/45b28/45b280837adad26893927039a19c5aa7ec6b8459" alt="メインカメラの位置設定"
MainCameraのPositionのXを12に、Yを2に、Zを0に変更します。また、MainCameraのField of Viewを30に変更します。
カゴの作成と設定
data:image/s3,"s3://crabby-images/1ece0/1ece05e98ca7a2efd6dc96cbc94dc5b94adbfa26" alt="親オブジェクトの作成"
ヒエラルキーで右クリックし、「Create Empty」を選択します。
data:image/s3,"s3://crabby-images/dd71e/dd71e8caf7fb808000608edfdd8e2f985645f8a6" alt="Basketに名称変更する"
GameObjectの名前を「Basket」に変更します。ちなみに、バスケットはカゴという意味です。
data:image/s3,"s3://crabby-images/f18bf/f18bfcb7661add0c7460592317aea44f05bbf560" alt="Basketのポジションを変更する"
BasketのPositionのXを12、Yを0.5、Zを10に変更します。
data:image/s3,"s3://crabby-images/5b092/5b092fe412c018354a3a90ab36555f07859c221d" alt="Cubeの作成"
Basketを右クリックし、「3D Object」>「Cube」を作成します。これで、CubeがBasketの子オブジェクトになります。
data:image/s3,"s3://crabby-images/22d26/22d262c33b747c0c3f845f46a70344fd9bc72ab3" alt="CubeのTransformの設定"
CubeのPositionのXを0、Yを-0.45、Zを0に変更します。さらに、CubeのScaleのXを2、Yを0.1、Zを2に変更します。
data:image/s3,"s3://crabby-images/44e72/44e72e6307dd8798810f839296851dd58ab69064" alt="Cube (1)のTransformの設定"
先ほどと同様に、Basketを右クリックし、「3D Object」>「Cube」を作成します。
Cube (1)のPositionのXを-1、Yを0、Zを0に変更します。さらに、Cube (1)のScaleのXを0.1、Yを1、Zを2に変更します。
data:image/s3,"s3://crabby-images/15626/156266c1fb595548455dda675b5df5d0dda7569f" alt="Cube (2)のTransformの設定"
今まで同様に、Basketを右クリックし、「3D Object」>「Cube」を作成します。
Cube (2)のPositionのXを1、Yを0、Zを0に変更します。さらに、Cube (2)のScaleのXを0.1、Yを1、Zを2に変更します。
data:image/s3,"s3://crabby-images/77e75/77e75aa3532220ef2e9f92bcf30e241b1c9eccf3" alt="Cube (3)のTransformの設定"
今まで同様に、Basketを右クリックし、「3D Object」>「Cube」を作成します。
Cube (3)のPositionのXを0、Yを0、Zを0.95に変更します。さらに、Cube (3)のScaleのXを2、Yを1、Zを0.1に変更します。
data:image/s3,"s3://crabby-images/896ee/896ee315efcc4ffae74c02f20b2c7d536f8e5485" alt="Cube (4)のTransformの設定"
今まで同様に、Basketを右クリックし、「3D Object」>「Cube」を作成します。
Cube (4)のPositionのXを0、Yを0、Zを-0.95に変更します。さらに、Cube (4)のScaleのXを2、Yを1、Zを0.1に変更します。
data:image/s3,"s3://crabby-images/a83a2/a83a27ddac91ec8d95ceb3f1173bb3b50ba075b8" alt="BasketにAdd Component1"
data:image/s3,"s3://crabby-images/13454/134542033732136cab346ba23511828b2e8d0cf9" alt="BasketにAdd Component2"
Basketに、インスペクターから「Add Component」>「Physics」>「Rigidbody」を設定します。
※親オブジェクトである「Basket」に設定しないと、子オブジェクト同士(Cube同士)がくっつかずにバラバラになってしまうので、注意してください。
data:image/s3,"s3://crabby-images/ea370/ea370af50e0f5ed888d51575988d8c5a02cc9cf1" alt="BasketのRigidbody設定"
BasketのInterpolateを「Interpolate」に、Collision Detectionを「Continous Dynamic」に変更します。
テストプレイ(動作確認)
data:image/s3,"s3://crabby-images/332c0/332c08e3a0a54474608861ad9841d260d0fac4a4" alt="プレイボタンをクリック"
プレイボタンを押して、動作確認します。
data:image/s3,"s3://crabby-images/44a05/44a0556a23672672f7559239914fcb0ff3cc3221" alt="動作確認1"
白いカゴができていることがわかりました!
data:image/s3,"s3://crabby-images/1f96f/1f96f71d79fbe5b26bb95c39db8cdf8f030b0504" alt="動作確認2"
すると、黒い球体がカゴに落ちてきました。確かに、球体が入るようなカゴになっています!
ちなみに、この黒い球体の作り方は以下の記事で解説しています。
data:image/s3,"s3://crabby-images/1c132/1c1324207696891be34b942ae41005f44baf3ffb" alt="キャラクター"
これで完成です。皆さん、お疲れ様でした。