第一次触摸被忽略了?

Cor*_*urn 6 android

我正在制作一个闹钟.作为其中的一部分,我有一个IntentService在警报实际发生时启动一个活动.在活动中onCreate我正在唤醒屏幕,获取唤醒锁定,强制活动全屏播放,并播放声音.这就是onCreate中的所有内容:

super.onCreate(savedInstanceState);

// Get Alarm ID from the extras
Bundle extras = getIntent().getExtras();
int id = extras.getInt("AlarmID", -1);

// Get Alarm info from the DB 
DB = new DatabaseHelper(this);
alarm = DB.getAlarm(id);

if (alarm == null || !alarm.isEnabled()) finish();

getWindow().requestFeature(Window.FEATURE_ACTION_BAR);
setContentView(R.layout.activity_alarm);

// My root view
View contentView = findViewById(R.id.fullscreen_content);

// Hide action bar for full screen
ActionBar bar = getActionBar();
if (bar != null) bar.hide();
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);

// Hide nav bar
mSystemUiHider = SystemUiHider.getInstance(this, contentView, HIDER_FLAGS);
mSystemUiHider.setup();
mSystemUiHider.hide();

// Show over lock screen
getWindow().addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED);

// Wake up screen
PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
wakeLock = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP, "MyWakeLock");
wakeLock.acquire();

// Get UI Elements
TextView time = (TextView)findViewById(R.id.Time);
TextView name = (TextView)findViewById(R.id.SmallAlarmName);

// Fill UI Elements
time.setText(Alarm.FormatTime(alarm.getHour(), alarm.getMinute()));
name.setText(alarm.getName());

// Play selected ringtone
tone = RingtoneManager.getRingtone(this, alarm.getSound());
tone.setStreamType(RingtoneManager.TYPE_ALARM);
tone.play();
Run Code Online (Sandbox Code Playgroud)

视图相当简单:2x TextViews显示闹钟的时间和名称,2x可点击的ImageViews用于暂停和禁用.

我遇到的问题是,当我第一次触摸屏幕时,没有任何反应.两个ImageView都以一个开头,Log.i所以我知道当事件触发时我推它.在第一次推送时,没有日志输出.在第二次推送时,会触发正确的ImageView事件.如果在创建活动时屏幕最初打开或关闭并不重要,则第一次触摸可以被非常重复地忽略.发生了什么,如何解决它,以便第一次触摸按预期工作?

我正在测试我的Nexus 5,4.4.3,Rooted,stock rom,Xposed Framework(但没有会影响我的应用程序的模块).我无法在虚拟机中进行真正的测试,因为需要使用铃声(VM没有铃声).

此外,对于记录,第一次点击不会发生其他日志.我不知道手机认为我在窃听什么.

编辑:我认为它与旗帜有关.我注意到我打电话setFlags而不是addFlags打电话getWindow().setFlags(...).相反,我将其更改为addFlags并尝试将其更改为:

int flags = WindowManager.LayoutParams.FLAG_FULLSCREEN |
            WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON |
            WindowManager.LayoutParams.FLAG_TOUCHABLE_WHEN_WAKING |
            WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED;
getWindow().addFlags(flags);
Run Code Online (Sandbox Code Playgroud)

但没有变化.

有没有办法告诉我们可能会截断第一次点击?

我尝试在onCreate结束时设置一个断点,并不断踩到最终等待事件发生,但即使在这种状态下,第一次点击也不会在调试器中进行更改.如我所料,第二次点击我的一个ImageView将停止我的点击处理程序内第一行的调试器.

编辑2:我想我正在做点什么.我正在通过过滤器观看logcat,只看到与我的应用程序相关的内容.我尝试在没有过滤器的情况下查看logcat,并且能够在第一次点击时可靠地获取这些类型的消息:

06-12 23:28:04.437      812-844/? W/InputEventReceiver? Attempted to finish an input event but the input event receiver has already been disposed.
Run Code Online (Sandbox Code Playgroud)

第一次点击将响应其中两个警告.第一个之后的额外点击将不会发出此类警告,我的处理程序将按预期执行.

快速搜索回来了这个问题,但对我的情况没有帮助.不仅仅是一个警告,我认为这可能是为什么第一次点击被忽略的根本原因.但是,我仍然不知道如何解决它.

tee*_*jay 8

不确定这是否是答案或者它是多少普遍,但是......我通过删除这些标志设法解决了这个问题:

getWindow().getDecorView().setSystemUiVisibility(
    View.SYSTEM_UI_FLAG_LAYOUT_STABLE
          //| View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
          //| View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
          | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY);
Run Code Online (Sandbox Code Playgroud)

我只能推测为什么那两个标志导致第一次触摸无知的原因.也许它是与这些标签相关的"沉浸模式",因为它应该(并且确实)隐藏导航本身,所以也许它在引擎盖下以某种方式发生冲突......我不知道:-)