diff options
author | Alan Viverette <alanv@google.com> | 2015-01-26 15:34:56 -0800 |
---|---|---|
committer | Alan Viverette <alanv@google.com> | 2015-01-26 15:34:56 -0800 |
commit | 5efe0d199e9a6133af355ace6e4b52b82a65af6e (patch) | |
tree | 9121c054b0a3646bb2d28d74f4cdae0591b4c51c /core/java/android/widget/RadialTimePickerView.java | |
parent | de8d28405538128fad55e34dc7c74fd49a909ae6 (diff) | |
download | frameworks_base-5efe0d199e9a6133af355ace6e4b52b82a65af6e.zip frameworks_base-5efe0d199e9a6133af355ace6e4b52b82a65af6e.tar.gz frameworks_base-5efe0d199e9a6133af355ace6e4b52b82a65af6e.tar.bz2 |
Convert getHourForDegrees result to 12-hour format when needed
Also prevents the selector from jumping between the inner and outer
circle during touch exploration in 24-hour mode.
Bug: 19101918
Change-Id: If342056b378927397f8651dad5e8d806bcda03a6
Diffstat (limited to 'core/java/android/widget/RadialTimePickerView.java')
-rw-r--r-- | core/java/android/widget/RadialTimePickerView.java | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/core/java/android/widget/RadialTimePickerView.java b/core/java/android/widget/RadialTimePickerView.java index 7b64cf5..11fda2c 100644 --- a/core/java/android/widget/RadialTimePickerView.java +++ b/core/java/android/widget/RadialTimePickerView.java @@ -1381,11 +1381,19 @@ public class RadialTimePickerView extends View implements View.OnTouchListener { @Override protected int getVirtualViewAt(float x, float y) { final int id; + + // Calling getDegreesXY() has side-effects, so we need to cache the + // current inner circle value and restore after the call. + final boolean wasOnInnerCircle = mIsOnInnerCircle; final int degrees = getDegreesFromXY(x, y); + final boolean isOnInnerCircle = mIsOnInnerCircle; + mIsOnInnerCircle = wasOnInnerCircle; + if (degrees != -1) { final int snapDegrees = snapOnly30s(degrees, 0) % 360; if (mShowHours) { - final int hour = getHourForDegrees(snapDegrees, mIsOnInnerCircle); + final int hour24 = getHourForDegrees(snapDegrees, isOnInnerCircle); + final int hour = mIs24HourMode ? hour24 : hour24To12(hour24); id = makeId(TYPE_HOUR, hour); } else { final int current = getCurrentMinute(); @@ -1514,6 +1522,16 @@ public class RadialTimePickerView extends View implements View.OnTouchListener { return hour24; } + private int hour24To12(int hour24) { + if (hour24 == 0) { + return 12; + } else if (hour24 > 12) { + return hour24 - 12; + } else { + return hour24; + } + } + private void getBoundsForVirtualView(int virtualViewId, Rect bounds) { final float radius; final int type = getTypeFromId(virtualViewId); |