在三星 Galaxy S 上发送“向下”键时出现“窗口管理器崩溃”

Posted

技术标签:

【中文标题】在三星 Galaxy S 上发送“向下”键时出现“窗口管理器崩溃”【英文标题】:"Window Manager Crash" on dispatching 'Down' key on Samsung Galaxy S 【发布时间】:2012-02-23 22:05:35 【问题描述】:

我正在使用 Instrumentation 在各种 android 设备上运行我的单元测试。测试用例在模拟器和除 Samsung Galaxy S 之外的所有设备上都能正常工作。 在三星 Galaxy S 上,它显示 Window Manager 在使用检测注入大约 30 个关键事件后崩溃 以下是完整的崩溃日志:

D/dalvikvm(11862): GC_EXPLICIT freed 6800 objects / 374040 bytes in 54ms
D/dalvikvm(11862): GC_EXPLICIT freed 780 objects / 71856 bytes in 39ms
W/dalvikvm(11862): threadid=9: thread exiting with uncaught exception (group=0x4001d7d0)
E/WindowManager( 2472): Window Manager Crash
E/WindowManager( 2472): java.lang.NullPointerException
E/WindowManager( 2472):         at com.android.server.WindowManagerService$KeyWaiter.waitForNextEventTarget(WindowManagerService.java:5844)
E/WindowManager( 2472):         at com.android.server.WindowManagerService.injectKeyEvent(WindowManagerService.java:5565)
E/WindowManager( 2472):         at android.view.IWindowManager$Stub.onTransact(IWindowManager.java:110)
E/WindowManager( 2472):         at com.android.server.WindowManagerService.onTransact(WindowManagerService.java:692)
E/WindowManager( 2472):         at android.os.Binder.execTransact(Binder.java:288)
E/WindowManager( 2472):         at dalvik.system.NativeStart.run(Native Method)
E/AndroidRuntime(11862): FATAL EXCEPTION: Instr: com.myapp.test.ImpInstrumentation
E/AndroidRuntime(11862): java.lang.NullPointerException
E/AndroidRuntime(11862):        at android.os.Parcel.readException(Parcel.java:1266)
E/AndroidRuntime(11862):        at android.os.Parcel.readException(Parcel.java:1248)
E/AndroidRuntime(11862):        at android.view.IWindowManager$Stub$Proxy.injectKeyEvent(IWindowManager.java:830)
E/AndroidRuntime(11862):        at android.app.Instrumentation.sendKeySync(Instrumentation.java:859)
E/AndroidRuntime(11862):        at android.app.Instrumentation.sendKeyDownUpSync(Instrumentation.java:872)
E/AndroidRuntime(11862):        at com.myapp.test.util.ListUtil.<b>arrowDownToPosition</b>(ListUtil.java:69)

下面是它通常崩溃的一段代码:

    private void arrowDownToPosition(int position) 
          int maxDowns = 50;
        while(mListView.getSelectedItemPosition() < position && --maxDowns > 0) 
             mInstrumentation.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_DOWN);
        

//Crashes on below line dispatching enter key
      mInstrumentation.sendKeyDownUpSync(KeyEvent.KEYCODE_ENTER);
    

欢迎所有解决方案/建议。

【问题讨论】:

什么版本的Android? @ReubenScratton 在 Android 2.2 上 令人烦恼的是您的堆栈跟踪没有与任何 2.2.x 源代码树对齐。大概是三星定制的。 知道waitForNextEventTarget() 方法的作用吗? 来自三星的任何 cmets/解决方案/建议.... 【参考方案1】:

不确定这是否有帮助,但在简要研究这个问题时,我发现了这个source。看一下,特别是第 175 行关于 Galaxy S 上 DPAD_CENTER 的错误,以及该问题是如何解决的。

【讨论】:

感谢提示我仅在 ListView 中遇到问题。除了KEYPAD_DOWN 上的ListView 之外,我没有任何替代方法可以移动到ListView 中的特定位置。 嗯,我明白了,我会继续寻找。【参考方案2】:

根据您的堆栈跟踪,您的变量 mInstrumentation 似乎为空。忘记初始化了吗?

试试这个:

while(mInstrumentation!=null && mListView.getSelectedItemPosition()>-1) 
    mInstrumentation.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_DOWN);

【讨论】:

不是,不是。 'mInstrumentation' 显然已初始化,因为堆栈跟踪显示异常源自 'sendKeyDownUpSync' 方法的子级内部。

以上是关于在三星 Galaxy S 上发送“向下”键时出现“窗口管理器崩溃”的主要内容,如果未能解决你的问题,请参考以下文章

三星Galaxy S22和 三星Galaxy S22+参数对比

如何在三星 Galaxy S 上使用前置摄像头

如何在三星 Galaxy S 上使用前置摄像头

在三星 Galaxy S 上以人像模式“拍照并呈现”

Android phonegap 应用程序在三星 Galaxy 设备上存在 SQlite 和本地存储问题

在三星 Galaxy Tab 3 上调用了闹钟,但在 LeEco Le2 上没有调用