Move BT, NFC out of Conntection pref
Move BT, NFC preference out of Connection Preference, To Connected devices page. Because NFC and Android Beam are controlled by the same controller, Create each controller for those preference and leave the sharing part. Change-Id: I8bc303a5f487de9c667487119b49e1e4130aa80c Fixes: 72458929 Test: manually test, make RunSettingsRoboTests
This commit is contained in:
@@ -16,146 +16,35 @@
|
||||
package com.android.settings.nfc;
|
||||
|
||||
import android.content.Context;
|
||||
import android.database.ContentObserver;
|
||||
import android.net.Uri;
|
||||
import android.nfc.NfcAdapter;
|
||||
import android.nfc.NfcManager;
|
||||
import android.os.Handler;
|
||||
import android.provider.Settings;
|
||||
import android.support.v14.preference.SwitchPreference;
|
||||
import android.support.v7.preference.PreferenceScreen;
|
||||
import android.support.v14.preference.SwitchPreference;
|
||||
|
||||
import com.android.settings.core.PreferenceControllerMixin;
|
||||
import com.android.settingslib.RestrictedPreference;
|
||||
import com.android.settingslib.core.AbstractPreferenceController;
|
||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||
import com.android.settingslib.core.lifecycle.events.OnPause;
|
||||
import com.android.settingslib.core.lifecycle.events.OnResume;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public class NfcPreferenceController extends AbstractPreferenceController
|
||||
implements PreferenceControllerMixin, LifecycleObserver, OnResume, OnPause {
|
||||
public class NfcPreferenceController extends BaseNfcPreferenceController {
|
||||
|
||||
public static final String KEY_TOGGLE_NFC = "toggle_nfc";
|
||||
public static final String KEY_ANDROID_BEAM_SETTINGS = "android_beam_settings";
|
||||
|
||||
private NfcEnabler mNfcEnabler;
|
||||
private NfcAdapter mNfcAdapter;
|
||||
private int mAirplaneMode;
|
||||
private AirplaneModeObserver mAirplaneModeObserver;
|
||||
private SwitchPreference mNfcPreference;
|
||||
private RestrictedPreference mBeamPreference;
|
||||
|
||||
public NfcPreferenceController(Context context) {
|
||||
super(context);
|
||||
mNfcAdapter = NfcAdapter.getDefaultAdapter(context);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void displayPreference(PreferenceScreen screen) {
|
||||
super.displayPreference(screen);
|
||||
if (!isAvailable()) {
|
||||
setVisible(screen, KEY_TOGGLE_NFC, false /* visible */);
|
||||
setVisible(screen, KEY_ANDROID_BEAM_SETTINGS, false /* visible */);
|
||||
mNfcEnabler = null;
|
||||
return;
|
||||
}
|
||||
mNfcPreference = (SwitchPreference) screen.findPreference(KEY_TOGGLE_NFC);
|
||||
mBeamPreference = (RestrictedPreference) screen.findPreference(
|
||||
KEY_ANDROID_BEAM_SETTINGS);
|
||||
mNfcEnabler = new NfcEnabler(mContext, mNfcPreference, mBeamPreference);
|
||||
// Manually set dependencies for NFC when not toggleable.
|
||||
if (!isToggleableInAirplaneMode(mContext)) {
|
||||
mAirplaneModeObserver = new AirplaneModeObserver();
|
||||
updateNfcPreference();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateNonIndexableKeys(List<String> keys) {
|
||||
final NfcManager manager = (NfcManager) mContext.getSystemService(Context.NFC_SERVICE);
|
||||
if (manager != null) {
|
||||
NfcAdapter adapter = manager.getDefaultAdapter();
|
||||
if (adapter == null) {
|
||||
keys.add(KEY_TOGGLE_NFC);
|
||||
keys.add(KEY_ANDROID_BEAM_SETTINGS);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isAvailable() {
|
||||
return mNfcAdapter != null;
|
||||
mNfcEnabler = new NfcEnabler(mContext, (SwitchPreference) mPreference);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getPreferenceKey() {
|
||||
return null;
|
||||
return KEY_TOGGLE_NFC;
|
||||
}
|
||||
|
||||
public void onResume() {
|
||||
if (mAirplaneModeObserver != null) {
|
||||
mAirplaneModeObserver.register();
|
||||
}
|
||||
if (mNfcEnabler != null) {
|
||||
mNfcEnabler.resume();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPause() {
|
||||
if (mAirplaneModeObserver != null) {
|
||||
mAirplaneModeObserver.unregister();
|
||||
}
|
||||
if (mNfcEnabler != null) {
|
||||
mNfcEnabler.pause();
|
||||
}
|
||||
}
|
||||
|
||||
private void updateNfcPreference() {
|
||||
final int airplaneMode = Settings.Global.getInt(
|
||||
mContext.getContentResolver(), Settings.Global.AIRPLANE_MODE_ON, mAirplaneMode);
|
||||
if (airplaneMode == mAirplaneMode) {
|
||||
return;
|
||||
}
|
||||
mAirplaneMode = airplaneMode;
|
||||
boolean toggleable = mAirplaneMode != 1;
|
||||
if (toggleable) {
|
||||
mNfcAdapter.enable();
|
||||
} else {
|
||||
mNfcAdapter.disable();
|
||||
}
|
||||
mNfcPreference.setEnabled(toggleable);
|
||||
mBeamPreference.setEnabled(toggleable);
|
||||
}
|
||||
|
||||
public static boolean isToggleableInAirplaneMode(Context context) {
|
||||
String toggleable = Settings.Global.getString(context.getContentResolver(),
|
||||
Settings.Global.AIRPLANE_MODE_TOGGLEABLE_RADIOS);
|
||||
return toggleable != null && toggleable.contains(Settings.Global.RADIO_NFC);
|
||||
}
|
||||
|
||||
private final class AirplaneModeObserver extends ContentObserver {
|
||||
private final Uri AIRPLANE_MODE_URI =
|
||||
Settings.Global.getUriFor(Settings.Global.AIRPLANE_MODE_ON);
|
||||
|
||||
private AirplaneModeObserver() {
|
||||
super(new Handler());
|
||||
}
|
||||
|
||||
public void register() {
|
||||
mContext.getContentResolver().registerContentObserver(AIRPLANE_MODE_URI, false, this);
|
||||
}
|
||||
|
||||
public void unregister() {
|
||||
mContext.getContentResolver().unregisterContentObserver(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onChange(boolean selfChange, Uri uri) {
|
||||
super.onChange(selfChange, uri);
|
||||
updateNfcPreference();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user