diff options
author | Jeff Hamilton <jham@android.com> | 2011-09-21 16:44:36 -0500 |
---|---|---|
committer | Jeff Hamilton <jham@android.com> | 2011-09-22 12:35:55 -0500 |
commit | 3d670de5ce9180e0a75d0884832c4714cb56e1b5 (patch) | |
tree | 2e41eb2d978f3a1fd6e10c36bc1fe64b8c6e11ee /src/com/android/settings/nfc | |
parent | 7c430090c9a5033ad5ee91e968dab1618cf5eed3 (diff) | |
download | packages_apps_Settings-3d670de5ce9180e0a75d0884832c4714cb56e1b5.zip packages_apps_Settings-3d670de5ce9180e0a75d0884832c4714cb56e1b5.tar.gz packages_apps_Settings-3d670de5ce9180e0a75d0884832c4714cb56e1b5.tar.bz2 |
Bring back the Android Beam settings panel.
Bug: 5350022
Change-Id: I22d2c6f91f7ab86501021fe97a2d57b109ed10bf
Diffstat (limited to 'src/com/android/settings/nfc')
-rw-r--r-- | src/com/android/settings/nfc/AndroidBeam.java | 99 | ||||
-rw-r--r-- | src/com/android/settings/nfc/NfcEnabler.java | 19 |
2 files changed, 117 insertions, 1 deletions
diff --git a/src/com/android/settings/nfc/AndroidBeam.java b/src/com/android/settings/nfc/AndroidBeam.java new file mode 100644 index 0000000..a6bd037 --- /dev/null +++ b/src/com/android/settings/nfc/AndroidBeam.java @@ -0,0 +1,99 @@ +/* + * Copyright (C) 2011 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.settings.nfc; + +import android.app.ActionBar; +import android.app.Activity; +import android.app.Fragment; +import android.nfc.NfcAdapter; +import android.os.Bundle; +import android.os.Handler; +import android.preference.PreferenceActivity; +import android.view.Gravity; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; +import android.widget.CompoundButton; +import android.widget.ImageView; +import android.widget.Switch; +import com.android.settings.R; + +public class AndroidBeam extends Fragment + implements CompoundButton.OnCheckedChangeListener { + private View mView; + private ImageView mImageView; + private NfcAdapter mNfcAdapter; + private Switch mActionBarSwitch; + + + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + Activity activity = getActivity(); + + mActionBarSwitch = new Switch(activity); + + if (activity instanceof PreferenceActivity) { + PreferenceActivity preferenceActivity = (PreferenceActivity) activity; + if (preferenceActivity.onIsHidingHeaders() || !preferenceActivity.onIsMultiPane()) { + final int padding = activity.getResources().getDimensionPixelSize( + R.dimen.action_bar_switch_padding); + mActionBarSwitch.setPadding(0, 0, padding, 0); + activity.getActionBar().setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM, + ActionBar.DISPLAY_SHOW_CUSTOM); + activity.getActionBar().setCustomView(mActionBarSwitch, new ActionBar.LayoutParams( + ActionBar.LayoutParams.WRAP_CONTENT, + ActionBar.LayoutParams.WRAP_CONTENT, + Gravity.CENTER_VERTICAL | Gravity.RIGHT)); + activity.getActionBar().setTitle(R.string.android_beam_settings_title); + } + } + + mActionBarSwitch.setOnCheckedChangeListener(this); + + mNfcAdapter = NfcAdapter.getDefaultAdapter(getActivity()); + mActionBarSwitch.setChecked(mNfcAdapter.isNdefPushEnabled()); + } + + @Override + public View onCreateView(LayoutInflater inflater, ViewGroup container, + Bundle savedInstanceState) { + mView = inflater.inflate(R.layout.android_beam, container, false); + initView(mView); + return mView; + } + + private void initView(View view) { + mActionBarSwitch.setOnCheckedChangeListener(this); + mActionBarSwitch.setChecked(mNfcAdapter.isNdefPushEnabled()); + } + + @Override + public void onCheckedChanged(CompoundButton buttonView, boolean desiredState) { + boolean success = false; + mActionBarSwitch.setEnabled(false); + if (desiredState) { + success = mNfcAdapter.enableNdefPush(); + } else { + success = mNfcAdapter.disableNdefPush(); + } + if (success) { + mActionBarSwitch.setChecked(desiredState); + } + mActionBarSwitch.setEnabled(true); + } +} diff --git a/src/com/android/settings/nfc/NfcEnabler.java b/src/com/android/settings/nfc/NfcEnabler.java index c7a2d60..018b8ae 100644 --- a/src/com/android/settings/nfc/NfcEnabler.java +++ b/src/com/android/settings/nfc/NfcEnabler.java @@ -23,6 +23,9 @@ import android.content.IntentFilter; import android.nfc.NfcAdapter; import android.preference.CheckBoxPreference; import android.preference.Preference; +import android.preference.PreferenceScreen; + +import com.android.settings.R; /** * NfcEnabler is a helper to manage the Nfc on/off checkbox preference. It is @@ -32,6 +35,7 @@ import android.preference.Preference; public class NfcEnabler implements Preference.OnPreferenceChangeListener { private final Context mContext; private final CheckBoxPreference mCheckbox; + private final PreferenceScreen mAndroidBeam; private final NfcAdapter mNfcAdapter; private final IntentFilter mIntentFilter; @@ -46,14 +50,17 @@ public class NfcEnabler implements Preference.OnPreferenceChangeListener { } }; - public NfcEnabler(Context context, CheckBoxPreference checkBoxPreference) { + public NfcEnabler(Context context, CheckBoxPreference checkBoxPreference, + PreferenceScreen androidBeam) { mContext = context; mCheckbox = checkBoxPreference; + mAndroidBeam = androidBeam; mNfcAdapter = NfcAdapter.getDefaultAdapter(context); if (mNfcAdapter == null) { // NFC is not supported mCheckbox.setEnabled(false); + mAndroidBeam.setEnabled(false); mIntentFilter = null; return; } @@ -97,18 +104,28 @@ public class NfcEnabler implements Preference.OnPreferenceChangeListener { case NfcAdapter.STATE_OFF: mCheckbox.setChecked(false); mCheckbox.setEnabled(true); + mAndroidBeam.setEnabled(false); + mAndroidBeam.setSummary(R.string.android_beam_disabled_summary); break; case NfcAdapter.STATE_ON: mCheckbox.setChecked(true); mCheckbox.setEnabled(true); + mAndroidBeam.setEnabled(true); + if (mNfcAdapter.isNdefPushEnabled()) { + mAndroidBeam.setSummary(R.string.android_beam_on_summary); + } else { + mAndroidBeam.setSummary(R.string.android_beam_off_summary); + } break; case NfcAdapter.STATE_TURNING_ON: mCheckbox.setChecked(true); mCheckbox.setEnabled(false); + mAndroidBeam.setEnabled(false); break; case NfcAdapter.STATE_TURNING_OFF: mCheckbox.setChecked(false); mCheckbox.setEnabled(false); + mAndroidBeam.setEnabled(false); break; } } |