InputDispatcher:已丢弃事件,因为输入调度已禁用



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

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

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

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

请告知可以做些什么来启用输入调度。

提前感谢

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

  1. DROP_REASON_BLOCKED:如果当前应用程序没有响应,并且用户正在敲击设备,则输入事件将被删除
  2. DROP_REASON_STALE:已删除事件,因为它已过期
  3. DROP_REASON_APP_SWITCH:由于挂起过期的应用程序切换而丢弃事件
  4. DROP_REASON_DISABLED:由于禁用了输入调度,已丢弃事件

等等。

在您的案例中,执行案例4。意味着有可疑的东西或您的第一个输入尚未执行。因此,Input Dispatcher被禁用。

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

它只在屏幕关闭时发生。点击事件打开屏幕,但它事件比打开屏幕更快。

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

//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");
}

相关内容

最新更新