今回はUnityの2Dゲームで簡単な「メニュー画面」と「シーンの移動」をシンプルな仕組みで実装していきます。
はじめに
Unityのバージョンは2021.3.14f1です。
下記記事で、シーン移動の超基本を書いてますが、追加みたいな感じです。
今回やる事
「シンプルなメニュー画面の作成」と「シーンの移動」を実装していきます。
実装開始
では、実際に作成していきます。
メニュー画面の作成
「Create」→「Scene」で新規シーンを2つ作成。名前は「Menu」と「Game」にしておきます。
data:image/s3,"s3://crabby-images/3c296/3c296bec67c0d09d7e4b15e94bd8b8626c1d5571" alt=""
ヒエラルキーメニューで、UIから「Button-TextMeshPro」を追加。TextMeshProはテキストを拡張した感じのものですね。
data:image/s3,"s3://crabby-images/acce2/acce20afd247858bc039053f6a8cb35a5dd034c7" alt=""
Buttonを好きな位置に変更します。
data:image/s3,"s3://crabby-images/c76ba/c76ba995dacfe41a08e2cbfd719fc1297bfa09da" alt=""
ボタンテキストの中身を変更、サイズやグラデーションを変更します。
data:image/s3,"s3://crabby-images/68e70/68e709c0c846c175d0a0fbdce4e45e3ac1a9f8b4" alt=""
カラーグラデーションの作成
カラーグラデーションはベースを作成しておくと、使いまわしが出来るので便利です。
プロジェクトで右クリック「Create」→「TextMeshPro」→「ColorGradient」を選択。
data:image/s3,"s3://crabby-images/bde12/bde12e2c863c44de77679063b4c2425df10c9f48" alt=""
色をInspectorでセットします。
data:image/s3,"s3://crabby-images/19ac5/19ac53a60e3d0fc2589d69fb5a4fc8705b288742" alt=""
作成したのを「Color Preset」にセットすると反映されます。
data:image/s3,"s3://crabby-images/330e5/330e53e4c7c143643f9cbeb0391efbef3a73644c" alt=""
終了ボタン
スタートボタンをコピーして「終了ボタン」も作成。位置をずらして、サイズや色を適当に変更しておきます。
data:image/s3,"s3://crabby-images/58317/583176c9b41609725d284c81aa00975306412fce" alt=""
これで超簡単なメニューが完成。実際は設定ボタンとかも必要なのであくまでも最低限ですね。
画面遷移スクリプトを作成
「ゲーム画面へ遷移」、「ゲームを終了」するスクリプトを作成します。
新規スクリプトで「Menu」と言う名前で作成、中身は下記に変更。指定したシーンを呼び出しているだけですね。
using UnityEngine; using UnityEngine.SceneManagement; public class Menu : MonoBehaviour { public void StartGame() { SceneManager.LoadScene("Game"); } public void EndGame() { Application.Quit(); } }
MainCameraにスクリプトをアタッチします。
data:image/s3,"s3://crabby-images/cd266/cd266fedeff035c166744e48f824ed87d2663c06" alt=""
ボタンクリック時の動作にそれぞれのメソッド(関数)を呼ぶように追加。
data:image/s3,"s3://crabby-images/ee330/ee3307f03f6ccf9bf4b2f28f25fa245f1bdb3971" alt=""
「File」→「BuildSettings」を選択。
data:image/s3,"s3://crabby-images/80629/80629a1745e22d476873ece45312f0d85b2a409f" alt=""
移動先のGameシーンを追加します。
data:image/s3,"s3://crabby-images/ed365/ed365fedcd2c0cf7a3476f3a39db8dbe5689db02" alt=""
これで実行して、ゲーム画面に移動すればOK。
別の方法
メニューから「ゲームスタート」を選ぶ場合は良いですが、メニューからの行き先が複数ある場合、下記の様にパラメータでセットする方法も(複数ステージなど)。
using UnityEngine; using UnityEngine.SceneManagement; public class Menu : MonoBehaviour { public void StartGame(int Sceneindex) { SceneManager.LoadScene(Sceneindex); } public void EndGame() { Application.Quit(); } }
パラメータの数字はビルド設定の数字を渡せばOK。
data:image/s3,"s3://crabby-images/cc9b6/cc9b6104fc378792ddc9ca04d273efeda790b64c" alt=""
パラメータを文字列(string)にして、シーン名称を渡してもOK。