実現したいこと
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が表示されてから警告がでる。
回答1件
あなたの回答
tips
プレビュー