data:image/s3,"s3://crabby-images/d8b22/d8b223017ada10a18af7dd63a5d51ed090bc1e43" alt="赤かぶくん"
何か簡単なゲームを作りたい。
ボタン連打ゲームはどうやって作るの?
data:image/s3,"s3://crabby-images/9e049/9e049cbf042c6e6a54d2a28eb63e1322142746fd" alt="まつぼん"
そんなお悩みにお答えします!
ボタン連打ゲームは、開発難易度も低く、個人ゲーム開発初心者が作りやすいジャンルです。
本記事では、Unityで簡単なボタン連打ゲームの作り方をご紹介したいと思います。
また、ハイスコアを保存しゲーム再開時に表示する機能もご紹介します。
環境
Unity バージョン:2020.3.46f1
Unity Hub バージョン:3.7.0
ボタン連打ゲームのゲーム画面
ボタン連打ゲームのゲーム画面はこちらです。
data:image/s3,"s3://crabby-images/b8781/b878183943b617ad5db4e24ead7c390295814082" alt=""
10秒の間にどれだけボタンを連打できるかを競うゲームです。
ハイスコアを保存して、ゲーム再開後にハイスコアを表示できるようにします。
ボタン連打ゲームの作り方
ボタン連打ゲームの作り方は、下記のとおりです。
- プロジェクト作成
- UI作成
- スクリプト作成
- セーブ機能実装
詳細を順番にご説明します。
プロジェクト作成
まず、プロジェクトを作成しましょう。
Unity Hubを開いて、「新しいプロジェクト」をクリックしてください。
data:image/s3,"s3://crabby-images/81dfb/81dfba07c2d15c8297ea5549caf7b0b04294eea9" alt="プロジェクト画面 新しいプロジェクト"
テンプレートは「2Dコア」を選択。
プロジェクト名は「TestButtonClick」とします。
「プロジェクトを作成」をクリックしましょう。
data:image/s3,"s3://crabby-images/f310d/f310d580377954b2e6c61b20f518f06b04a2f33d" alt=""
そうすると、Unityエディターが開きます。
プロジェクト画面には「TestButtonClick」が追加されています。
data:image/s3,"s3://crabby-images/6f8c3/6f8c33c434e26bb459fb0918ddb36406e0b89926" alt=""
UI作成
まず、Canvasを作成します。
Canvasはボタンやテキストなど各UIを配置する土台となります。
Hierarchy画面左上「+」をクリックし、「UI」→「Canvas」を選択しましょう。
data:image/s3,"s3://crabby-images/ee20c/ee20cbfa1e3835c88d9c3cb26e5e0fdc06e3999e" alt=""
Hierarchy画面に「Canvas」が作られます。
data:image/s3,"s3://crabby-images/ffcb3/ffcb39d8c9ef8177c73fb21be77a826f7dc8b6eb" alt=""
次に、Canvasのサイズを調節しましょう。
現在、Canvasのサイズがゲーム画面に比べてとても大きい状態なので、カメラが移す範囲内に収まるようにします。
「Render Mode」から「Screen Space – Camera」を選択、「Render Camera」にHierarchy画面の「Main Camera」をドラッグ&ドロップします。
あと、今後配置するUIのサイズも調節しましょう。
今回は横幅960、縦幅540の画面サイズを基本として、ゲームを出力時に画面サイズが変更になっても、UIが崩れないようにします。
「UI Scale Mode」から「Scale With Screen Size」を選択、「Reference Resolution」の「X」に「960」、「Y」に「540」を入力、「Screen Match Mode」から「Expand」を選択しましょう。
data:image/s3,"s3://crabby-images/c8c42/c8c423fa85b47aaf60d30e3b4b533dd3b78ebc86" alt=""
それではボタンを配置していきましょう。
「Canvas」を右クリック→「UI」→「Button」を選択します。
data:image/s3,"s3://crabby-images/02d08/02d08438befe34006eba3e39926345e73c2f4d36" alt=""
Hierarchy画面に「Button」が生成されます。
data:image/s3,"s3://crabby-images/28f35/28f35956df8ff516181ed425978ce1b4c001ee94" alt=""
「Button」をクリックすると、Inspector画面に詳細が表示されます。
Pos Yを-100、 Widthを160、 Heightを80 に変更しましょう。
data:image/s3,"s3://crabby-images/fc504/fc50487958c82b2c4a10e0ba83b68be92b0abe6b" alt=""
タイム、ハイスコア、スコアの各テキストを配置します。
「Canvas」を右クリック→「UI」→「Text」を選択しましょう。
data:image/s3,"s3://crabby-images/d249d/d249dc1938df5c4c96c3c5bb8a05ace7a5acc795" alt=""
Hierarchy画面に「Text」が生成されます。
data:image/s3,"s3://crabby-images/a18b5/a18b5603a4e6a5d283bd0d216b6bc0a70b346a79" alt=""
「Text」を右クリック→「Rename」→名前を「TimeText」とします。
「TimeText」をクリックすると、Inspector画面に詳細が表示されます。
Pos Yを100、 Widthを160、 Heightを30、 Textをタイム:10、 Font Sizeを100、 Best Fitにチェックを入れる、 Colarを白 に変更しましょう。
data:image/s3,"s3://crabby-images/262d6/262d6ce3efd093133008fbafb7ba61d76d636577" alt=""
同様に、ハイスコアとスコアのテキストを配置します。
「HighScoreText」のInspector画面は以下の通り入力してください。
「TimeText」との違いは、Pos Yを50、 Textをハイスコア:0 の2点です。
data:image/s3,"s3://crabby-images/9f1e8/9f1e87c941b09ca595ec4f9e3b7910e7bcbe2eb5" alt=""
「CountText」のInspector画面は以下の通り入力してください。
「TimeText」との違いは、Pos Yを0、 Textをスコア:0 の2点です。
data:image/s3,"s3://crabby-images/6e5aa/6e5aafbd2afbeef53a0367e99749302b93c85426" alt=""
ここまでの作業で、Hierarchy画面はこちらのようになります。
data:image/s3,"s3://crabby-images/9423c/9423cd27705f8cf2cad24e5a3e9d5290aa8aca32" alt=""
Game画面はこんな感じです。
data:image/s3,"s3://crabby-images/2a73a/2a73a26059f777b98e60aa56a550647a44a207a0" alt=""
スクリプト作成
今度はスクリプトを作っていきましょう。
まず、Project画面の「+」をクリック→「C# Script」を選択します。
data:image/s3,"s3://crabby-images/8982e/8982e812cdb102d9273f89bfe86b6768069c11ff" alt=""
data:image/s3,"s3://crabby-images/5f49e/5f49ecaa7815cc556178f5241f9117fbe0eb5064" alt=""
スクリプトファイルが出来るので、名前を「ClickManager」とします。
data:image/s3,"s3://crabby-images/88642/886428ec3a0013b3dd0be4565b57fffa7a95a7c3" alt=""
このファイルに、以下のコードを記述してください。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
public class ClickManager : MonoBehaviour
{
//カウント用の変数を用意
public int count = 0;
//テキスト型の変数を用意。スコア表示
public Text countText;
//float型の変数を用意
public float time = 10.0f;
//テキスト型の変数を用意。タイム表示
public Text timeText;
//ハイスコア用の変数を用意
public int highScore = 0;
//テキスト型の変数を用意。ハイスコア表示
public Text highScoreText;
//変数を増やす関数を作成
public void PushButton()
{
//timeが0より上の時
if (time >0)
{
//countを1ずつ増やす
count++;
//増えた数字をテキストで表示
countText.text = "スコア:" + count;
}
}
// Start is called before the first frame update
void Start()
{
// "HIGHSCORE"をキーとして、ハイスコアを取得。値がない場合は0となる
highScore = PlayerPrefs.GetInt("HIGHSCORE", 0);
//ハイスコアをテキストで表示
highScoreText.text = "ハイスコア:" + highScore;
}
// Update is called once per frame
void Update()
{
//timeが0以下の時
if (time <= 0)
{
//テキストにカウントダウンの表示をする
timeText.text = "タイム:0.00";
}
else
{
//カウントダウンさせる
time -= Time.deltaTime;
//テキストにカウントダウンの表示をする
timeText.text = "タイム:" + time.ToString("f2");
}
//ハイスコアを超えた場合に更新
if (highScore < count)
{
highScore = count;
Debug.Log(highScore);
//ハイスコアをテキストで表示
highScoreText.text = "ハイスコア:" + highScore;
//"HIGHSCORE"をキーとして、ハイスコアを保存
PlayerPrefs.SetInt("HIGHSCORE", highScore);
//ディスクへの書き込み
PlayerPrefs.Save();
}
}
}
ハイスコアを保存し、ゲーム再開時に表示するため、Player Prefsを使用しています。
上記の黄色いアンダーバーに相当した部分です。
次に、Hierarchy画面の「+」をクリック→「Create Empty」を選択します。
data:image/s3,"s3://crabby-images/779a6/779a69a89a926f9ef8bbed345157a717edc96cb7" alt=""
空のゲームオブジェクトが出来るので、名前を「ClickManager」とします。
data:image/s3,"s3://crabby-images/5736a/5736a6f382ebc9d1ccbff2df7a17b7e29dfa9df0" alt=""
スクリプトファイルをゲームオブジェクトにアタッチします。
data:image/s3,"s3://crabby-images/ce51e/ce51ec356c1a549503efadd0c6fe76a33eb59313" alt=""
「ClickManager」のInspector画面で、以下の通りそれぞれアタッチしてください。
data:image/s3,"s3://crabby-images/ddbe1/ddbe1c1958ca0bbd274a64af17887bc4cf6fda78" alt=""
最後に、ボタンにスクリプトの関数をアタッチしましょう。
「Button」のInspector画面で、「On Click ()」の「+」をクリックします。
data:image/s3,"s3://crabby-images/5d7f0/5d7f0fc63dc86da7678a3373acef2efdd3f7c030" alt=""
ClickManagerをアタッチします。
data:image/s3,"s3://crabby-images/8b163/8b1637ed42a14c292b8df21e7ce34dd6e8e80f68" alt=""
「No Function」→「ClickManager」→「Push Button ()」を選択します。
data:image/s3,"s3://crabby-images/fd4a3/fd4a3cde22e8597f4701503deec4364f481f4905" alt=""
これで、ボタン連打ゲームが完成しました。
お疲れさまでした。
セーブ機能実装
セーブ機能を実装するには、下記の方法があります。
- Player Prefs
- Easy Save
今回は、Player Prefsを使ってハイスコアを保存しゲーム再開時に表示できるようにしました。
上記、スクリプトの黄色いアンダーバーの部分になります。
一方、Easy Saveは保存できる型が多い、オートセーブができるなど利点が多くあります。
有料ではありますが、個人ゲーム開発初心者にはEasy Saveをおすすめします。
Easy Saveを使ったセーブ機能実装方法については、こちらの記事をご参考ください。
【Unity】ボタン連打ゲームの作り方 ハイスコアを保存する方法 まとめ
data:image/s3,"s3://crabby-images/dafc1/dafc17ac83dd8dd621788de24767a9721c2c39db" alt="まとめアイキャッチ"
本記事では、Unityでボタン連打ゲームの作り方とハイスコアを保存する方法をご紹介しました。
ボタン連打ゲームは比較的簡単に作れるので、個人ゲーム開発初心者にうってつけのジャンルです。
手順どおりにすれば出来るので、ぜひ作ってみてくださいね。
本記事が、皆さんの参考になれば幸いです。