diff options
author | Xin Li <delphij@google.com> | 2018-08-06 16:51:26 -0700 |
---|---|---|
committer | Xin Li <delphij@google.com> | 2018-08-06 16:51:26 -0700 |
commit | aca265722281fe082995a71fd35401f766afac3e (patch) | |
tree | 28eac0d8752df3b094f50103a9ebb6d6340f4cc8 /src/com/android/tv/receiver/AbstractGlobalKeyReceiver.java | |
parent | 5fdc24aa6cc0acfd6a2d5939862e6edbe14f1ef6 (diff) | |
parent | c56e1892201e0b31f3043e37a32d779b4055cb34 (diff) | |
download | TV-oreo-mr1-1.2-iot-release.tar.gz |
Merge Android Pie into masterandroid-o-mr1-iot-release-smart-display-r3android-o-mr1-iot-release-1.0.5android-o-mr1-iot-release-1.0.4android-o-mr1-iot-release-1.0.3oreo-mr1-1.2-iot-releasemaster-cuttlefish-testing-release
Bug: 112104996
Change-Id: Iec32f622f0bb1bc1583aefcbf6d115ad05baa693
Diffstat (limited to 'src/com/android/tv/receiver/AbstractGlobalKeyReceiver.java')
-rw-r--r-- | src/com/android/tv/receiver/AbstractGlobalKeyReceiver.java | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/src/com/android/tv/receiver/AbstractGlobalKeyReceiver.java b/src/com/android/tv/receiver/AbstractGlobalKeyReceiver.java new file mode 100644 index 00000000..f88bd8a8 --- /dev/null +++ b/src/com/android/tv/receiver/AbstractGlobalKeyReceiver.java @@ -0,0 +1,106 @@ +/* + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.tv.receiver; + +import android.content.BroadcastReceiver; +import android.content.Context; +import android.content.Intent; +import android.os.AsyncTask; +import android.provider.Settings; +import android.util.Log; +import android.view.KeyEvent; +import com.android.tv.Starter; +import com.android.tv.TvApplication; +import com.android.tv.TvSingletons; + +/** Handles global keys. */ +public abstract class AbstractGlobalKeyReceiver extends BroadcastReceiver { + private static final boolean DEBUG = false; + private static final String TAG = "AbstractGlobalKeyReceiver"; + + private static final String ACTION_GLOBAL_BUTTON = "android.intent.action.GLOBAL_BUTTON"; + // Settings.Secure.USER_SETUP_COMPLETE is hidden. + private static final String SETTINGS_USER_SETUP_COMPLETE = "user_setup_complete"; + + private static long sLastEventTime; + private static boolean sUserSetupComplete; + + @Override + public void onReceive(Context context, Intent intent) { + if (!TvSingletons.getSingletons(context).getTvInputManagerHelper().hasTvInputManager()) { + Log.wtf(TAG, "Stopping because device does not have a TvInputManager"); + return; + } + Starter.start(context); + Context appContext = context.getApplicationContext(); + if (DEBUG) Log.d(TAG, "onReceive: " + intent); + if (sUserSetupComplete) { + handleIntent(appContext, intent); + } else { + new AsyncTask<Void, Void, Boolean>() { + @Override + protected Boolean doInBackground(Void... params) { + return Settings.Secure.getInt( + appContext.getContentResolver(), + SETTINGS_USER_SETUP_COMPLETE, + 0) + != 0; + } + + @Override + protected void onPostExecute(Boolean setupComplete) { + if (DEBUG) Log.d(TAG, "Is setup complete: " + setupComplete); + sUserSetupComplete = setupComplete; + if (sUserSetupComplete) { + handleIntent(appContext, intent); + } + } + }.execute(); + } + } + + private void handleIntent(Context appContext, Intent intent) { + if (ACTION_GLOBAL_BUTTON.equals(intent.getAction())) { + KeyEvent event = intent.getParcelableExtra(Intent.EXTRA_KEY_EVENT); + if (DEBUG) Log.d(TAG, "handleIntent: " + event); + int keyCode = event.getKeyCode(); + int action = event.getAction(); + long eventTime = event.getEventTime(); + if (action == KeyEvent.ACTION_UP && sLastEventTime != eventTime) { + // Workaround for b/23947504, the same key event may be sent twice, filter it. + sLastEventTime = eventTime; + switch (keyCode) { + case KeyEvent.KEYCODE_DVR: + ((TvApplication) appContext).handleDvrKey(); + break; + case KeyEvent.KEYCODE_GUIDE: + ((TvApplication) appContext).handleGuideKey(); + break; + case KeyEvent.KEYCODE_TV: + ((TvApplication) appContext).handleTvKey(); + break; + case KeyEvent.KEYCODE_TV_INPUT: + ((TvApplication) appContext).handleTvInputKey(); + break; + default: + // Do nothing + break; + } + } + } + } +} |