6

我有一个应用程序,TabActivity每次从我的引擎(NDK C 代码)收到回调时,我都会在其中显示一个对话框。我确保当应用程序处于恢复状态时显示对话框。

在收到来自引擎的回调后,我启动了NetworkDownDialog活动,但这会导致对话框停留一秒钟然后消失。Dialog如果我使用or ,也会发生同样的事情AlertDialog。最奇怪的是,消失似乎是随机的(并不总是发生)。

这是一个 S3 设备。这是怎么回事?

编辑于 23/05/2013

网络关闭对话框代码

public class NetworkDownDialog extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.network_down);
        Logger.d("NetworkDownDialog", "----------onCreate-----------");
        registerReceiver(mNetworkDownReceiver, new IntentFilter("NetworkDown"));
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
        unregisterReceiver(mNetworkDownReceiver);
        Logger.d("NetworkDownDialog", "------onDestroy-------");
    }
    @Override
    protected void onResume() {
        super.onResume();
        Logger.d("NetworkDownDialog", "------onResume-------");
    }
    @Override
    protected void onRestart() {
        super.onRestart();
        Logger.d("NetworkDownDialog", "------onRestart-------");
    }
    @Override
    protected void onStart() {
        super.onStart();
        Logger.d("NetworkDownDialog", "------onStart-------");
    }
    @Override
    protected void onStop() {
        super.onStop();
        Logger.d("NetworkDownDialog", "------onStop-------");
    }
    @Override
    public void onBackPressed() {
        Logger.d("NetworkDownDialog", "------onBackPressed Do nothing-------");
    }
    private BroadcastReceiver mNetworkDownReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            finish();
        }
    };
}

在日志中,这是我看到的:

05-15 20:48:02.981 D/NetworkDownDialog( 1050): ------onCreate-------
05-15 20:48:02.981 D/alsa_ucm(  202): Setting mixer control: RX5 MIX1 INP2, value: RX2
05-15 20:48:02.991 D/alsa_ucm(  202): Setting mixer control: RX6 DSM MUX, value: DSM_INV
05-15 20:48:02.991 D/alsa_ucm(  202): Setting mixer control: LINEOUT2 Volume, value: 100
05-15 20:48:02.991 D/alsa_ucm(  202): Setting mixer control: LINEOUT4 Volume, value: 100
05-15 20:48:02.991 D/NetworkDownDialog( 1050): ------onStart-------
05-15 20:48:02.991 D/alsa_ucm(  202): Setting mixer control: RX5 Digital Volume, value: 65
05-15 20:48:02.991 D/NetworkDownDialog( 1050): ------onResume-------

显示的活动对话框

 **05-15 20:48:05.073 W/InputDispatcher(  716): channel ~ Consumer closed input channel or an error occurred.  events=0x9
05-15 20:48:05.073 E/InputDispatcher(  716): channel ~ Channel is unrecoverably broken and will be disposed!**
05-15 20:48:05.073 W/InputDispatcher(  716): Attempted to unregister already unregistered input channel
05-15 20:48:05.083 I/SurfaceFlinger(  195): id=2033 Removed idx=5 MapSz=4
05-15 20:48:05.083 D/KeyguardViewMediator(  716): setHidden false
05-15 20:48:05.103 I/Adreno200-EGLSUB(  195): <CreateImage:897>: Android Image
05-15 20:48:05.103 I/Adreno200-EGLSUB(  195): <GetImageAttributes:1106>: RGBA_8888
**05-15 20:48:05.103 E/BufferQueue(  195): [mypackage.NetworkDownDialog] dequeueBuffer: SurfaceTexture has been abandoned!
05-15 20:48:05.103 E/SurfaceTextureClient( 1050): dequeueBuffer failed (No such device**)
05-15 20:48:05.103 D/PhoneStatusBar(  894): addNotification score=0
05-15 20:48:05.123 E/ViewRootImpl( 1050): Could not lock surface
05-15 20:48:05.123 E/ViewRootImpl( 1050): java.lang.IllegalArgumentException
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.Surface.lockCanvasNative(Native Method)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.Surface.lockCanvas(Surface.java:88)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.ViewRootImpl.drawSoftware(ViewRootImpl.java:2314)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.ViewRootImpl.draw(ViewRootImpl.java:2277)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2145)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1956)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1110)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4472)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.Choreographer$CallbackRecord.run(Choreographer.java:725)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.Choreographer.doCallbacks(Choreographer.java:555)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.Choreographer.doFrame(Choreographer.java:525)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:711)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.os.Handler.handleCallback(Handler.java:615)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.os.Handler.dispatchMessage(Handler.java:92)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.os.Looper.loop(Looper.java:137)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at android.app.ActivityThread.main(ActivityThread.java:4918)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at java.lang.reflect.Method.invokeNative(Native Method)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at java.lang.reflect.Method.invoke(Method.java:511)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
05-15 20:48:05.123 E/ViewRootImpl( 1050):   at dalvik.system.NativeStart.main(Native Method)

在这种情况下,上述的ActivityDialog消失了。

为什么我的对话框消失了?我的 C 级本机代码中的内存损坏是否可能导致此问题?我在 UI 方面做错了吗?我完全被困住了...

编辑于 24 -05 -2013

05-24 19:49:00.025 I/SurfaceFlinger( 1901): id=2147 Removed NainTabActivity idx=3 MapSz=4

05-24 19:49:00.025 I/SurfaceFlinger( 1901): id=2147 Removed NainTabActivity idx=-2 MapSz=4

SurfaceFlinger 删除了我的 tabactivity。这会导致对话框删除吗?

4

6 回答 6

5
  1. 确保您正在显示带有应用程序上下文的对话框。
  2. 确保没有两个事件出现并击中代码的同一部分。即,当您要显示对话框时,来自 c 代码的另一个事件来显示对话框。
  3. 确保您的应用程序有足够的内存来顺利运行。
于 2013-05-15T11:58:15.087 回答
3

您收到的错误是由于在您调用dialog.show().

另一个(可能的)解决方案是使用系统对话框,如下例所示:

AlertDialog dialog = new AlertDialog.Builder(context)
    .setMessage(text)
    .setPositiveButton(R.string.ok, null)
    .setCancelable(true)
    .create();
dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
于 2013-05-22T14:09:44.640 回答
2

看到您的代码后,我建议您删除finish()BroadcastReceiver运行您的程序(用于测试目的)。您看到的问题可能是由于您的Activity开始和结束几乎同时发生。

于 2013-05-24T05:01:53.097 回答
1

我认为问题是由于表面没有被锁定。这是我在 SO 找到的一些解决方案。

希望他们有所帮助。

android-canvas-lockingandroid-draw-on-camera-preview

于 2013-05-23T05:41:36.017 回答
1

当我看到(通道〜消费者关闭输入通道)之前出现错误时,我发现它表明该应用程序正在关闭设计或其他地方引发的异常。我的直觉是,您要么终止活动,要么在显示对话框的同时遇到异常,导致您的应用程序开始退出。我还会在您调用完成的任何地方添加更多日志记录,以验证您在显示对话框时不会意外完成。

于 2013-05-24T00:35:22.503 回答
0

很好的问题是c代码一些文件描述符fd损坏导致了这个问题。一旦问题在c级别解决,问题就看不到了。虽然很奇怪。

于 2014-09-10T06:13:16.240 回答