今回は、Unityでスコアランキング(オンラインランキング)を簡単に実装してみます。
見た目は一旦置いといて、どのように実装するのかを簡単にやってみます。
はじめに
オンラインランキングや対戦型のゲームなどを実装する場合、自分でサーバーを立てるか、外部サービスを利用するかが必要になります。
手軽なのはもちろん外部サービスを使う方法。ということで今回はNCMB(ニフクラモバイルバックエンド)を利用して簡単にランキングを実装してみます。
サービスの登録
まずは登録。今回使うのはニフクラのmBaaS(mobile backend as a Service)です。
無料プランはSNS連携で登録、私はGoogleアカウントでログインしました。
data:image/s3,"s3://crabby-images/06c4c/06c4c82637ccd30a5891432870e494ad31a294a6" alt=""
メール確認が届くのでクリックすれば登録完了。10秒もあればできますね。
ログインすると、初めに「アプリの新規作成」画面が出てくるので、名前を適当につけておきます。
data:image/s3,"s3://crabby-images/515e5/515e5be809183ee3db9f5ca1b6a47286b9a8d910" alt=""
Unityで実装開始
登録が済んだらUnityを起動、今回は新規で作成してみます。
Unityのバージョンは2021.3.3f1。
data:image/s3,"s3://crabby-images/ee685/ee685dc883ba326288f0c9c8b8fdaff7948840c7" alt=""
Unityの起動を待つ間に必要なSDKをダウンロードしておきます。
下記のGithubのページから最新のZipファイルをダウンロード。
data:image/s3,"s3://crabby-images/8f8d9/8f8d90e39e69ff55cab2871a0602fff8f091747e" alt=""
Unityが起動したら、ダウンロードしたSDKを取り込み(ダブルクリック)。
data:image/s3,"s3://crabby-images/152f2/152f28c2d1d57e7704c7265b62f7b770a4939331" alt=""
全てのファイルをインポート。
data:image/s3,"s3://crabby-images/20e78/20e78490c6d798e998a95111aa04ba048c6eff44" alt=""
サンプルを確認
インポートしたファイルの中にあるサンプルを動かしてみます。
Scenes→QuickStartフォルダ内にあるQuickStartシーンに切り替えます。
その中のNCMBSettingsにアプリケーションキーとクライアントキーを入力します。
data:image/s3,"s3://crabby-images/78c99/78c99e82281b7c75b34e65666acccfa049b054a4" alt=""
入力するキーは管理画面の「アプリ設定」内にあります。
data:image/s3,"s3://crabby-images/1df33/1df33c245fc66c851f4425d1999143789a7b716e" alt=""
キーを入力したら実行をしてみます。実行すると下記のスクリプトが動きます。
data:image/s3,"s3://crabby-images/2b21d/2b21d78f4089d3b0dc26d7e662ad5366729bf11a" alt=""
サンプルスクリプト通りにデータストアにデータが入ればOK
data:image/s3,"s3://crabby-images/74720/747203543bf99d868164ca7b7600247f69c347a1" alt=""
ランキングの実装
ここからランキングを実装していきます。
新規シーンに切り替え。NCMBManagerとNCMBSettingsのプレハブをヒエラルキーメニューに入れます
data:image/s3,"s3://crabby-images/689b2/689b245c27b32d844483cc033e295e6c96674d4a" alt=""
NCMBSettingsにキーを入力。
data:image/s3,"s3://crabby-images/926ac/926ac4b8d8d460aba01fd9cebf00a54d86961b60" alt=""
空オブジェクトを追加、名前をScoreManagerとしてScoreSaveスクリプトをアタッチ。
data:image/s3,"s3://crabby-images/3140c/3140c958f84b855df9b171b2658c9b421192843d" alt=""
ScoreSaveスクリプトは下記に変更。サンプルと同じ感じですが、通信が発生するので未接続の可能性も考慮して少し処理を追加。パラメータに指定した値をデータストアに保存する感じです。
using System.Collections; using System.Collections.Generic; using UnityEngine; using NCMB; public class ScoreSave : MonoBehaviour { public void SaveScore(int Score) { NCMBObject scoreClass = new NCMBObject("ScoreClass"); scoreClass["score"] = Score; scoreClass.SaveAsync((NCMBException e) => { if (e != null) { Debug.Log("Error: " + e.ErrorMessage); } else { Debug.Log("success"); } }); } }
UI→ボタンを追加。
data:image/s3,"s3://crabby-images/8026a/8026a9bcf03672abfb695be0339d2425cd83731e" alt=""
ボタンクリックでスコアを追加するようにします。実際はゲーム終了時に呼び出す感じですかね。
data:image/s3,"s3://crabby-images/2da49/2da49db69cfdf5d0ad3bf7cf7c6a92754aef32ca" alt=""
実行してみて、コンソールにsuccessと表示され、スコアが保存されていればOK。
data:image/s3,"s3://crabby-images/2b4ae/2b4aec18e8598a62c114e9a40580ff1d6213bed4" alt=""
次は保存したスコアの呼び出し、ScoreManagerオブジェクトにScoreLoadで新規スクリプトをアタッチ。
data:image/s3,"s3://crabby-images/17da5/17da52ce9788e4e949110a4e02d405000a01fb34" alt=""
スクリプトは下記に変更。スコアを高い順に10件と指定してからデータを抜き出しています。
using System.Collections; using System.Collections.Generic; using UnityEngine; using NCMB; public class ScoreLoad : MonoBehaviour { public void LoadScore() { int rank; NCMBQuery<NCMBObject> query = new NCMBQuery<NCMBObject>("ScoreClass"); query.OrderByDescending("score"); query.Limit = 10; query.FindAsync((List<NCMBObject> objList, NCMBException e) => { if (e != null) { Debug.LogWarning("error: " + e.ErrorMessage); } else { for (int i = 0; i < objList.Count; i++) { rank = i + 1; Debug.Log("ScoreRanking " + rank + "位: " + objList[i]["score"]); } } }); } }
同じようにボタンを作成して、呼び出し。
data:image/s3,"s3://crabby-images/dd1bb/dd1bb392cb72578704fadc8e97da47a628cf0fcd" alt=""
コンソールに表示されるか確認。
data:image/s3,"s3://crabby-images/a6656/a6656614b33aac4cedaefcc88edd7b1221420346" alt=""
次に、適当に複数のスコアを保存してから実行、スコアの大きい順に並んで表示されればOK。
data:image/s3,"s3://crabby-images/c8200/c820045149c1be4ea7402cdaee5e3a28b6a60293" alt=""
実際には10番目のスコアを取得して、そのスコアよりも上だったらデータストアに保存する感じにするのかな。
この後は画面を作って、取得したスコアを表示って感じですね。ユーザー名の入力・表示もあった方が良いですかね。
とりあえず今回はスコアの保存と呼び出しまで。
無料枠について
無料で使える枠はAPIリクエストが月10万回まで。他にも条件がありますが十分すぎるかなと。
data:image/s3,"s3://crabby-images/2da92/2da925818f7b7262706bf667bbee6e70805c8f3a" alt=""
並び替えや件数絞りではリスクエスト回数は増えないみたい。
ランキング以外にもアイテムを管理したりガチャ機能もできるみたい。
オフラインランキング
ちなみに、自分の端末内だけでランキングするならplayerprefsで良いかな。