今回はUnity2Dで簡単なルーレットを作成してみます。ボタンクリックでホイールを回転させて、止まった時の値を取得していきます。
はじめに
Unityのバージョンは2021.3.14f1です。
下記の画像を利用していきます、Inkscapeで簡単に作成したものです。
data:image/s3,"s3://crabby-images/fb97a/fb97a97fb66a995366b01552a2ee426c28ccece7" alt=""
画像をAssetsフォルダ内に入れておきます。
data:image/s3,"s3://crabby-images/455d2/455d24c4745ae09e698a9bdcc36ffa1f35f7318a" alt=""
実装開始
簡単な画面を作成した後にスクリプトで動きを実装します。利用する画像は上の画像だけです。
UI作成
シーンにwheel画像をドラッグアンドドロップします。
data:image/s3,"s3://crabby-images/e7dde/e7dde1986325c7113134b3fe131505c94df1dddf" alt=""
「2DObject」→「Sprites」→「Circle」を追加し、配下に「Triangle」を追加。
data:image/s3,"s3://crabby-images/4a42d/4a42dd95731e3a504e4a5198a07ad8e663ca1c38" alt=""
Triangleの位置とスケールを変更して、下記のような見た目にします。
data:image/s3,"s3://crabby-images/f09cc/f09cca6d2127a71d72276a4b99ca39e54dc83226" alt=""
data:image/s3,"s3://crabby-images/45182/451828984c0b417c0f3f2074913a73d1fad0869e" alt=""
スクリプトの作成
下記スクリプトを作成します。マウスを左クリックするとオブジェクトが回転して、徐々に回転が弱まって最後には止まります。
using UnityEngine; public class wheel : MonoBehaviour { private float speed; void Update() { if (Input.GetMouseButton(0)) speed = 20f; transform.Rotate(0, 0, speed); speed *= 0.98f; } }
スクリプトをwheelに追加します。
data:image/s3,"s3://crabby-images/c9f1d/c9f1d2d93e162e61e44d0c4143bdebe2d436dbbe" alt=""
実行すると下記のようになります。
data:image/s3,"s3://crabby-images/700e0/700e0c16291d1ded4b6be3d1a18268007023b0df" alt=""
ランダム性の修正
次に「ランダム性」、「回転中の制御」と「矢印が示している数字の取得」を追加していきます。
Hierarchyで右クリックして「UI」→「Legacy」→「Button」を追加。
data:image/s3,"s3://crabby-images/11606/1160683c9b48ca43f00783832d746b1f2ea7299d" alt=""
ButtonのRectTransform、Textを変更して下記のような感じにします。
data:image/s3,"s3://crabby-images/a5fce/a5fce87c5e30bcc101f9b5b31f689fbd71d55b10" alt=""
スクリプトを下記に変更します。回転速度をランダムにし、止まった時に矢印が何処を示しているのかを「debug.log」で出力しています。また、回転中には再度回転しないようにフラグを追加しています。
using UnityEngine; public class wheel : MonoBehaviour { private float speed; private bool isRotate; private void Awake() { isRotate = false; } void Update() { if (isRotate) { transform.Rotate(0, 0, speed); speed *= 0.98f; if (speed <= 0.05f) { transform.Rotate(0, 0, 0); StopWheel(); isRotate = false; } } } public void Rotate() { if (!isRotate) { speed = Random.Range(10, 40); isRotate = true; } } private void StopWheel() { float rotz = transform.eulerAngles.z; if (rotz > 0 && rotz <= 90) Debug.Log("1"); if (rotz > 90 && rotz <= 180) Debug.Log("2"); if (rotz > 180 && rotz <= 270) Debug.Log("3"); if (rotz > 270 && rotz <= 360) Debug.Log("4"); } }
ボタンを押した時に回転させたいので下記のようにセットします。
data:image/s3,"s3://crabby-images/ad44c/ad44cd4b98518d7efd58d15e7725d19c31a24e6f" alt=""
実行すると下記のような感じに。コンソールに矢印に該当する値が出力されていたらOKです。
data:image/s3,"s3://crabby-images/f574d/f574d3c41947d160bb9ea174fbc91e3da2384d7c" alt=""