InputDispatcher:由于禁用了输入分派而丢弃了事件

时间:2012-08-02 09:36:53

标签: android ui-automation dispatch

我正在为Android开发ui自动化平台。

由于某些原因,有时(非常罕见)点击事件可以被删除

当它发生时我会在日志中看到

I/InputDispatcher( 2707): Dropped event because input dispatch is disabled.

请告知如何启用输入调度。

提前谢谢

2 个答案:

答案 0 :(得分:1)

在某些条件下,Input Dispatcher将丢弃输入事件:

  1. DROP_REASON_BLOCKED:如果当前应用程序没有响应且用户正在点击设备,则输入事件将被删除
  2. DROP_REASON_STALE:丢弃的事件,因为它陈旧
  3. DROP_REASON_APP_SWITCH:由于待处理的逾期应用程序切换而丢弃的事件
  4. DROP_REASON_DISABLED:由于禁用了输入调度而丢弃了事件
  5. 在你的情况下,它的执行案例4.意味着有些东西可疑或你的第一个输入尚未执行。所以输入调度程序被禁用。

    检查[中间件类InputDispatcher.cpp的方法dropInboundEventLocked

答案 1 :(得分:1)

只有在屏幕关闭时才会发生这种情况。点击事件正在打开屏幕,但事件比打开屏幕更快。

现在,我正在检查屏幕是否关闭并打开它

//Acquire wake lock in case screen is off
if (PermissionsUtil.checkSelfPermission(getContext(), Manifest.permission.WAKE_LOCK))
{
    PowerManager pm = (PowerManager)getContext().getSystemService(Context.POWER_SERVICE);
    if (pm.isScreenOn() == false)
    {
        wakeLock = pm.newWakeLock((PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP), TAG);
        // 
        wakeLock.acquire();
        Log.d(TAG,"Acquiring wake lock");
     }
}

//Do my stuff

//Release wake lock in case it was acquire
if (wakeLock != null && wakeLock.isHeld())
{
    wakeLock.release();
    wakeLock = null;
    Log.d(TAG,"Releasing wake lock");
}