diff options
author | Ady Abraham <adyabr@google.com> | 2019-11-20 11:13:30 -0800 |
---|---|---|
committer | Ady Abraham <adyabr@google.com> | 2019-12-17 18:20:52 -0800 |
commit | 678e187b8c89e4698abb9f15427e730abf5af25d (patch) | |
tree | dbe923b531ac61127df2686f7319f42e4bf181ae /src/com/android/settings/development/ShowRefreshRatePreferenceController.java | |
parent | 01cf29b958b447fbaa5b27eb6bf9be122d746cba (diff) |
Settings: add a new developer menu entry to show refresh rate overlay
The refresh rate overlay will be shown on screen if the option is
selected from the developer option.
Test: enable show refresh rate from developer menu
Bug: 129297325
Change-Id: Ic7b59fa93e1ca1e5649501eb87bda64c7a868fa1
Diffstat (limited to 'src/com/android/settings/development/ShowRefreshRatePreferenceController.java')
-rw-r--r-- | src/com/android/settings/development/ShowRefreshRatePreferenceController.java | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/src/com/android/settings/development/ShowRefreshRatePreferenceController.java b/src/com/android/settings/development/ShowRefreshRatePreferenceController.java new file mode 100644 index 0000000000..e56268d4c6 --- /dev/null +++ b/src/com/android/settings/development/ShowRefreshRatePreferenceController.java @@ -0,0 +1,124 @@ +/* + * Copyright 2019 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.IBinder; +import android.os.Parcel; +import android.os.RemoteException; +import android.os.ServiceManager; + +import androidx.annotation.VisibleForTesting; +import androidx.preference.Preference; +import androidx.preference.SwitchPreference; + +import com.android.settings.core.PreferenceControllerMixin; +import com.android.settingslib.development.DeveloperOptionsPreferenceController; + +/** + * Controller class for controlling the refresh rate overlay on SurfaceFlinger + */ +public class ShowRefreshRatePreferenceController extends DeveloperOptionsPreferenceController + implements Preference.OnPreferenceChangeListener, PreferenceControllerMixin { + + private static final String SHOW_REFRESH_RATE_KEY = "show_refresh_rate"; + + private static final int SETTING_VALUE_QUERY = 2; + private static final int SETTING_VALUE_ON = 1; + private static final int SETTING_VALUE_OFF = 0; + + @VisibleForTesting + static final String SURFACE_FLINGER_SERVICE_KEY = "SurfaceFlinger"; + @VisibleForTesting + static final int SURFACE_FLINGER_CODE = 1034; + + private static final String SURFACE_COMPOSER_INTERFACE_KEY = "android.ui.ISurfaceComposer"; + + private final IBinder mSurfaceFlinger; + + public ShowRefreshRatePreferenceController(Context context) { + super(context); + mSurfaceFlinger = ServiceManager.getService(SURFACE_FLINGER_SERVICE_KEY); + } + + @Override + public String getPreferenceKey() { + return SHOW_REFRESH_RATE_KEY; + } + + @Override + public boolean onPreferenceChange(Preference preference, Object newValue) { + final boolean isEnabled = (Boolean) newValue; + writeShowRefreshRateSetting(isEnabled); + return true; + } + + @Override + public void updateState(Preference preference) { + updateShowRefreshRateSetting(); + } + + @Override + protected void onDeveloperOptionsSwitchDisabled() { + super.onDeveloperOptionsSwitchDisabled(); + final SwitchPreference preference = (SwitchPreference) mPreference; + if (preference.isChecked()) { + // Writing false to the preference when the setting is already off will have a + // side effect of turning on the preference that we wish to avoid + writeShowRefreshRateSetting(false); + preference.setChecked(false); + } + } + + @VisibleForTesting + void updateShowRefreshRateSetting() { + // magic communication with surface flinger. + try { + if (mSurfaceFlinger != null) { + final Parcel data = Parcel.obtain(); + final Parcel reply = Parcel.obtain(); + data.writeInterfaceToken(SURFACE_COMPOSER_INTERFACE_KEY); + data.writeInt(SETTING_VALUE_QUERY); + mSurfaceFlinger.transact(SURFACE_FLINGER_CODE, data, reply, 0 /* flags */); + final boolean enabled = reply.readBoolean(); + ((SwitchPreference) mPreference).setChecked(enabled); + reply.recycle(); + data.recycle(); + } + } catch (RemoteException ex) { + // intentional no-op + } + } + + @VisibleForTesting + void writeShowRefreshRateSetting(boolean isEnabled) { + try { + if (mSurfaceFlinger != null) { + final Parcel data = Parcel.obtain(); + data.writeInterfaceToken(SURFACE_COMPOSER_INTERFACE_KEY); + final int showRefreshRate = isEnabled ? SETTING_VALUE_ON : SETTING_VALUE_OFF; + data.writeInt(showRefreshRate); + mSurfaceFlinger.transact(SURFACE_FLINGER_CODE, data, + null /* reply */, 0 /* flags */); + data.recycle(); + } + } catch (RemoteException ex) { + // intentional no-op + } + updateShowRefreshRateSetting(); + } +} |