mirror of
https://github.com/team-infusion-developers/android_hardware_samsung.git
synced 2024-11-06 21:55:41 +00:00
samsung: doze: Allow to wake the screen on gestures instead of pulsing
Co-authored-by: Nauval Rizky <enuma.alrizky@gmail.com> Co-authored-by: Fabian Leutenegger <fabian.leutenegger@bluewin.ch> Change-Id: I1e74f8eafa51843e77d2d8c514c646a4494327cd
This commit is contained in:
parent
67e48ea301
commit
c143344242
4 changed files with 31 additions and 4 deletions
|
@ -24,6 +24,12 @@
|
|||
android:summary="@string/ambient_display_always_on_summary"
|
||||
android:persistent="false" />
|
||||
|
||||
<SwitchPreference
|
||||
android:key="wake_on_gesture"
|
||||
android:defaultValue="false"
|
||||
android:title="@string/wake_on_gesture_title"
|
||||
android:summary="@string/wake_on_gesture_summary" />
|
||||
|
||||
<PreferenceCategory
|
||||
android:key="proximity_sensor"
|
||||
android:title="@string/proximity_sensor_title">
|
||||
|
|
|
@ -27,6 +27,7 @@ import android.hardware.SensorEventListener;
|
|||
import android.hardware.SensorManager;
|
||||
import android.os.IBinder;
|
||||
import android.os.PowerManager;
|
||||
import android.os.SystemClock;
|
||||
import android.os.UserHandle;
|
||||
import android.util.Log;
|
||||
|
||||
|
@ -72,7 +73,7 @@ public class SamsungDozeService extends Service {
|
|||
boolean isNear = event.values[0] < mSensor.getMaximumRange();
|
||||
if (mSawNear && !isNear) {
|
||||
if (shouldPulse(event.timestamp)) {
|
||||
launchDozePulse();
|
||||
wakeOrLaunchDozePulse();
|
||||
}
|
||||
} else {
|
||||
mInPocketTime = event.timestamp;
|
||||
|
@ -140,9 +141,16 @@ public class SamsungDozeService extends Service {
|
|||
return null;
|
||||
}
|
||||
|
||||
private void launchDozePulse() {
|
||||
mContext.sendBroadcastAsUser(new Intent(DOZE_INTENT),
|
||||
new UserHandle(UserHandle.USER_CURRENT));
|
||||
private void wakeOrLaunchDozePulse() {
|
||||
if (Utils.isWakeOnGestureEnabled(mContext)) {
|
||||
if (DEBUG) Log.d(TAG, "Wake up display");
|
||||
PowerManager powerManager = mContext.getSystemService(PowerManager.class);
|
||||
powerManager.wakeUp(SystemClock.uptimeMillis(), PowerManager.WAKE_REASON_GESTURE, TAG);
|
||||
} else {
|
||||
if (DEBUG) Log.d(TAG, "Launch doze pulse");
|
||||
mContext.sendBroadcastAsUser(
|
||||
new Intent(DOZE_INTENT), new UserHandle(UserHandle.USER_CURRENT));
|
||||
}
|
||||
}
|
||||
|
||||
private boolean isInteractive() {
|
||||
|
|
|
@ -43,6 +43,7 @@ public class SamsungDozeSettings extends PreferenceFragment
|
|||
private SwitchPreference mAlwaysOnDisplayPreference;
|
||||
private SwitchPreference mHandwavePreference;
|
||||
private SwitchPreference mPocketPreference;
|
||||
private SwitchPreference mWakeOnGesturePreference;
|
||||
|
||||
private Handler mHandler = new Handler();
|
||||
|
||||
|
@ -67,12 +68,17 @@ public class SamsungDozeSettings extends PreferenceFragment
|
|||
mPocketPreference.setEnabled(dozeEnabled);
|
||||
mPocketPreference.setOnPreferenceChangeListener(this);
|
||||
|
||||
mWakeOnGesturePreference = (SwitchPreference) findPreference(Utils.WAKE_ON_GESTURE_KEY);
|
||||
mWakeOnGesturePreference.setEnabled(dozeEnabled);
|
||||
mWakeOnGesturePreference.setOnPreferenceChangeListener(this);
|
||||
|
||||
// Hide AOD if not supported and set all its dependents otherwise
|
||||
if (!Utils.alwaysOnDisplayAvailable(getActivity())) {
|
||||
getPreferenceScreen().removePreference(mAlwaysOnDisplayPreference);
|
||||
} else {
|
||||
mHandwavePreference.setDependency(Utils.ALWAYS_ON_DISPLAY);
|
||||
mPocketPreference.setDependency(Utils.ALWAYS_ON_DISPLAY);
|
||||
mWakeOnGesturePreference.setDependency(Utils.ALWAYS_ON_DISPLAY);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -143,6 +149,7 @@ public class SamsungDozeSettings extends PreferenceFragment
|
|||
|
||||
mHandwavePreference.setEnabled(isChecked);
|
||||
mPocketPreference.setEnabled(isChecked);
|
||||
mWakeOnGesturePreference.setEnabled(isChecked);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -38,6 +38,7 @@ public final class Utils {
|
|||
|
||||
protected static final String GESTURE_HAND_WAVE_KEY = "gesture_hand_wave";
|
||||
protected static final String GESTURE_POCKET_KEY = "gesture_pocket";
|
||||
protected static final String WAKE_ON_GESTURE_KEY = "wake_on_gesture";
|
||||
|
||||
protected static void startService(Context context) {
|
||||
if (DEBUG) Log.d(TAG, "Starting service");
|
||||
|
@ -101,4 +102,9 @@ public final class Utils {
|
|||
return PreferenceManager.getDefaultSharedPreferences(context)
|
||||
.getBoolean(GESTURE_POCKET_KEY, false);
|
||||
}
|
||||
|
||||
protected static boolean isWakeOnGestureEnabled(Context context) {
|
||||
return PreferenceManager.getDefaultSharedPreferences(context)
|
||||
.getBoolean(WAKE_ON_GESTURE_KEY, false);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue