Do not listen for clock ticks, time changes, timezone changes, or time format changes when TextClock is not visible

BUG: 31840153
Change-Id: I11adf1036fb25b28aee5caba6daa1ab0d9d1f23a
This commit is contained in:
Erik Wolsheimer
2016-10-03 13:07:19 -07:00
parent a87ba31b70
commit e12cd3bb3b

View File

@@ -130,7 +130,7 @@ public class TextClock extends TextView {
private CharSequence mDescFormat;
private boolean mAttached;
private boolean mRegistered;
private Calendar mTime;
private String mTimeZone;
@@ -250,7 +250,7 @@ public class TextClock extends TextView {
}
createTime(mTimeZone);
// Wait until onAttachedToWindow() to handle the ticker
// Wait until registering for events to handle the ticker
chooseFormat(false);
}
@@ -501,7 +501,7 @@ public class TextClock extends TextView {
boolean hadSeconds = mHasSeconds;
mHasSeconds = DateFormat.hasSeconds(mFormat);
if (handleTicker && mAttached && hadSeconds != mHasSeconds) {
if (handleTicker && mRegistered && hadSeconds != mHasSeconds) {
if (hadSeconds) getHandler().removeCallbacks(mTicker);
else mTicker.run();
}
@@ -515,11 +515,9 @@ public class TextClock extends TextView {
}
@Override
protected void onAttachedToWindow() {
super.onAttachedToWindow();
if (!mAttached) {
mAttached = true;
public void onVisibilityAggregated(boolean isVisible) {
if (!mRegistered && isVisible) {
mRegistered = true;
registerReceiver();
registerObserver();
@@ -531,20 +529,13 @@ public class TextClock extends TextView {
} else {
onTimeChanged();
}
}
}
@Override
protected void onDetachedFromWindow() {
super.onDetachedFromWindow();
if (mAttached) {
} else if (mRegistered && !isVisible) {
unregisterReceiver();
unregisterObserver();
getHandler().removeCallbacks(mTicker);
mAttached = false;
mRegistered = false;
}
}
@@ -567,7 +558,7 @@ public class TextClock extends TextView {
}
private void registerObserver() {
if (isAttachedToWindow()) {
if (mRegistered) {
if (mFormatChangeObserver == null) {
mFormatChangeObserver = new FormatChangeObserver(getHandler());
}