Unity UIに用意されているボタンの使い方です。とりあえず作成して、クリックした時に何かイベントを起こすところまでやります。
ボタンの作成
data:image/s3,"s3://crabby-images/90aa8/90aa80230f5f179865b2d085c9206c32ff55acec" alt="unity ボタン button1"
ボタンを作るには、ヒエラルキーの+(Create)→UI→Buttonをクリックします。
data:image/s3,"s3://crabby-images/5b493/5b49394c4327b6ead08eb49dfef6cf591197f0ae" alt="unity ボタン button2"
ボタンが画面上に配置されました。
data:image/s3,"s3://crabby-images/5b9c8/5b9c816546a2b1bcfd3858fa031f77795157cbe7" alt="unity ボタン button3"
UI要素は必ずCanvasとセットになるので、もしまだ作っていなければCanvasも一緒に作られているはずです。
もし後で書くスクリプトも試してみたい場合、UI→テキストもいっしょに作成して、画面内に配置しておいてください。
キャンバスがデカ過ぎる件についてはこちら参照。
もし後で書くスクリプトも試してみたい場合、UI→テキストもいっしょに作成して、画面内に配置しておいてください。
キャンバスがデカ過ぎる件についてはこちら参照。
data:image/s3,"s3://crabby-images/9dcb1/9dcb113709664e03ee5c7845df7ca12a866b2990" alt="unity ボタン button4"
Buttonの子オブジェクトにさらにTextがあり、
data:image/s3,"s3://crabby-images/c5718/c5718ddbff203223595fe0ddaa7cd6cbce8a3e07" alt="unity ボタン button5"
Textのヒエラルキーをいじることで、表示する文字やフォント、色などを変更できます。
data:image/s3,"s3://crabby-images/fd2fa/fd2fa0761e091b842c4f144ddc83f7ad0969e928" alt="unity ボタン button13"
メインのテキストと差別化するために、ちょっと名前を変えておきます。
ボタンを押すとイベント
コライダーの追加
data:image/s3,"s3://crabby-images/f472b/f472ba77bb65de60ff3aa8e9b90e6718c706957a" alt="unity ボタン button6"
先に当たり判定を作ります。
ボタンのインスペクター最下部でコンポーネントを追加→
ボタンのインスペクター最下部でコンポーネントを追加→
data:image/s3,"s3://crabby-images/e250f/e250f241d7357ab6a3261bdbe697aaedc6c868dc" alt="unity ボタン button7"
2D物理→
data:image/s3,"s3://crabby-images/6b43f/6b43f94786284ed4d0b7219129eb4d408318e86e" alt="unity ボタン button8"
2Dボックスコライダーをクリックします。
イベントトリガーの追加
UIオブジェクトはイベントトリガーという機能を使うことで何かした時にイベントを起こすことができ、この記事ではテキストをクリックするとイベントが起きるようにしています。
なのでこれの引き写しになるんですが、
なのでこれの引き写しになるんですが、
data:image/s3,"s3://crabby-images/51a41/51a41147e08c5874fec2111c1b78912d9a0adeb4" alt="numberbox15"
ボタンのインスペクターでコンポーネントの追加→イベント→
data:image/s3,"s3://crabby-images/02e0d/02e0d6fb954c8d6302e10917f57677d313c55e58" alt="numberbox16"
イベントトリガーをクリックします。
data:image/s3,"s3://crabby-images/021c0/021c06af29ff21a7f0efb4a4251f977b8bdf41dd" alt="numberbox17"
イベントトリガーコンポーネントが追加されたら、新しいイベントタイプを追加→Pointer Clickをクリックします。
data:image/s3,"s3://crabby-images/98a51/98a519c38be451374966f27af399fe56d86e3b36" alt="numberbox18"
+を押すとオブジェクトが「なし」となっているので、
data:image/s3,"s3://crabby-images/b0a89/b0a89f4406d920bd90e790b760a58139c35b4f52" alt="unity ボタン button9"
自分自身(Button)をヒエラルキーからドラッグしてきてセットします。
スクリプトの設置
//Unity C#
using UnityEngine.UI;
//好きな名前で
public void ButtonClick()
{
GameObject text = GameObject.Find("Text");
text.GetComponent().text = "Changed!";
}
スクリプトを作成し、public voidの後に好きな名前をつけてメソッドを作り、その中に左記のコードを記述します。
やってることは「Text」という名前のオブジェクトを見付けて、そのテキストを変更するという処理です。これのためにさっきボタンのテキストの名前を変更しました。
やってることは「Text」という名前のオブジェクトを見付けて、そのテキストを変更するという処理です。これのためにさっきボタンのテキストの名前を変更しました。
data:image/s3,"s3://crabby-images/1b61d/1b61d7baade7f381b0dffd8fd0c2ca4a279b0830" alt="unity ボタン button10"
スクリプトをボタンにアタッチし、
data:image/s3,"s3://crabby-images/c984b/c984b0599344781eb90bd580f77e9f0da1f621c9" alt="unity ボタン button11"
ボタンのイベントトリガーのNo Functionをクリック→作ったクラス名→作ったメソッド名をクリックします。これで大体終わり。
環境準備
data:image/s3,"s3://crabby-images/6d29b/6d29b5487d0174e886b324f897d2eb249395e332" alt="onclk16"
まだ作ってなければ、ヒエラルキーの+(Create)→UI→Event Systemを追加します。
data:image/s3,"s3://crabby-images/1dd91/1dd915d35dafdbb7b26051b204dc3882c00e64e1" alt="unity ボタン button12"
それからMain Cameraをクリックし、
data:image/s3,"s3://crabby-images/bf8e2/bf8e290fbb54c22ffbc17656afe331e20158183f" alt="onclk18"
インスペクターでコンポーネントの追加→イベント→
data:image/s3,"s3://crabby-images/0d3ed/0d3ed9ec47c3bdc9c016d32670f5f0a406c65e52" alt="onclk19"
2D物理レイキャスターをクリックします。
完成品
data:image/s3,"s3://crabby-images/08938/08938fb066260d61830ea64c10a63fc31b3fa5ff" alt="click changed"
以上の手順を踏むと、「クリックするとテキストを変更するボタン」が作成できます。
data:image/s3,"s3://crabby-images/50184/50184014560c3429c7fe185575dabf459e3910fa" alt=""
やりたいことから逆引きするUNITYの使い方まとめ
Unityをやりたいことから学習していけるよう、機能・用途別にまとめたページです。C#の命令別の逆引きは現時点で作っていません。2019の時期に書き始めているので、それより前のバージョンについては言及しません。
コメント