summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings/development/WindowAnimationScalePreferenceController.java
diff options
context:
space:
mode:
authorjeffreyhuang <jeffreyhuang@google.com>2017-10-10 14:51:55 -0700
committerjeffreyhuang <jeffreyhuang@google.com>2017-10-10 14:51:55 -0700
commit9c4a8c104f0061c0c58d8ead3e856376a987d2ea (patch)
tree3a882dd3a506195226384b56b76fd36fdb3a2c2e /src/com/android/settings/development/WindowAnimationScalePreferenceController.java
parente2fc925bb32fa30782e9b25817c4d0220cb37a01 (diff)
downloadpackages_apps_Settings-9c4a8c104f0061c0c58d8ead3e856376a987d2ea.tar.gz
packages_apps_Settings-9c4a8c104f0061c0c58d8ead3e856376a987d2ea.tar.bz2
packages_apps_Settings-9c4a8c104f0061c0c58d8ead3e856376a987d2ea.zip
Introduce WindowAnimationScalePreferenceController
- Create new WindowAnimationScalePreferenceController - Create controller inside the DashboardFragment - Port logic from DevelopmentSettings into the controller Bug: 34203528 Test: make RunSettingsRoboTests -j40 Change-Id: I71c17f4ea7ca9a0273a84cb75e506e9668817473
Diffstat (limited to 'src/com/android/settings/development/WindowAnimationScalePreferenceController.java')
-rw-r--r--src/com/android/settings/development/WindowAnimationScalePreferenceController.java120
1 files changed, 120 insertions, 0 deletions
diff --git a/src/com/android/settings/development/WindowAnimationScalePreferenceController.java b/src/com/android/settings/development/WindowAnimationScalePreferenceController.java
new file mode 100644
index 0000000000..1a17fd24e6
--- /dev/null
+++ b/src/com/android/settings/development/WindowAnimationScalePreferenceController.java
@@ -0,0 +1,120 @@
+/*
+ * Copyright (C) 2017 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.settings.development;
+
+import android.content.Context;
+import android.os.RemoteException;
+import android.os.ServiceManager;
+import android.support.annotation.VisibleForTesting;
+import android.support.v7.preference.ListPreference;
+import android.support.v7.preference.Preference;
+import android.support.v7.preference.PreferenceScreen;
+import android.view.IWindowManager;
+
+import com.android.settings.R;
+import com.android.settings.core.PreferenceControllerMixin;
+import com.android.settingslib.development.DeveloperOptionsPreferenceController;
+
+public class WindowAnimationScalePreferenceController extends
+ DeveloperOptionsPreferenceController implements Preference.OnPreferenceChangeListener,
+ PreferenceControllerMixin {
+
+ private static final String WINDOW_ANIMATION_SCALE_KEY = "window_animation_scale";
+
+ @VisibleForTesting
+ static final int WINDOW_ANIMATION_SCALE_SELECTOR = 0;
+ @VisibleForTesting
+ static final float DEFAULT_VALUE = 1;
+
+ private final IWindowManager mWindowManager;
+ private final String[] mListValues;
+ private final String[] mListSummaries;
+
+ private ListPreference mPreference;
+
+ public WindowAnimationScalePreferenceController(Context context) {
+ super(context);
+
+ mWindowManager = IWindowManager.Stub.asInterface(
+ ServiceManager.getService(Context.WINDOW_SERVICE));
+ mListValues = context.getResources().getStringArray(R.array.window_animation_scale_values);
+ mListSummaries = context.getResources().getStringArray(
+ R.array.window_animation_scale_entries);
+ }
+
+ @Override
+ public String getPreferenceKey() {
+ return WINDOW_ANIMATION_SCALE_KEY;
+ }
+
+ @Override
+ public void displayPreference(PreferenceScreen screen) {
+ super.displayPreference(screen);
+
+ mPreference = (ListPreference) screen.findPreference(getPreferenceKey());
+ }
+
+ @Override
+ public boolean onPreferenceChange(Preference preference, Object newValue) {
+ writeAnimationScaleOption(newValue);
+ return true;
+ }
+
+ @Override
+ public void updateState(Preference preference) {
+ updateAnimationScaleValue();
+ }
+
+ @Override
+ protected void onDeveloperOptionsSwitchEnabled() {
+ mPreference.setEnabled(true);
+ }
+
+ @Override
+ protected void onDeveloperOptionsSwitchDisabled() {
+ writeAnimationScaleOption(null);
+ mPreference.setEnabled(false);
+ }
+
+ private void writeAnimationScaleOption(Object newValue) {
+ try {
+ float scale = newValue != null ? Float.parseFloat(newValue.toString()) : DEFAULT_VALUE;
+ mWindowManager.setAnimationScale(WINDOW_ANIMATION_SCALE_SELECTOR, scale);
+ updateAnimationScaleValue();
+ } catch (RemoteException e) {
+ // intentional no-op
+ }
+ }
+
+ private void updateAnimationScaleValue() {
+ try {
+ final float scale = mWindowManager.getAnimationScale(WINDOW_ANIMATION_SCALE_SELECTOR);
+ int index = 0; // default
+ for (int i = 0; i < mListValues.length; i++) {
+ float val = Float.parseFloat(mListValues[i]);
+ if (scale <= val) {
+ index = i;
+ break;
+ }
+ }
+ mPreference.setValue(mListValues[index]);
+ mPreference.setSummary(mListSummaries[index]);
+ } catch (RemoteException e) {
+ // intentional no-op
+ }
+ }
+}