data:image/s3,"s3://crabby-images/4bf4d/4bf4d4a8704ee901fc7455689f8118ac5dc4c5fb" alt="見出し画像"
Unityで画面遷移をしてみる
1. Unityで画面遷移をしてみる
Unityはゲームを効率よく開発するゲームエンジンの一つである。このツールを使用すると、ツール上でゲーム開発が可能である。
今回は、画面遷移をUnityを使用してやってみようと思う。
環境:Mac OS venetura
Unityのバージョン:2022.3.15f1
2. Unityで画面遷移を実現しよう
2.1 新規プロジェクトを作成する
まず、新規プロジェクトを作成する。Unity Hubを開き、「New Project」を押下する。
data:image/s3,"s3://crabby-images/5db65/5db659ae4ea7166f0e2ebc448b825231dcb6b8ba" alt=""
次に、プロジェクトを作成する。
・All Templateから3D Coreを選択し、「Create Project」を選択する。
・Create projectを選択する。
data:image/s3,"s3://crabby-images/c9f60/c9f6011fe96761dd2721d115793492144c2eb3a1" alt=""
2.2 シーンを作成する
遷移する画面のSceneを作成する。「File」から「New Scene」を選択し、新規のSceneを作成する。
data:image/s3,"s3://crabby-images/5b42b/5b42b5addee42b57028f8da9a3fcd145a772b86f" alt=""
「Basic (Build-in)」を選択し、「Create」を選択する。
data:image/s3,"s3://crabby-images/efd81/efd815d4cd558f6b546034e0982f5235f89a9a62" alt=""
作成すると、Hierarchyに「Untitiled」というSceneが作成できる。名称を変更し、わかりやすい名前にする。Ctrl + sで保存画面を開く。
data:image/s3,"s3://crabby-images/e3ad1/e3ad1d2d8bc5f4b1b5fca4ce03192963b6355fe4" alt=""
Save AsにNewSceneと入力し、新しいシーンを作成する。
data:image/s3,"s3://crabby-images/78c1a/78c1a4e971899a8b472d3f69796fe7b862dbabfc" alt=""
先ほどのシーンの名前が変更されていることを確認する。
data:image/s3,"s3://crabby-images/4efdc/4efdc20fbaf810f5ecef864202bbb60aff238fb2" alt=""
2.3 もう一つシーンを作成する
先ほどと同じ手順で、もう一つのシーンを作成する。筆者は、BaseSceneという名前で作成した。
ここまでの操作内容を確認する。
(1) 新規プロジェクトを作成
(2) NewSceneとBaseSceneの二つのシーンを作成した。
今回は、BaseSceneからNewSceneへ画面遷移することを目標とする。Assets/Scenesの中にあるシーンを確認する。
data:image/s3,"s3://crabby-images/0b9ef/0b9ef5e289913ebfbd933103f577f506651b6953" alt=""
2.4 シーンを登録する
次は、作成したSceneをUnityに登録する。「File」から「Build Settings」を選択する。
data:image/s3,"s3://crabby-images/ae511/ae511e3aa25334bffed20c71ca0dcd817a59e9e0" alt=""
Build Settingsを開き、先ほど作成したSceneを選択し、Build Settingsにドラッグアンドドロップする。
data:image/s3,"s3://crabby-images/0922c/0922cf156b0fa92f74397931113cdb702208ea71" alt=""
data:image/s3,"s3://crabby-images/8dd70/8dd70b93e07fcedb956a2bcb8c992d00ab97b9fd" alt=""
上記の通り、作成したSceneが登録できればOKである。
2.5 目印となるオブジェクトを配置する
このままの状態だと、同じ画面のため、画面を遷移しても切り替わりがわからない。そこで、オブジェクトを配置して目印をつける。
BaseSceneには、Cubeを配置する。Hierarchyの➕ボタンを選択し、から3D ObjectのCubeを選択する。
data:image/s3,"s3://crabby-images/47c22/47c22bd0f2d6a1338129a4f4d28feeabb2b17fe9" alt=""
Cubeを選択すると、下記のようにCubeが配置されていることがわかる。
data:image/s3,"s3://crabby-images/18e83/18e83d7f07fe752027cf80ed063dadb49c1ae11f" alt=""
NewSceneには、Sphereを配置する。Hierarchyの➕ボタンを選択し、3DObjectからSphereを選択する。
data:image/s3,"s3://crabby-images/de069/de069d62f8226563f2095686a31f2e4083db3523" alt=""
選択すると、Sphereが作成される。
data:image/s3,"s3://crabby-images/0a89d/0a89d0dd8625febfbac31b816f21b10c956cd084" alt=""
2.6 C#スクリプトを作成する
画面遷移の制御は、C#のスクリプトから行う。Projectビューで右クリックを押し、CreateからC# Scriptを選択する。
data:image/s3,"s3://crabby-images/94138/9413807ea9212b075c0a0ac2390e17dc909c72fa" alt=""
ファイル名は、SceneChangeとした。
data:image/s3,"s3://crabby-images/189b8/189b8f50bcfd6b66311ebe730dd1e357e9791c93" alt=""
ファイルをダブルクリックすると、エディタが立ち上がる。初期状態のコードは以下のようになっている。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class SceneChange : MonoBehaviour
{
// Start is called before the first frame update
void Start()
{
}
// Update is called once per frame
void Update()
{
}
}
今回、画面遷移は、Start()にinvokeメソッドを追加して実現する。Unityにおいて、invokeとは、指定した時間遅延の後に実行するコードを指定するものである。今回は、invokeで3秒後に画面遷移を行うと記述する。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
//Usingを追加
using UnityEngine.SceneManagement;
public class SceneChange : MonoBehaviour
{
// Start is called before the first frame update
void Start()
{
//3s後に画面遷移する
Invoke("ChangeNewScene", 3.0f);
}
// Update is called once per frame
void Update()
{
}
void ChangeNewScene()
{
//NewSceneを呼び出す
SceneManager.LoadScene("NewScene");
}
}
上記は、画面遷移のプログラムの記述例である。下記に処理の内容を振り返る。
(1) ゲームを開始するとStartメソッドを実行する
(2) Invokeを使用してゲームを開始して3秒後にChangeNewSceneメソッドを実行する。
(3) ChangeNewSceneメソッドを実行し、NewSceneをロードする。
2.7 Scriptをアタッチする
作成したC#のスクリプトをシーンに読み込んで実行する。BaseSceneを開き、Game Objectを作成する。Unityでは、GameObjectにスクリプトなどを割り当てて実行することができる。
Hierarchyから➕ボタンを押して、「Create Empty」を選択する。
data:image/s3,"s3://crabby-images/5c984/5c984633110458df2020fe566006cc8a155eafcd" alt=""
選択すると、GameObjectが作成される。
data:image/s3,"s3://crabby-images/9d914/9d914abd7cf18088cc6a9e304c48f6e0c213a009" alt=""
GameObjectを選択した状態で、Inspectorビューを確認すると、「Add Component」と書かれているボタンがある。そこを選択し、先ほど作成したScene Changeを選択する。検索欄に作成した名称を入れると、自動的に現れる。
data:image/s3,"s3://crabby-images/66097/66097c9057f858a440760e0a62c4439bc5653af0" alt=""
選択すると、InspectorビューにScene Changeのスクリプトが登録される。
data:image/s3,"s3://crabby-images/81911/819112d618d2ea86ec41e3b239e9d227418fd73d" alt=""
2.8 実行して確かめよう
準備は完了したので、実行して確かめてみましょう。BaseSceneを読み込んだ状態で、実行ボタンを押してみましょう。
data:image/s3,"s3://crabby-images/f3135/f31350fd6e962479121d9b92fcf6dfb96c69a5f7" alt=""
実行すると、CubeのオブジェクトからSphereのオブジェクトに画面が遷移することがわかります。
3. 終わりに
今回は、Unityでの簡単な画面遷移のやり方を手順立ててまとめた。より深く学ぶことで、例えば、ゲームタイトルからゲーム画面へ遷移するといったことも可能である。興味がある人は試してみてほしい。