Fix ColorInversionTile for secondary users

Bug: 17626692
Change-Id: I40354a460a7c00f6fd5eb05f7836dc89129fdacb
This commit is contained in:
Adrian Roos
2014-09-24 17:08:22 +02:00
parent bdc07b6986
commit 32d88e8ead
3 changed files with 20 additions and 9 deletions

View File

@@ -123,7 +123,7 @@ public abstract class QSTile<TState extends State> implements Listenable {
}
public void userSwitch(int newUserId) {
mHandler.obtainMessage(H.USER_SWITCH, newUserId).sendToTarget();
mHandler.obtainMessage(H.USER_SWITCH, newUserId, 0).sendToTarget();
}
public void fireToggleStateChanged(boolean state) {

View File

@@ -16,6 +16,7 @@
package com.android.systemui.qs;
import android.app.ActivityManager;
import android.content.Context;
import android.database.ContentObserver;
import android.os.Handler;
@@ -28,32 +29,33 @@ public abstract class SecureSetting extends ContentObserver implements Listenabl
private final Context mContext;
private final String mSettingName;
private boolean mListening;
private int mUserId;
protected abstract void handleValueChanged(int value);
public SecureSetting(Context context, Handler handler, String settingName) {
super(handler);
mContext = context;
mSettingName = settingName;
rebindForCurrentUser();
}
public void rebindForCurrentUser() {
mUserId = ActivityManager.getCurrentUser();
setListening(true);
}
public int getValue() {
return Secure.getInt(mContext.getContentResolver(), mSettingName, 0);
return Secure.getIntForUser(mContext.getContentResolver(), mSettingName, 0, mUserId);
}
public void setValue(int value) {
Secure.putInt(mContext.getContentResolver(), mSettingName, value);
Secure.putIntForUser(mContext.getContentResolver(), mSettingName, value, mUserId);
}
@Override
public void setListening(boolean listening) {
mListening = listening;
if (listening) {
mContext.getContentResolver().registerContentObserver(
Secure.getUriFor(mSettingName), false, this);
Secure.getUriFor(mSettingName), false, this, mUserId);
} else {
mContext.getContentResolver().unregisterContentObserver(this);
}
@@ -63,4 +65,12 @@ public abstract class SecureSetting extends ContentObserver implements Listenabl
public void onChange(boolean selfChange) {
handleValueChanged(getValue());
}
public void setUserId(int userId) {
mUserId = userId;
if (mListening) {
setListening(false);
setListening(true);
}
}
}

View File

@@ -71,7 +71,8 @@ public class ColorInversionTile extends QSTile<QSTile.BooleanState> {
@Override
protected void handleUserSwitch(int newUserId) {
mSetting.rebindForCurrentUser();
mSetting.setUserId(newUserId);
handleRefreshState(mSetting.getValue());
}
@Override