我正在为android开发ui自动化平台。
由于某些原因,有时(非常罕见)点击事件可能会被删除
当它发生时,我在日志中看到
I/InputDispatcher( 2707): Dropped event because input dispatch is disabled.
请告知可以做些什么来启用输入调度。
提前感谢
Input Dispatcher在某些条件下会丢弃输入事件:
- DROP_REASON_BLOCKED:如果当前应用程序没有响应,并且用户正在敲击设备,则输入事件将被删除
- DROP_REASON_STALE:已删除事件,因为它已过期
- DROP_REASON_APP_SWITCH:由于挂起过期的应用程序切换而丢弃事件
- 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");
}