Fix ColorInversionTile for secondary users
Bug: 17626692 Change-Id: I40354a460a7c00f6fd5eb05f7836dc89129fdacb
This commit is contained in:
@@ -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) {
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user