集成到另一个 Android 应用程序中的 Unity Android 在 Application.Quit() 上崩溃
Unity Android integrated into a different Android app is crashing on Application.Quit()
将项目导出到 Android 项目后,我们将其与我们从中启动游戏的现有项目集成。这工作正常,但 Application.Quit() 导致整个应用程序退出,而不仅仅是 Unity activity。所以我们通过将其添加到清单中使其在不同的进程上启动:
android:process=":UnityKillsMe"
这解决了问题,但是,在使用 Proguard 混淆代码后,一切都停止了。 Unity 仍然可以正确启动,但是当退出时,应用程序会显示 Unity 已停止的崩溃错误,即使应用程序本身仍在运行。重新启动 Unity 甚至可以正常工作,但在 Application.Quit() 上,崩溃错误仍然显示。这是发生时的错误日志:
12-02 15:01:35.112: E/AndroidRuntime(4342): FATAL EXCEPTION: UnityMain
12-02 15:01:35.112: E/AndroidRuntime(4342): Process: mobi.foo.touch:UnityKillsMe, PID: 4342
12-02 15:01:35.112: E/AndroidRuntime(4342): java.lang.Error: FATAL EXCEPTION [UnityMain]
12-02 15:01:35.112: E/AndroidRuntime(4342): Unity version : 5.2.3f1
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.nativeDone(Native Method)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.f(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.g(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.run(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.executeGLThreadJobs(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer$b.run(Unknown Source)
12-02 15:01:35.122: E/ActivityManager(890): App crashed! Process: mobi.foo.touch:UnityKillsMe
如何解决?是什么导致了这个问题?
我刚刚遇到了确切的问题并设法解决了它。
如果在 Unity3D 中调用 Application.Quit(),Proguard + Unity3D 在单独的进程中启动将崩溃。
解决方案: 通过本机销毁退出 Unity3D 应用程序。
Unity3D:
// Add this code in, replace Application.Quit() to AndroidQuit()
void AndroidQuit(){
AndroidJavaClass myClass = new AndroidJavaClass("com.yourpackagenamehere.UnityPlayerActivity");
AndroidJavaObject activity = myClass.GetStatic<AndroidJavaObject>("UnityActivity");
activity.Call("QuitUnity");
}
Android 项目:
// In UnityPlayerActivity.java
// Declare static object for Unity to make calls from
public static Context UnityActivity;
// Instantiate it in the onCreate Method right after super.onCreate
UnityActivity = this;
// Add the following method for Unity3D function to trigger the Quit
public void QuitUnity() {
android.os.Process.killProcess(android.os.Process.myPid());
//finish();
//this.onDestroy();
}
编辑:
在我更新我的项目后,this.OnDestroy() 和 finish() 将显示一个崩溃对话框。 android.os.Process.killProcess() 效果很好。
但是直接杀掉进程就可以了。
附带说明一下,崩溃的原因之一可能是由于我在 logcat.
中使用渲染纹理和以下统一错误表面
Destroying active render texture. Switching to main context.
将项目导出到 Android 项目后,我们将其与我们从中启动游戏的现有项目集成。这工作正常,但 Application.Quit() 导致整个应用程序退出,而不仅仅是 Unity activity。所以我们通过将其添加到清单中使其在不同的进程上启动:
android:process=":UnityKillsMe"
这解决了问题,但是,在使用 Proguard 混淆代码后,一切都停止了。 Unity 仍然可以正确启动,但是当退出时,应用程序会显示 Unity 已停止的崩溃错误,即使应用程序本身仍在运行。重新启动 Unity 甚至可以正常工作,但在 Application.Quit() 上,崩溃错误仍然显示。这是发生时的错误日志:
12-02 15:01:35.112: E/AndroidRuntime(4342): FATAL EXCEPTION: UnityMain
12-02 15:01:35.112: E/AndroidRuntime(4342): Process: mobi.foo.touch:UnityKillsMe, PID: 4342
12-02 15:01:35.112: E/AndroidRuntime(4342): java.lang.Error: FATAL EXCEPTION [UnityMain]
12-02 15:01:35.112: E/AndroidRuntime(4342): Unity version : 5.2.3f1
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.nativeDone(Native Method)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.f(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.g(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.run(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer.executeGLThreadJobs(Unknown Source)
12-02 15:01:35.112: E/AndroidRuntime(4342): at com.unity3d.player.UnityPlayer$b.run(Unknown Source)
12-02 15:01:35.122: E/ActivityManager(890): App crashed! Process: mobi.foo.touch:UnityKillsMe
如何解决?是什么导致了这个问题?
我刚刚遇到了确切的问题并设法解决了它。
如果在 Unity3D 中调用 Application.Quit(),Proguard + Unity3D 在单独的进程中启动将崩溃。
解决方案: 通过本机销毁退出 Unity3D 应用程序。
Unity3D:
// Add this code in, replace Application.Quit() to AndroidQuit()
void AndroidQuit(){
AndroidJavaClass myClass = new AndroidJavaClass("com.yourpackagenamehere.UnityPlayerActivity");
AndroidJavaObject activity = myClass.GetStatic<AndroidJavaObject>("UnityActivity");
activity.Call("QuitUnity");
}
Android 项目:
// In UnityPlayerActivity.java
// Declare static object for Unity to make calls from
public static Context UnityActivity;
// Instantiate it in the onCreate Method right after super.onCreate
UnityActivity = this;
// Add the following method for Unity3D function to trigger the Quit
public void QuitUnity() {
android.os.Process.killProcess(android.os.Process.myPid());
//finish();
//this.onDestroy();
}
编辑: 在我更新我的项目后,this.OnDestroy() 和 finish() 将显示一个崩溃对话框。 android.os.Process.killProcess() 效果很好。
但是直接杀掉进程就可以了。
附带说明一下,崩溃的原因之一可能是由于我在 logcat.
中使用渲染纹理和以下统一错误表面Destroying active render texture. Switching to main context.