【画像付き】unityでButtonを使ってScene遷移する方法【超簡単】
data:image/s3,"s3://crabby-images/527d1/527d13c4897e1c5830e98bf2bf9f1dc77fb00fd2" alt=""
data:image/s3,"s3://crabby-images/efbef/efbef1475d9e922446f2ee92deb68ff9bc7e7d6c" alt="シロウ"
こんにちは、シロウです。
今回はタイトル通り、下記のような『Buttonを使ってScene(シーン)遷移する方法』を画像付きでわかりやすく解説していきます。
data:image/s3,"s3://crabby-images/ed6fe/ed6fe2b04b19f6e78126aaedd1b1e383fc7fbf8f" alt=""
それでは早速ですが、みていきましょう!
Buttonを使ったScene遷移の方法をわかりやすく解説!
まずはSceneを二つ用意しましょう。
今回は『A』と『B』のSceneを用意しました。
シーンを二つ用意したらそれらのシーンを登録していきます。
まずは【File】をクリックして【Build Settings】を選択してください。
data:image/s3,"s3://crabby-images/eddcf/eddcf05220e127e0fa666bd05a1e1b3f8ce048b3" alt=""
そして次に先ほど作成したScene二つをドラッグ&ドロップで追加します。(下記GIFの画質がわるくてすいませんm(_ _)m)
data:image/s3,"s3://crabby-images/4a1f2/4a1f2bbda875718c5beda8dcfb7e76f7126d9d1c" alt=""
次にButtonを作成します。
Hierarchie(ヒエラルキー)上で【Create】>【UI】>【Button】の順にクリックしてください。
Buttonを追加すると【Canvas】と【Event System】も自動で追加されます。
*削除しないように注意。
data:image/s3,"s3://crabby-images/12414/12414a90d6073aec24b9c6f1eb3760edaa78a21c" alt=""
作業をやりやすくするためにヒエラルキー上で【Canvas】を選択して、Inspector上の【Screen Space – Overlay】>【Screen Space – Camera】の順にクリック。
data:image/s3,"s3://crabby-images/9825f/9825f8d45ffbd2ba5c6b3d3de4be3d391e489d08" alt=""
そして【Render Camera】に【Main Camera】をアタッチしてください。
これで見やすくなりましたね。
data:image/s3,"s3://crabby-images/362a1/362a1d466108c5c6d216650bad7dd560687dcbd7" alt=""
次にスクリプトにScene遷移させるためのコードを書いていきます。
Projectウインドウ上で【Create】>【C# Script】をクリック。
data:image/s3,"s3://crabby-images/fc110/fc110051cabb1ae350715cf64fd33af2518e5e30" alt=""
スクリプト名は『SceneController』としておきましょう。(大抵の人はシーン遷移のスクリプトはこの名前にしているっぽいです。)
data:image/s3,"s3://crabby-images/eb5e2/eb5e20b4f24957fef58109d1b230e1baa4734e9c" alt=""
先ほど作成したスクリプトをダブルクリックして、エディタ(コードを書く場所)を開いて、そこに下記のスクリプトを記述します。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI; //ボタンを使用するのでUI
using UnityEngine.SceneManagement;//SceneManagerを使用ためSceneManagementを追加
public class SceneController : MonoBehaviour
{
// ボタンをクリックするとScene『B』に移動
public void ButtonClick()
{
SceneManager.LoadScene("B");
}
}
SceneManager.LoadScene(“B”);で遷移先を決定しています。
(””)の中に遷移したいScene名を指定することで、指定されたSceneに遷移できるようになります。
『ButtonClick』は自分がわかれば他の名前でもOKです。
次に今コードを記述した『SceneController』スクリプトをアタッチするための空のオブジェクトを作成します。
Hierarchy上で【Create】>【Create Empty】の順にクリックして、空のオブジェクトを作成してください。(名前は自分がわかりやすいように付けてください。今回は『』)
data:image/s3,"s3://crabby-images/ec067/ec067f0c36b8fb6cefa5dc7a47127d24c97ae673" alt=""
空のオブジェクトが作成できたら、『SceneController』スクリプトをドラッグ&ドロップして空のオブジェクトにアタッチしてください。
data:image/s3,"s3://crabby-images/a5cdf/a5cdf0f8b13964a6d55d8dd0363e554a021f8dcc" alt=""
hierarchy上の【Button】を選択 > Inspector上の【On Click】の『+』をクリック > さっき作成したオブジェクトをアタッチ >【SceneController】から【ButtonClicke()】を選択
data:image/s3,"s3://crabby-images/1a45d/1a45dcbcbc076e9be7e637d78ceb05745ceef2a1" alt=""
これで完成です。
うん、慣れれば3分ぐらいでできちゃう簡単作業でした٩( ‘ω’ )و