Cherish:[QUASH]Revert Gaming Mode
Revert "Cherish: Option to disable all headsup notifications for Gaming mode [2/2]" This reverts commitbda00a0719. Signed-off-by: Hưng Phan <phandinhhungvp2001@gmail.com> Revert "Prevent NPE in gaming mode settings" This reverts commit568bd02088. Revert "Gaming mode: stop using masterswitch preference" This reverts commitf58718e4ae. Revert "GameMode: remove hwkeys toggle on non-hwkeys devices" This reverts commit7a5e86f2e5. Revert "Cherish:Bring back Gaming mode [3/3]" This reverts commitc1e9a0df45. Signed-off-by: Hưng Phan <phandinhhungvp2001@gmail.com>
This commit is contained in:
@@ -620,33 +620,6 @@
|
|||||||
<item>@string/file_header_provider</item>
|
<item>@string/file_header_provider</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
<!-- Gaming mode -->
|
|
||||||
<string-array name="gaming_mode_ringer_entries">
|
|
||||||
<item>@string/gaming_mode_ringer_off_title</item>
|
|
||||||
<item>@string/gaming_mode_ringer_vibrate_title</item>
|
|
||||||
<item>@string/gaming_mode_ringer_dnd_title</item>
|
|
||||||
<item>@string/gaming_mode_ringer_silent_title</item>
|
|
||||||
</string-array>
|
|
||||||
<string-array name="gaming_mode_ringer_values" translatable="false">
|
|
||||||
<item>0</item>
|
|
||||||
<item>1</item>
|
|
||||||
<item>2</item>
|
|
||||||
<item>3</item>
|
|
||||||
</string-array>
|
|
||||||
|
|
||||||
<string-array name="gaming_mode_notifications_entries">
|
|
||||||
<item>@string/gaming_mode_notifications_off_title</item>
|
|
||||||
<item>@string/gaming_mode_notifications_notif_title</item>
|
|
||||||
<item>@string/gaming_mode_notifications_toast_title</item>
|
|
||||||
<item>@string/gaming_mode_notifications_all_title</item>
|
|
||||||
</string-array>
|
|
||||||
<string-array name="gaming_mode_notifications_values" translatable="false">
|
|
||||||
<item>0</item>
|
|
||||||
<item>1</item>
|
|
||||||
<item>2</item>
|
|
||||||
<item>3</item>
|
|
||||||
</string-array>
|
|
||||||
|
|
||||||
<string-array name="ambient_notification_light_timeout_entries" translatable="false">
|
<string-array name="ambient_notification_light_timeout_entries" translatable="false">
|
||||||
<item>@string/entry_infinite</item>
|
<item>@string/entry_infinite</item>
|
||||||
<item>@string/entry_five_minute</item>
|
<item>@string/entry_five_minute</item>
|
||||||
@@ -1071,23 +1044,6 @@
|
|||||||
<item>3</item>
|
<item>3</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
<!-- Gaming mode-->
|
|
||||||
<string-array name="gaming_mode_headsup_toggle_entries">
|
|
||||||
<item>@string/gaming_mode_headsup_allow</item>
|
|
||||||
<item>@string/gaming_mode_headsup_dnc</item>
|
|
||||||
<item>@string/gaming_mode_headsup_clock</item>
|
|
||||||
<item>@string/gaming_mode_headsup_dialer</item>
|
|
||||||
<item>@string/gaming_mode_headsup_stop</item>
|
|
||||||
</string-array>
|
|
||||||
|
|
||||||
<string-array name="gaming_mode_headsup_toggle_values">
|
|
||||||
<item>0</item>
|
|
||||||
<item>1</item>
|
|
||||||
<item>2</item>
|
|
||||||
<item>3</item>
|
|
||||||
<item>4</item>
|
|
||||||
</string-array>
|
|
||||||
|
|
||||||
<!-- Settings dashboard icon style -->
|
<!-- Settings dashboard icon style -->
|
||||||
<string-array name="theming_settings_dashboard_icons_entries" translatable="false">
|
<string-array name="theming_settings_dashboard_icons_entries" translatable="false">
|
||||||
<item>@string/theming_settings_dashboard_icons_default</item>
|
<item>@string/theming_settings_dashboard_icons_default</item>
|
||||||
@@ -1397,5 +1353,4 @@
|
|||||||
<item>@string/monet_5</item>
|
<item>@string/monet_5</item>
|
||||||
<item>@string/monet_6</item>
|
<item>@string/monet_6</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@@ -683,37 +683,6 @@
|
|||||||
<string name="status_bar_custom_header_shadow_title">Darken image</string>
|
<string name="status_bar_custom_header_shadow_title">Darken image</string>
|
||||||
<string name="status_bar_custom_header_height_title">Image height offset</string>
|
<string name="status_bar_custom_header_height_title">Image height offset</string>
|
||||||
|
|
||||||
<!-- Gaming mode -->
|
|
||||||
<string name="gaming_mode_title">Gaming Mode</string>
|
|
||||||
<string name="gaming_mode_summary">Customize gaming mode preferences</string>
|
|
||||||
<string name="gaming_mode_enable_title">Enable Gaming Mode</string>
|
|
||||||
<string name="gaming_mode_enable_summary">Master switch for Gaming Mode</string>
|
|
||||||
<string name="gaming_mode_app_picker_title">Automatically turn on for these apps</string>
|
|
||||||
<string name="add_gaming_mode_package_title">Add apps for Gaming mode</string>
|
|
||||||
<string name="add_gaming_mode_package_summary">Gaming mode will turn on automatically when these apps are opened and turn off when they are closed</string>
|
|
||||||
<string name="gaming_mode_headsup_title">Heads-up Notifications</string>
|
|
||||||
<string name="gaming_mode_headsup_allow">Allow all headsup notifications</string>
|
|
||||||
<string name="gaming_mode_headsup_dnc">Block all headsup notifications except calls & alarms</string>
|
|
||||||
<string name="gaming_mode_headsup_clock">Block all headsup notifications except alarms</string>
|
|
||||||
<string name="gaming_mode_headsup_dialer">Block all headsup notifications except calls</string>
|
|
||||||
<string name="gaming_mode_headsup_stop">Block all headsup notifications</string>
|
|
||||||
<string name="gaming_mode_hardware_keys_title">Lock buttons</string>
|
|
||||||
<string name="gaming_mode_hardware_keys_summary">Disable hardware buttons when Gaming mode is turned on</string>
|
|
||||||
<string name="gaming_mode_brightness_title">Disable automatic brightness</string>
|
|
||||||
<string name="gaming_mode_brightness_summary">Lock screen brightness when Gaming mode is turned on</string>
|
|
||||||
<string name="gaming_mode_ringer_title">Ringer in gaming mode</string>
|
|
||||||
<string name="gaming_mode_ringer_off_title">Do not change</string>
|
|
||||||
<string name="gaming_mode_ringer_vibrate_title">Vibrate</string>
|
|
||||||
<string name="gaming_mode_ringer_dnd_title">Do Not Disturb</string>
|
|
||||||
<string name="gaming_mode_ringer_silent_title">Silent</string>
|
|
||||||
<string name="gaming_mode_notifications_title">Gaming mode indication</string>
|
|
||||||
<string name="gaming_mode_notifications_off_title">Disabled</string>
|
|
||||||
<string name="gaming_mode_notifications_notif_title">Show notification</string>
|
|
||||||
<string name="gaming_mode_notifications_toast_title">Show toasts</string>
|
|
||||||
<string name="gaming_mode_notifications_all_title">Show toasts and notification</string>
|
|
||||||
<string name="gaming_mode_dynamic_title">Dynamic mode</string>
|
|
||||||
<string name="gaming_mode_dynamic_summary">Try detecting and adding gaming apps automatically</string>
|
|
||||||
|
|
||||||
<!-- Ambient edge lighting -->
|
<!-- Ambient edge lighting -->
|
||||||
<string name="pulse_ambient_light_category">Screen edge lighting</string>
|
<string name="pulse_ambient_light_category">Screen edge lighting</string>
|
||||||
<string name="pulse_ambient_light_title">Show on new notifcation</string>
|
<string name="pulse_ambient_light_title">Show on new notifcation</string>
|
||||||
|
|||||||
@@ -18,14 +18,6 @@
|
|||||||
android:title="@string/misc_title"
|
android:title="@string/misc_title"
|
||||||
xmlns:settings="http://schemas.android.com/apk/res/com.android.settings">
|
xmlns:settings="http://schemas.android.com/apk/res/com.android.settings">
|
||||||
|
|
||||||
<Preference
|
|
||||||
android:key="gaming_mode"
|
|
||||||
android:icon="@drawable/ic_gaming_mode"
|
|
||||||
android:fragment="com.cherish.settings.fragments.GamingMode"
|
|
||||||
android:title="@string/gaming_mode_title"
|
|
||||||
android:summary="@string/gaming_mode_summary"
|
|
||||||
android:defaultValue="false" />
|
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:title="@string/doze_brightness_category">
|
android:title="@string/doze_brightness_category">
|
||||||
|
|
||||||
|
|||||||
@@ -1,85 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
Copyright (C) 2016-2019 crDroid Android 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.
|
|
||||||
-->
|
|
||||||
<PreferenceScreen
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
xmlns:settings="http://schemas.android.com/apk/res/com.android.settings"
|
|
||||||
android:title="@string/gaming_mode_title">
|
|
||||||
|
|
||||||
<com.cherish.settings.preferences.SystemSettingSwitchPreference
|
|
||||||
android:key="gaming_mode_enabled"
|
|
||||||
android:title="@string/gaming_mode_enable_title"
|
|
||||||
android:summary="@string/gaming_mode_enable_summary"
|
|
||||||
android:defaultValue="false" />
|
|
||||||
|
|
||||||
<com.cherish.settings.preferences.SystemSettingListPreference
|
|
||||||
android:key="gaming_mode_headsup_toggle"
|
|
||||||
android:title="@string/gaming_mode_headsup_title"
|
|
||||||
android:entries="@array/gaming_mode_headsup_toggle_entries"
|
|
||||||
android:entryValues="@array/gaming_mode_headsup_toggle_values"
|
|
||||||
android:summary="%s"
|
|
||||||
android:dependency="gaming_mode_enabled"
|
|
||||||
android:defaultValue="1" />
|
|
||||||
|
|
||||||
<com.cherish.settings.preferences.SystemSettingSwitchPreference
|
|
||||||
android:key="gaming_mode_hw_keys_toggle"
|
|
||||||
android:title="@string/gaming_mode_hardware_keys_title"
|
|
||||||
android:summary="@string/gaming_mode_hardware_keys_summary"
|
|
||||||
android:dependency="gaming_mode_enabled"
|
|
||||||
android:defaultValue="false" />
|
|
||||||
|
|
||||||
<com.cherish.settings.preferences.SystemSettingSwitchPreference
|
|
||||||
android:key="gaming_mode_manual_brightness_toggle"
|
|
||||||
android:title="@string/gaming_mode_brightness_title"
|
|
||||||
android:summary="@string/gaming_mode_brightness_summary"
|
|
||||||
android:dependency="gaming_mode_enabled"
|
|
||||||
android:defaultValue="true" />
|
|
||||||
|
|
||||||
<com.cherish.settings.preferences.SystemSettingListPreference
|
|
||||||
android:key="gaming_mode_ringer_mode"
|
|
||||||
android:title="@string/gaming_mode_ringer_title"
|
|
||||||
android:entries="@array/gaming_mode_ringer_entries"
|
|
||||||
android:entryValues="@array/gaming_mode_ringer_values"
|
|
||||||
android:defaultValue="0"
|
|
||||||
android:dependency="gaming_mode_enabled"
|
|
||||||
android:summary="%s" />
|
|
||||||
|
|
||||||
<com.cherish.settings.preferences.SystemSettingListPreference
|
|
||||||
android:key="gaming_mode_notifications"
|
|
||||||
android:title="@string/gaming_mode_notifications_title"
|
|
||||||
android:entries="@array/gaming_mode_notifications_entries"
|
|
||||||
android:entryValues="@array/gaming_mode_notifications_values"
|
|
||||||
android:defaultValue="3"
|
|
||||||
android:dependency="gaming_mode_enabled"
|
|
||||||
android:summary="%s" />
|
|
||||||
|
|
||||||
<!-- <com.cherish.settings.preferences.SystemSettingSwitchPreference
|
|
||||||
android:key="gaming_mode_dynamic_state"
|
|
||||||
android:title="@string/gaming_mode_dynamic_title"
|
|
||||||
android:summary="@string/gaming_mode_dynamic_summary"
|
|
||||||
android:dependency="gaming_mode_enabled"
|
|
||||||
android:defaultValue="false" />
|
|
||||||
-->
|
|
||||||
<PreferenceCategory
|
|
||||||
android:dependency="gaming_mode_enabled"
|
|
||||||
android:title="@string/gaming_mode_app_picker_title"
|
|
||||||
android:key="gamingmode_applications">
|
|
||||||
<Preference
|
|
||||||
android:key="add_gamingmode_packages"
|
|
||||||
android:icon="@drawable/ic_menu_add_white"
|
|
||||||
android:title="@string/add_gaming_mode_package_title" />
|
|
||||||
</PreferenceCategory>
|
|
||||||
</PreferenceScreen>
|
|
||||||
@@ -79,14 +79,6 @@
|
|||||||
android:title="@string/sleep_mode_aggressive_toggle_title"
|
android:title="@string/sleep_mode_aggressive_toggle_title"
|
||||||
android:summary="@string/sleep_mode_aggressive_toggle_summary"
|
android:summary="@string/sleep_mode_aggressive_toggle_summary"
|
||||||
android:defaultValue="true" />
|
android:defaultValue="true" />
|
||||||
|
|
||||||
<com.cherish.settings.preferences.SecureSettingListPreference
|
|
||||||
android:key="sleep_mode_ringer_mode"
|
|
||||||
android:title="@string/gaming_mode_ringer_title"
|
|
||||||
android:entries="@array/gaming_mode_ringer_entries"
|
|
||||||
android:entryValues="@array/gaming_mode_ringer_values"
|
|
||||||
android:defaultValue="0"
|
|
||||||
android:summary="%s" />
|
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
<com.android.settingslib.widget.LayoutPreference
|
<com.android.settingslib.widget.LayoutPreference
|
||||||
|
|||||||
@@ -1,364 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2019 crDroid Android 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.cherish.settings.fragments;
|
|
||||||
|
|
||||||
import android.app.AlertDialog;
|
|
||||||
import android.app.Dialog;
|
|
||||||
import android.content.ContentResolver;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.DialogInterface;
|
|
||||||
import android.content.pm.PackageInfo;
|
|
||||||
import android.content.pm.PackageManager;
|
|
||||||
import android.content.pm.PackageManager.NameNotFoundException;
|
|
||||||
import android.database.ContentObserver;
|
|
||||||
import android.net.Uri;
|
|
||||||
import android.os.Bundle;
|
|
||||||
import android.os.Handler;
|
|
||||||
import android.os.Looper;
|
|
||||||
import android.os.UserHandle;
|
|
||||||
import android.provider.Settings;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
import android.view.LayoutInflater;
|
|
||||||
import android.view.View;
|
|
||||||
import android.view.ViewGroup;
|
|
||||||
import android.widget.AdapterView;
|
|
||||||
import android.widget.AdapterView.OnItemClickListener;
|
|
||||||
import android.widget.ListView;
|
|
||||||
|
|
||||||
import androidx.preference.ListPreference;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceCategory;
|
|
||||||
import androidx.preference.PreferenceGroup;
|
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
import androidx.preference.SwitchPreference;
|
|
||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto;
|
|
||||||
import com.android.settings.R;
|
|
||||||
import com.android.settings.SettingsPreferenceFragment;
|
|
||||||
|
|
||||||
import com.cherish.settings.preferences.PackageListAdapter;
|
|
||||||
import com.cherish.settings.preferences.PackageListAdapter.PackageItem;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
public class GamingMode extends SettingsPreferenceFragment
|
|
||||||
implements Preference.OnPreferenceClickListener {
|
|
||||||
|
|
||||||
private static final int DIALOG_GAMING_APPS = 1;
|
|
||||||
private static final String GAMING_MODE_HW_KEYS = "gaming_mode_hw_keys_toggle";
|
|
||||||
|
|
||||||
private SwitchPreference mHardwareKeysDisable;
|
|
||||||
|
|
||||||
private PackageListAdapter mPackageAdapter;
|
|
||||||
private PackageManager mPackageManager;
|
|
||||||
private PreferenceGroup mGamingPrefList;
|
|
||||||
private Preference mAddGamingPref;
|
|
||||||
|
|
||||||
private String mGamingPackageList;
|
|
||||||
private Map<String, Package> mGamingPackages;
|
|
||||||
private Context mContext;
|
|
||||||
|
|
||||||
private static final int KEY_MASK_HOME = 0x01;
|
|
||||||
private static final int KEY_MASK_BACK = 0x02;
|
|
||||||
private static final int KEY_MASK_MENU = 0x04;
|
|
||||||
private static final int KEY_MASK_APP_SWITCH = 0x10;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
|
||||||
super.onCreate(savedInstanceState);
|
|
||||||
// Get launch-able applications
|
|
||||||
addPreferencesFromResource(R.xml.gaming_mode_settings);
|
|
||||||
|
|
||||||
// mFooterPreferenceMixin.createFooterPreference().setTitle(R.string.add_gaming_mode_package_summary);
|
|
||||||
|
|
||||||
final PreferenceScreen prefScreen = getPreferenceScreen();
|
|
||||||
|
|
||||||
mHardwareKeysDisable = (SwitchPreference) findPreference(GAMING_MODE_HW_KEYS);
|
|
||||||
|
|
||||||
if (!haveHWkeys()) {
|
|
||||||
prefScreen.removePreference(mHardwareKeysDisable);
|
|
||||||
}
|
|
||||||
|
|
||||||
mPackageManager = getPackageManager();
|
|
||||||
mPackageAdapter = new PackageListAdapter(getActivity());
|
|
||||||
|
|
||||||
mGamingPrefList = (PreferenceGroup) findPreference("gamingmode_applications");
|
|
||||||
mGamingPrefList.setOrderingAsAdded(false);
|
|
||||||
|
|
||||||
mGamingPackages = new HashMap<String, Package>();
|
|
||||||
|
|
||||||
mAddGamingPref = findPreference("add_gamingmode_packages");
|
|
||||||
|
|
||||||
mAddGamingPref.setOnPreferenceClickListener(this);
|
|
||||||
|
|
||||||
mContext = getActivity().getApplicationContext();
|
|
||||||
|
|
||||||
SettingsObserver observer = new SettingsObserver(new Handler(Looper.getMainLooper()));
|
|
||||||
observer.observe();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onResume() {
|
|
||||||
super.onResume();
|
|
||||||
refreshCustomApplicationPrefs();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getMetricsCategory() {
|
|
||||||
return MetricsProto.MetricsEvent.CHERISH_SETTINGS;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getDialogMetricsCategory(int dialogId) {
|
|
||||||
if (dialogId == DIALOG_GAMING_APPS) {
|
|
||||||
return MetricsProto.MetricsEvent.CHERISH_SETTINGS;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Utility classes and supporting methods
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Dialog onCreateDialog(int id) {
|
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
|
|
||||||
final Dialog dialog;
|
|
||||||
final ListView list = new ListView(getActivity());
|
|
||||||
list.setAdapter(mPackageAdapter);
|
|
||||||
|
|
||||||
builder.setTitle(R.string.profile_choose_app);
|
|
||||||
builder.setView(list);
|
|
||||||
dialog = builder.create();
|
|
||||||
|
|
||||||
switch (id) {
|
|
||||||
case DIALOG_GAMING_APPS:
|
|
||||||
list.setOnItemClickListener(new OnItemClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
|
|
||||||
// Add empty application definition, the user will be able to edit it later
|
|
||||||
PackageItem info = (PackageItem) parent.getItemAtPosition(position);
|
|
||||||
addCustomApplicationPref(info.packageName, mGamingPackages);
|
|
||||||
dialog.cancel();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return dialog;
|
|
||||||
}
|
|
||||||
|
|
||||||
class SettingsObserver extends ContentObserver {
|
|
||||||
SettingsObserver(Handler handler) {
|
|
||||||
super(handler);
|
|
||||||
}
|
|
||||||
|
|
||||||
void observe() {
|
|
||||||
ContentResolver resolver = mContext.getContentResolver();
|
|
||||||
|
|
||||||
resolver.registerContentObserver(Settings.System.getUriFor(
|
|
||||||
Settings.System.GAMING_MODE_ACTIVE), false, this,
|
|
||||||
UserHandle.USER_ALL);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onChange(boolean selfChange, Uri uri) {
|
|
||||||
if (uri.equals(Settings.System.getUriFor(
|
|
||||||
Settings.System.GAMING_MODE_ACTIVE))) {
|
|
||||||
boolean enable = Settings.System.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.System.GAMING_MODE_ACTIVE, 0) == 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Application class
|
|
||||||
*/
|
|
||||||
private static class Package {
|
|
||||||
public String name;
|
|
||||||
/**
|
|
||||||
* Stores all the application values in one call
|
|
||||||
* @param name
|
|
||||||
*/
|
|
||||||
public Package(String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String toString() {
|
|
||||||
StringBuilder builder = new StringBuilder();
|
|
||||||
builder.append(name);
|
|
||||||
return builder.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Package fromString(String value) {
|
|
||||||
if (TextUtils.isEmpty(value)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
Package item = new Package(value);
|
|
||||||
return item;
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
private void refreshCustomApplicationPrefs() {
|
|
||||||
if (!parsePackageList()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add the Application Preferences
|
|
||||||
if (mGamingPrefList != null) {
|
|
||||||
mGamingPrefList.removeAll();
|
|
||||||
|
|
||||||
for (Package pkg : mGamingPackages.values()) {
|
|
||||||
try {
|
|
||||||
Preference pref = createPreferenceFromInfo(pkg);
|
|
||||||
mGamingPrefList.addPreference(pref);
|
|
||||||
} catch (PackageManager.NameNotFoundException e) {
|
|
||||||
// Do nothing
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Keep these at the top
|
|
||||||
mAddGamingPref.setOrder(0);
|
|
||||||
// Add 'add' options
|
|
||||||
mGamingPrefList.addPreference(mAddGamingPref);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
|
||||||
if (preference == mAddGamingPref) {
|
|
||||||
showDialog(DIALOG_GAMING_APPS);
|
|
||||||
} else {
|
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity())
|
|
||||||
.setTitle(R.string.dialog_delete_title)
|
|
||||||
.setMessage(R.string.dialog_delete_message)
|
|
||||||
.setIconAttribute(android.R.attr.alertDialogIcon)
|
|
||||||
.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if (preference == mGamingPrefList.findPreference(preference.getKey())) {
|
|
||||||
removeApplicationPref(preference.getKey(), mGamingPackages);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.setNegativeButton(android.R.string.cancel, null);
|
|
||||||
|
|
||||||
builder.show();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addCustomApplicationPref(String packageName, Map<String,Package> map) {
|
|
||||||
Package pkg = map.get(packageName);
|
|
||||||
if (pkg == null) {
|
|
||||||
pkg = new Package(packageName);
|
|
||||||
map.put(packageName, pkg);
|
|
||||||
savePackageList(false, map);
|
|
||||||
refreshCustomApplicationPrefs();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private Preference createPreferenceFromInfo(Package pkg)
|
|
||||||
throws PackageManager.NameNotFoundException {
|
|
||||||
PackageInfo info = mPackageManager.getPackageInfo(pkg.name,
|
|
||||||
PackageManager.GET_META_DATA);
|
|
||||||
Preference pref =
|
|
||||||
new Preference(getActivity());
|
|
||||||
|
|
||||||
pref.setKey(pkg.name);
|
|
||||||
pref.setTitle(info.applicationInfo.loadLabel(mPackageManager));
|
|
||||||
pref.setIcon(info.applicationInfo.loadIcon(mPackageManager));
|
|
||||||
pref.setPersistent(false);
|
|
||||||
pref.setOnPreferenceClickListener(this);
|
|
||||||
return pref;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void removeApplicationPref(String packageName, Map<String,Package> map) {
|
|
||||||
if (map.remove(packageName) != null) {
|
|
||||||
savePackageList(false, map);
|
|
||||||
refreshCustomApplicationPrefs();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean parsePackageList() {
|
|
||||||
boolean parsed = false;
|
|
||||||
|
|
||||||
final String gamingModeString = Settings.System.getString(getContentResolver(),
|
|
||||||
Settings.System.GAMING_MODE_VALUES);
|
|
||||||
|
|
||||||
if (!TextUtils.equals(mGamingPackageList, gamingModeString)) {
|
|
||||||
mGamingPackageList = gamingModeString;
|
|
||||||
mGamingPackages.clear();
|
|
||||||
parseAndAddToMap(gamingModeString, mGamingPackages);
|
|
||||||
parsed = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parsed;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void parseAndAddToMap(String baseString, Map<String,Package> map) {
|
|
||||||
if (baseString == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
final String[] array = TextUtils.split(baseString, "\\|");
|
|
||||||
for (String item : array) {
|
|
||||||
if (TextUtils.isEmpty(item)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
Package pkg = Package.fromString(item);
|
|
||||||
map.put(pkg.name, pkg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private void savePackageList(boolean preferencesUpdated, Map<String,Package> map) {
|
|
||||||
String setting = map == mGamingPackages ? Settings.System.GAMING_MODE_VALUES : Settings.System.GAMING_MODE_DUMMY;
|
|
||||||
|
|
||||||
List<String> settings = new ArrayList<String>();
|
|
||||||
for (Package app : map.values()) {
|
|
||||||
settings.add(app.toString());
|
|
||||||
}
|
|
||||||
final String value = TextUtils.join("|", settings);
|
|
||||||
if (preferencesUpdated) {
|
|
||||||
if (TextUtils.equals(setting, Settings.System.GAMING_MODE_VALUES)) {
|
|
||||||
mGamingPackageList = value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Settings.System.putString(getContentResolver(),
|
|
||||||
setting, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean haveHWkeys() {
|
|
||||||
final int deviceKeys = getContext().getResources().getInteger(
|
|
||||||
com.android.internal.R.integer.config_deviceHardwareKeys);
|
|
||||||
|
|
||||||
// read bits for present hardware keys
|
|
||||||
final boolean hasHomeKey = (deviceKeys & KEY_MASK_HOME) != 0;
|
|
||||||
final boolean hasBackKey = (deviceKeys & KEY_MASK_BACK) != 0;
|
|
||||||
final boolean hasMenuKey = (deviceKeys & KEY_MASK_MENU) != 0;
|
|
||||||
final boolean hasAppSwitchKey = (deviceKeys & KEY_MASK_APP_SWITCH) != 0;
|
|
||||||
|
|
||||||
return (hasHomeKey || hasBackKey || hasMenuKey || hasAppSwitchKey);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,51 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2019 crDroid Android 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.cherish.settings.fragments;
|
|
||||||
|
|
||||||
import android.app.AlertDialog;
|
|
||||||
import android.content.BroadcastReceiver;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.DialogInterface;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.provider.Settings;
|
|
||||||
import android.util.Log;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
import com.android.internal.util.cherish.GamingModeController;
|
|
||||||
|
|
||||||
public class GamingModeReceiver extends BroadcastReceiver {
|
|
||||||
|
|
||||||
private static final String TAG = "GamingModeReceiver";
|
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
|
|
||||||
public GamingModeReceiver() {
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onReceive(Context context, Intent intent) {
|
|
||||||
if (intent.getAction() != null &&
|
|
||||||
intent.getAction().equals(GamingModeController.GAMING_MODE_TURN_OFF)) {
|
|
||||||
if (DEBUG) Log.d(TAG, "Received " + GamingModeController.GAMING_MODE_TURN_OFF);
|
|
||||||
Settings.System.putInt(context.getContentResolver(), Settings.System.GAMING_MODE_ACTIVE, 0);
|
|
||||||
} else if (intent.getAction() != null &&
|
|
||||||
intent.getAction().equals(GamingModeController.GAMING_MODE_TURN_ON)) {
|
|
||||||
if (DEBUG) Log.d(TAG, "Received " + GamingModeController.GAMING_MODE_TURN_ON);
|
|
||||||
Settings.System.putInt(context.getContentResolver(), Settings.System.GAMING_MODE_ACTIVE, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user