質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

Q&A

解決済

1回答

932閲覧

FirebaseのRealtime DatabaseでUnityのアプリの最新バージョンをチェックしたい

709

総合スコア28

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

0グッド

0クリップ

投稿2019/08/29 14:16

編集2019/08/30 11:39

実現したいこと

Realtime Databaseから最新のバージョン番号を取得し、アプリ起動時に取得したあと
今のバージョンを取得して最新バージョンでなければダウンロードページに誘導したい
###ソースコード
#####データの構造

json

1{ 2 3 "version" : { 4 "tuyopon" : "1.6.0" 5 } 6} 7

#####VersionCheck.cs

c#

1using System.Collections; 2using System.Collections.Generic; 3using System; 4using UnityEngine; 5using Firebase; 6using UnityEngine.UI; 7using Firebase.Database; 8using Firebase.Unity.Editor; 9public class VersionCheck : MonoBehaviour 10{ 11 public GameObject can;//ウェブサイト誘導用ダイアログ 12 13 void Start(){ 14 15 FirebaseApp.DefaultInstance.SetEditorDatabaseUrl("https://・・・.firebaseio.com/"); 16 FirebaseDatabase.DefaultInstance 17 .GetReference("version") 18 .GetValueAsync().ContinueWith(task => { 19 if (task.IsFaulted) { 20 // Handle the error... 21 } 22 else if (task.IsCompleted) { 23 DataSnapshot data = task.Result; 24 // Do something with snapshot... 25 string ver = (string)data.Child("tuyopon").Value; 26 27 if (NeedUpdate(Application.version,ver)) 28 { 29 can.SetActive(true); 30 }else 31 { 32 can.SetActive(false); 33 } 34 } 35 }); 36 37 } 38 bool NeedUpdate (string currentVersion, string minimumVersion) 39 {// バージョン比較 40 int[] currentVersions = Array.ConvertAll (currentVersion.Split ('.'), int.Parse); 41 int[] minimumVersions = Array.ConvertAll (minimumVersion.Split ('.'), int.Parse); 42 for (int i = 0; i < minimumVersions.Length; i++) { 43 if (currentVersions [i] < minimumVersions [i]) { 44 return true; 45 } 46 } 47 return false; 48 } 49public void up_page(){ 50//ウェブサイトへ 51 Application.OpenURL("http://razupai2468.starfree.jp/tuyopon.html"); 52} 53public void back(){ 54//ダイアログを隠す 55 can.SetActive(false); 56} 57}

###発生している問題
エラーはないが、
ダイアログが表示されない
Application.versionは「1.5」になっています。
#####追記

c#

1   ・・・ 2    string ver = (string)data.Child("tuyopon").Value; 3    Debug.Log(Application.version); 4 Debug.Log(ver); 5 Debug.Log(NeedUpdate(Application.version,ver)); 6 if (NeedUpdate(Application.version,ver)) 7 { 8 can.SetActive(true); 9 }else 10 { 11 can.SetActive(false); 12 } 13   ・・・

これだとコンソールにログは表示されない
しかし

console

1Database object 0x4f8809b0 should be deleted before the App 0x4c870910 it depends upon. 2UnityEngine.Debug:LogWarning(Object) 3Firebase.Platform.FirebaseLogger:LogMessage(PlatformLogLevel, String) (at Z:/tmp/tmp.SOETccsZXr/firebase/app/client/unity/src/Unity/FirebaseLogger.cs:76) 4Firebase.LogUtil:LogMessage(LogLevel, String) (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/LogUtil.cs:62) 5Firebase.LogUtil:LogMessageFromCallback(LogLevel, String) (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/LogUtil.cs:70) 6Firebase.AppUtilPINVOKE:FirebaseApp_ReleaseReferenceInternal(HandleRef) 7Firebase.FirebaseApp:ReleaseReferenceInternal(FirebaseApp) (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:965) 8Firebase.FirebaseApp:RemoveReference() (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:259) 9Firebase.FirebaseApp:Dispose() (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:51) 10Firebase.FirebaseApp:Finalize() (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:47) 11

と警告が表示された。
順番を変え

c#

1 Debug.Log(ver); 2 Debug.Log(Application.version); 3 Debug.Log(NeedUpdate(Application.version,ver));

にすると変数verだけコンソールに表示される
Debug.Log(Application.version);を
Start()のすぐ下に追加すると

console

11.5 2UnityEngine.Debug:Log(Object) 3VersionCheck:Start() (at Assets/VersionCheck.cs:14) 4 5 6Database object 0x4c1db4a0 should be deleted before the App 0x4c0b91f0 it depends upon. 7UnityEngine.Debug:LogWarning(Object) 8Firebase.Platform.FirebaseLogger:LogMessage(PlatformLogLevel, String) (at Z:/tmp/tmp.SOETccsZXr/firebase/app/client/unity/src/Unity/FirebaseLogger.cs:76) 9Firebase.LogUtil:LogMessage(LogLevel, String) (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/LogUtil.cs:62) 10Firebase.LogUtil:LogMessageFromCallback(LogLevel, String) (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/LogUtil.cs:70) 11Firebase.AppUtilPINVOKE:FirebaseApp_ReleaseReferenceInternal(HandleRef) 12Firebase.FirebaseApp:ReleaseReferenceInternal(FirebaseApp) (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:965) 13Firebase.FirebaseApp:RemoveReference() (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:259) 14Firebase.FirebaseApp:Dispose() (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:51) 15Firebase.FirebaseApp:Finalize() (at Z:/tmp/tmp.HzqjZMMOFf/firebase/app/client/unity/proxy/FirebaseApp.cs:47) 16

となり、Application.versionが表示されてから警告がでる。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sakura_hana

2019/08/30 02:12

Debug.Logを使用して、各値が想定通りか確認してみてください。
709

2019/08/30 13:30

修正しました
guest

回答1

0

自己解決

何回か再起動したら治りました。

投稿2019/08/31 12:22

709

総合スコア28

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問