簡介
以下指南說明如何使用適用於 Unity 的 Firebase SDK,對 Unity 遊戲的編譯和建構程序進行偵錯。說明如何針對新平台設定及建構遊戲時,或在更新後遇到的常見問題進行調查及解決。這些錯誤的排列順序,是依據這些錯誤在程序中可能發生的時間。請依序查看這些問題,並在解決每個問題後繼續進行。
除了本文件外,請參閱 Unity 版 Firebase 常見問題,進一步瞭解相關資訊。
遊戲模式編譯問題
在嘗試啟動行動裝置建構作業之前,您可以在編輯器中進行測試,這時可能會發生第一類建構問題。本節說明在 Play 模式前後發生的所有 Firebase 錯誤。
當 Unity 啟動或偵測到依附元件、程式碼或其他素材資源有變更時,就會嘗試重建專案。如果專案無法在該時間編譯,編輯器會將編譯錯誤記錄到主控台,如果您嘗試進入播放模式,Unity 的「Scene」分頁會顯示「All compiler errors have to be fixed before you can enter playmode!
」的錯誤彈出式視窗。
排解 Firebase 相關編譯問題
缺少類型、類別、方法和成員
許多 Firebase 問題都是因為編輯器和編譯器無法找到必要的類型、類別、方法和成員。這種情況的常見症狀包括:
The type or namespace name ‘<CLASS OR NAMESPACE NAME>' could not be found. Are you missing a using directive or an assembly reference?
The type or namespace name <TYPE OR NAMESPACE NAME> does not exist in the namespace ‘Firebase<.OPTIONAL NESTED NAMESPACE NAME PATH>' (are you missing an assembly reference?)
‘<CLASS NAME>' does not contain a definition for ‘<MEMBER VARIABLE OR METHOD NAME>'
解決步驟:
如果您在程式碼中使用 Firebase 類別或方法,請務必為所需的特定 Firebase 產品提供正確的
using
指示,確保這些類別或方法可供使用。確認您已匯入適當的 Firebase 套件:
- 如要匯入適當的套件,請執行下列任一操作:
- 將 Firebase Unity SDK 新增為
.unitypackage
或 - 查看並執行「其他 Unity 安裝選項」中其中一個替代選項。
- 將 Firebase Unity SDK 新增為
- 請確認專案和 EDM4U 中的每項 Firebase 產品:
- 使用相同版本
- 安裝為
.unitypackage
獨有,或僅透過 Unity 套件管理員安裝。
- 如要匯入適當的套件,請執行下列任一操作:
如果您匯入的 Firebase Unity SDK 版本為「10.0.0」以下版本,則 Firebase Unity SDK ZIP 封存檔會包含 .NET 3.x 和 .NET 4.x 的支援套件。請確認您在專案中只納入相容的 .NET Framework 版本:
- 如要瞭解 Unity 編輯器版本與 .NET 架構層級之間的相容性,請參閱「將 Firebase 新增至您的 Unity 專案」一文。
- 如果您不小心在錯誤的 .NET Framework 層級匯入 Firebase 套件,或是需要從使用
.unitypackage
切換至其他 Unity 安裝選項,最簡單的方法是透過這個遷移專區中提到的方法移除每個 Firebase 套件,然後重新匯入所有 Firebase 套件。
請確認編輯器是否正在重新建構專案,且您嘗試播放的內容反映了專案的最新狀態:
執行模式執行階段錯誤
如果遊戲已開始執行,但執行時在 Firebase 發生問題,請嘗試下列做法:
請確認你已在 Mac OS 的「安全性與隱私權」中核准 Firebase 套件
如果您在 Mac OS 的編輯器中啟動遊戲時,畫面上顯示「FirebaseCppApp-<version>.bundle 無法開啟,因為無法驗證開發人員」對話方塊,則必須在 Mac 的「安全性與隱私權」選單中核准該特定套件檔案。
做法是依序點選「Apple」圖示 >「系統偏好設定」>「安全性與隱私權」。
在安全性選單中,頁面下方約一半處有一個部分,指出「FirebaseCppApp-<version>.bundle」已遭封鎖,因為該檔案並非來自已識別的開發人員。」
按一下「還是允許」按鈕。
返回 Unity,然後再次按下「Play」。
接著,畫面會顯示類似第一個的警告:
按下「Open」後,程式便可繼續執行,且不會再詢問您是否要使用這個特定檔案。
確認專案包含並使用有效的設定檔
- 請在「File」>「Build Settings」中,確認已為您要設定的目標 (iOS 或 Android) 設定建構設定。如需更完整的討論內容,請參閱 Unity 建構設定說明文件。
- 請在 Firebase 控制台的 專案設定 > 您的應用程式中,下載應用程式的設定檔 (Android 版為
google-services.json
,iOS 版為GoogleService-Info.plist
) 和建構目標: 如果您已擁有這些檔案,請在專案中刪除這些檔案,並用最新版本取代,確保檔案名稱的拼法與上述完全一致,且檔名中沒有附加「(1)」或其他數字。 - 如果控制台包含有關
Assets/StreamingAssets/
中檔案的訊息,請確認控制台中沒有任何訊息指出 Unity 無法編輯該處的檔案 - 請確認已產生
Assets/StreamingAssets/google-services-desktop.json
,且與下載的設定檔相符。- 如果系統未自動產生,且
StreamingAssets/
不存在,請在Assets
目錄中手動建立目錄。 - 檢查 Unity 是否已產生
google-services-desktop.json
。
- 如果系統未自動產生,且
確保每個 Firebase 產品和 EDM4U 都只透過 .unitypackage
或 Unity 套件管理工具安裝
- 請檢查
Assets/
資料夾和 Unity Package Manager,確認 Firebase SDK 和 EDM4U 是否只透過其中一種方法安裝。 - 部分 Google 開發的外掛程式 (例如 Google Play) 和第三方外掛程式可能會依附 EDM4U。這些外掛程式可能會在
.unitypackage
或 Unity Package Manager (UPM) 套件中納入 EDM4U。請確保專案中只有一份 EDM4U 的副本。如果任何 UPM 套件都依賴 EDM4U,建議您只保留 EDM4U 的 UPM 版本,這些版本可在 Unity 存檔頁面中的 Google API 找到。
請確認專案中的每個 Firebase 產品都使用相同的版本。
- 如果 Firebase SDK 是透過
.unitypackage
安裝,請檢查Assets/Firebase/Plugins/x86_64/
底下的所有FirebaseCppApp
程式庫是否為相同版本。 - 如果是透過 Unity Package Manager (UPM) 安裝 Firebase SDK,請依序開啟「Windows」>「Package Manager」,搜尋「Firebase」,並確認所有 Firebase 套件皆為相同版本。
- 如果專案包含不同版本的 Firebase SDK,建議您先完全移除所有 Firebase SDK,再重新安裝所有 Firebase SDK,這次請使用相同版本。最簡單的方法,就是透過這個遷移專區中提到的方法移除每個 Firebase 套件。
解析器和目標裝置版本錯誤
如果遊戲可以在編輯器中運作 (已針對您選擇的適當建構目標進行設定),請接著確認 External Dependency Manager for Unity (EDM4U) 是否已正確設定及運作。
EDM4U GitHub 存放區包含逐步指南,您應先詳閱並遵循指南中的說明,再繼續進行。
「Single Dex」問題和精簡 (如使用 Cloud Firestore,則為必要)
建構 Android 應用程式時,您可能會遇到與單一 dex 檔案相關的建構失敗問題。錯誤訊息看起來會像以下內容 (如果您的專案已設定為使用 Gradle 建構系統):
Cannot fit requested classes in a single dex file.
.dex
檔案用於保存 Android 應用程式的一組類別定義及其相關附加資料。單一 DEX 檔案只能參照 65,536 個方法;如果專案中所有 Android 程式庫的方法總數超過此上限,建構作業就會失敗。
您可以依序套用下列兩個步驟;如果經過精簡處理後問題仍未解決,請再啟用多個 dex。
啟用壓縮功能
Unity 在 2017.2 版中推出了簡化功能,可移除未使用的程式碼,進而減少單一 DEX 檔案中參照方法的總數。* 這個選項位於「Player Settings」>「Android」>「Publishing Settings」>「Minify」。* 不同版本的 Unity 可能提供不同的選項,請參閱 Unity 官方說明文件。
啟用 Multidex
如果啟用精簡功能後,參照的方法數量仍超過限制,您可以選擇啟用 multidex
。在 Unity 中,您可以透過多種方式達成這項目標:
- 如果已啟用「Player Settings」下方的「Custom Gradle Template」,請修改
mainTemplate.gradle
。 - 如果您使用 Android Studio 建構匯出的專案,請修改模組層級的 build.gradle 檔案。
詳情請參閱 multidex 使用者指南。
瞭解並修正目標裝置的執行階段錯誤
如果您的遊戲可在編輯器中運作,且可針對目標裝置建構及安裝遊戲,但遇到執行階段錯誤,請檢查並調查裝置上產生的記錄。
本節將詳細說明如何調查記錄,找出可能的錯誤,以及在裝置或模擬器上執行時才會發生的錯誤。
Android
模擬工具
裝置
熟悉 adb 和 adb logcat 的使用方式。
- 您可以使用指令列環境的各種工具篩選輸出內容,也可以考慮查看 Logcat 的選項。
要以簡潔的插入畫面啟動 ADB 工作階段,最簡單的方法為:
adb logcat -c && adb logcat <OPTIONS>
其中
OPTIONS
是您傳遞指令列以篩選輸出的任意標記。
透過 Android Studio 使用 Logcat
透過 Android Studio 使用 Logcat 時,您可以使用其他搜尋工具,輕鬆產生有效率的搜尋結果。
iOS
檢查記錄
如果執行的是實體裝置,請將裝置連接至電腦。在 Xcode 中檢查 lldb。
Swift 相關問題
如果您遇到提到 swift 的錯誤記錄,請參閱「Unity 的外部依附元件管理工具」一節。
後續步驟
如果遊戲仍有與 Firebase 相關的編譯、建構或執行問題,請查看 Unity 版 Firebase SDK 問題頁面,並考慮提交新問題。此外,請參閱 Firebase 支援頁面,瞭解其他選項。