diff options
author | Joe Onorato <joeo@google.com> | 2010-11-26 13:19:58 -0800 |
---|---|---|
committer | Joe Onorato <joeo@google.com> | 2010-11-26 13:19:58 -0800 |
commit | a8e34189073c8f29f8e95db488b9a2a81019721e (patch) | |
tree | 553b77200560530071e8870d6c787a9ecf860478 | |
parent | 7750c2ac61d933cdb50114c2fc2e0a0c558a140e (diff) | |
download | frameworks_base-a8e34189073c8f29f8e95db488b9a2a81019721e.zip frameworks_base-a8e34189073c8f29f8e95db488b9a2a81019721e.tar.gz frameworks_base-a8e34189073c8f29f8e95db488b9a2a81019721e.tar.bz2 |
Start filling in the system settings panel.
Change-Id: I3384bb1cf6c2339d6136764635bb010ba096659b
6 files changed, 431 insertions, 6 deletions
diff --git a/packages/SystemUI/res/layout-xlarge/sysbar_panel_settings.xml b/packages/SystemUI/res/layout-xlarge/sysbar_panel_settings.xml index a800afb..8419f02 100644 --- a/packages/SystemUI/res/layout-xlarge/sysbar_panel_settings.xml +++ b/packages/SystemUI/res/layout-xlarge/sysbar_panel_settings.xml @@ -16,10 +16,155 @@ --> <com.android.systemui.statusbar.tablet.SettingsPanel - xmlns:android="http://schemas.android.com/apk/res/android" - android:layout_width="match_parent" - android:layout_height="200dip" - android:background="#ff000000" - > + xmlns:android="http://schemas.android.com/apk/res/android" + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:orientation="vertical" + android:background="@drawable/status_bar_item_background" + android:paddingLeft="16dp" + > + + <!-- Airplane mode --> + <LinearLayout + android:id="@+id/airplane" + style="@style/StatusBarPanelSettingsRow" + > + <ImageView + android:id="@+id/airplane_icon" + style="@style/StatusBarPanelSettingsIcon" + android:src="@drawable/ic_sysbar_airplane_on" + /> + <TextView + android:id="@+id/airplane_label" + style="@style/StatusBarPanelSettingsContents" + android:text="@string/system_panel_airplane" + /> + <CheckBox + android:id="@+id/airplane_checkbox" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_gravity="center_vertical" + /> + </LinearLayout> + <View style="@style/StatusBarPanelSettingsPanelSeparator" /> + + <!-- Network --> + <LinearLayout + android:id="@+id/network" + style="@style/StatusBarPanelSettingsRow" + > + <ImageView + android:id="@+id/network_icon" + style="@style/StatusBarPanelSettingsIcon" + android:src="@drawable/ic_sysbar_wifi_on" + /> + <TextView + android:id="@+id/network_label" + style="@style/StatusBarPanelSettingsContents" + /> + <ImageView + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_gravity="top" + android:layout_marginTop="16dp" + android:layout_marginRight="8dp" + android:src="@drawable/ic_notification_open" + /> + </LinearLayout> + <View style="@style/StatusBarPanelSettingsPanelSeparator" /> + + <!-- Rotation lock --> + <LinearLayout + android:id="@+id/rotate" + style="@style/StatusBarPanelSettingsRow" + > + <ImageView + android:id="@+id/rotate_icon" + style="@style/StatusBarPanelSettingsIcon" + android:src="@drawable/ic_sysbar_rotate_on" + /> + <TextView + android:id="@+id/rotate_label" + style="@style/StatusBarPanelSettingsContents" + android:text="@string/system_panel_rotation_lock" + /> + <CheckBox + android:id="@+id/rotate_checkbox" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_gravity="center_vertical" + /> + </LinearLayout> + <View style="@style/StatusBarPanelSettingsPanelSeparator" /> + + <!-- Brightness --> + <LinearLayout style="@style/StatusBarPanelSettingsRow" > + <ImageView + android:id="@+id/brightness_icon" + style="@style/StatusBarPanelSettingsIcon" + android:src="@drawable/ic_sysbar_brightness" + /> + </LinearLayout> + <View style="@style/StatusBarPanelSettingsPanelSeparator" /> + + <!-- Volume --> + <LinearLayout style="@style/StatusBarPanelSettingsRow" > + <ImageView + android:id="@+id/volume_icon" + style="@style/StatusBarPanelSettingsIcon" + android:src="@drawable/ic_sysbar_sound_on" + /> + </LinearLayout> + <View style="@style/StatusBarPanelSettingsPanelSeparator" /> + + <!-- Notifications / Do not disturb --> + <LinearLayout + android:id="@+id/do_not_disturb" + style="@style/StatusBarPanelSettingsRow" + > + <ImageView + android:id="@+id/do_not_disturb_icon" + style="@style/StatusBarPanelSettingsIcon" + android:src="@drawable/ic_sysbar_gps_on" + /> + <TextView + style="@style/StatusBarPanelSettingsContents" + android:text="@string/system_panel_notifications" + /> + <CheckBox + android:id="@+id/do_not_disturb_checkbox" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_gravity="center_vertical" + /> + </LinearLayout> + <View style="@style/StatusBarPanelSettingsPanelSeparator" /> + + <!-- Link to settings --> + <LinearLayout + android:id="@+id/settings" + style="@style/StatusBarPanelSettingsRow" + > + + <ImageView + android:id="@+id/settings" + style="@style/StatusBarPanelSettingsIcon" + android:src="@drawable/ic_sysbar_quicksettings" + /> + <TextView + style="@style/StatusBarPanelSettingsContents" + android:text="@string/system_panel_settings_button" + /> + <ImageView + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_gravity="top" + android:layout_marginTop="16dp" + android:layout_marginRight="8dp" + android:src="@drawable/ic_notification_open" + /> + </LinearLayout> + <View style="@style/StatusBarPanelSettingsPanelSeparator" /> + </com.android.systemui.statusbar.tablet.SettingsPanel> diff --git a/packages/SystemUI/res/values-xlarge/styles.xml b/packages/SystemUI/res/values-xlarge/styles.xml new file mode 100644 index 0000000..78c1988 --- /dev/null +++ b/packages/SystemUI/res/values-xlarge/styles.xml @@ -0,0 +1,45 @@ +<?xml version="1.0" encoding="utf-8"?> +<!-- Copyright (C) 2010 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. +--> + +<resources xmlns:android="http://schemas.android.com/apk/res/android"> + + <style name="StatusBarPanelSettingsRow"> + <item name="android:layout_height">64dp</item> + <item name="android:layout_width">match_parent</item> + <item name="android:orientation">horizontal</item> + </style> + + <style name="StatusBarPanelSettingsIcon"> + <item name="android:layout_height">match_parent</item> + <item name="android:layout_width">64dp</item> + <item name="android:scaleType">center</item> + </style> + + <style name="StatusBarPanelSettingsContents"> + <item name="android:layout_height">wrap_content</item> + <item name="android:layout_width">0dp</item> + <item name="android:layout_weight">1</item> + <item name="android:layout_gravity">left|center_vertical</item> + <item name="android:textColor">?android:attr/textColorPrimary</item> + </style> + + <style name="StatusBarPanelSettingsPanelSeparator"> + <item name="android:layout_width">match_parent</item> + <item name="android:layout_height">1dp</item> + <item name="android:background">@android:drawable/divider_horizontal_dark</item> + </style> + +</resources> diff --git a/packages/SystemUI/res/values/strings.xml b/packages/SystemUI/res/values/strings.xml index e8c3c91..8c38e46 100644 --- a/packages/SystemUI/res/values/strings.xml +++ b/packages/SystemUI/res/values/strings.xml @@ -74,6 +74,15 @@ <!-- Name of the button that links to the Settings app. [CHAR LIMIT=NONE] --> <string name="system_panel_settings_button">Settings</string> + <!-- Label in the system panel for airplane mode (all radios are turned off)[CHAR LIMIT=30] --> + <string name="system_panel_airplane">Airplane mode</string> + + <!-- Label in system panel saying the device will use the orientation sensor to rotate [CHAR LIMIT=30] --> + <string name="system_panel_rotation_lock">Lock screen orientation</string> + + <!-- Label in system panel saying the device will show notifications [CHAR LIMIT=30] --> + <string name="system_panel_notifications">Notifications</string> + <!-- Text to display next to the graphical battery meter. [CHAR LIMIT=3] --> <string name="system_panel_battery_meter_format" translatable="false"> <xliff:g id="number">%d</xliff:g><xliff:g id="percent">%%</xliff:g> diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/policy/AirplaneModeController.java b/packages/SystemUI/src/com/android/systemui/statusbar/policy/AirplaneModeController.java new file mode 100644 index 0000000..da60f0d --- /dev/null +++ b/packages/SystemUI/src/com/android/systemui/statusbar/policy/AirplaneModeController.java @@ -0,0 +1,92 @@ +/* + * Copyright (C) 2010 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.systemui.statusbar.policy; + +import android.content.BroadcastReceiver; +import android.content.ContentResolver; +import android.content.Context; +import android.content.Intent; +import android.content.IntentFilter; +import android.os.RemoteException; +import android.os.ServiceManager; +import android.provider.Settings; +import android.util.Slog; +import android.widget.CompoundButton; + +public class AirplaneModeController extends BroadcastReceiver + implements CompoundButton.OnCheckedChangeListener { + private static final String TAG = "StatusBar.AirplaneModeController"; + + private Context mContext; + private CompoundButton mCheckBox; + + private boolean mAirplaneMode; + + public AirplaneModeController(Context context, CompoundButton checkbox) { + mContext = context; + mAirplaneMode = getAirplaneMode(); + mCheckBox = checkbox; + checkbox.setChecked(mAirplaneMode); + checkbox.setOnCheckedChangeListener(this); + + IntentFilter filter = new IntentFilter(); + filter.addAction(Intent.ACTION_AIRPLANE_MODE_CHANGED); + context.registerReceiver(this, filter); + + } + + public void release() { + mContext.unregisterReceiver(this); + } + + public void onCheckedChanged(CompoundButton view, boolean checked) { + Slog.d(TAG, "onCheckedChanged checked=" + checked + " mAirplaneMode=" + mAirplaneMode); + if (checked != mAirplaneMode) { + mAirplaneMode = checked; + unsafe(checked); + } + } + + public void onReceive(Context context, Intent intent) { + if (Intent.ACTION_AIRPLANE_MODE_CHANGED.equals(intent.getAction())) { + final boolean enabled = intent.getBooleanExtra("state", false); + if (enabled != mAirplaneMode) { + mAirplaneMode = enabled; + mCheckBox.setChecked(enabled); + } + } + } + + private boolean getAirplaneMode() { + ContentResolver cr = mContext.getContentResolver(); + return 0 != Settings.System.getInt(cr, Settings.System.AIRPLANE_MODE_ON, 0); + } + + // TODO: Fix this racy API by adding something better to TelephonyManager or + // ConnectivityService. + private void unsafe(boolean enabled) { + Settings.System.putInt( + mContext.getContentResolver(), + Settings.System.AIRPLANE_MODE_ON, + enabled ? 1 : 0); + Intent intent = new Intent(Intent.ACTION_AIRPLANE_MODE_CHANGED); + intent.addFlags(Intent.FLAG_RECEIVER_REPLACE_PENDING); + intent.putExtra("state", enabled); + mContext.sendBroadcast(intent); + } +} + diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/policy/AutoRotateController.java b/packages/SystemUI/src/com/android/systemui/statusbar/policy/AutoRotateController.java new file mode 100644 index 0000000..866e5fc --- /dev/null +++ b/packages/SystemUI/src/com/android/systemui/statusbar/policy/AutoRotateController.java @@ -0,0 +1,73 @@ +/* + * Copyright (C) 2010 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.systemui.statusbar.policy; + +import android.content.ContentResolver; +import android.content.Context; +import android.os.RemoteException; +import android.os.ServiceManager; +import android.provider.Settings; +import android.util.Slog; +import android.view.IWindowManager; +import android.widget.CompoundButton; + +/** + * TODO: Listen for changes to the setting. + */ +public class AutoRotateController implements CompoundButton.OnCheckedChangeListener { + private static final String TAG = "StatusBar.AutoRotateController"; + + private Context mContext; + private CompoundButton mCheckBox; + + private boolean mLockRotation; + + public AutoRotateController(Context context, CompoundButton checkbox) { + mContext = context; + mLockRotation = getLockRotation(); + mCheckBox = checkbox; + checkbox.setChecked(mLockRotation); + checkbox.setOnCheckedChangeListener(this); + } + + public void onCheckedChanged(CompoundButton view, boolean checked) { + Slog.d(TAG, "onCheckedChanged checked=" + checked + " mLockRotation=" + mLockRotation); + if (checked != mLockRotation) { + setLockRotation(checked); + } + } + + private boolean getLockRotation() { + ContentResolver cr = mContext.getContentResolver(); + return 0 == Settings.System.getInt(cr, Settings.System.ACCELEROMETER_ROTATION, 0); + } + + private void setLockRotation(boolean locked) { + mLockRotation = locked; + try { + IWindowManager wm = IWindowManager.Stub.asInterface(ServiceManager.getService( + Context.WINDOW_SERVICE)); + ContentResolver cr = mContext.getContentResolver(); + if (locked) { + wm.freezeRotation(); + } else { + wm.thawRotation(); + } + } catch (RemoteException exc) { + } + } +} diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/tablet/SettingsPanel.java b/packages/SystemUI/src/com/android/systemui/statusbar/tablet/SettingsPanel.java index 9013f5c..fea326e 100644 --- a/packages/SystemUI/src/com/android/systemui/statusbar/tablet/SettingsPanel.java +++ b/packages/SystemUI/src/com/android/systemui/statusbar/tablet/SettingsPanel.java @@ -16,17 +16,28 @@ package com.android.systemui.statusbar.tablet; +import android.app.StatusBarManager; import android.content.Context; +import android.content.Intent; +import android.provider.Settings; import android.util.AttributeSet; import android.util.Slog; import android.widget.LinearLayout; import android.view.View; +import android.widget.CompoundButton; +import android.widget.ImageView; +import android.widget.TextView; import com.android.systemui.R; +import com.android.systemui.statusbar.policy.AirplaneModeController; +import com.android.systemui.statusbar.policy.AutoRotateController; -public class SettingsPanel extends LinearLayout { +public class SettingsPanel extends LinearLayout implements View.OnClickListener { static final String TAG = "SettingsPanel"; + AirplaneModeController mAirplane; + AutoRotateController mRotate; + public SettingsPanel(Context context, AttributeSet attrs) { this(context, attrs, 0); } @@ -34,5 +45,55 @@ public class SettingsPanel extends LinearLayout { public SettingsPanel(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } + + @Override + protected void onFinishInflate() { + super.onFinishInflate(); + + final Context context = getContext(); + + mAirplane = new AirplaneModeController(context, + (CompoundButton)findViewById(R.id.airplane_checkbox)); + findViewById(R.id.network).setOnClickListener(this); + mRotate = new AutoRotateController(context, + (CompoundButton)findViewById(R.id.rotate_checkbox)); + findViewById(R.id.settings).setOnClickListener(this); + } + + @Override + protected void onDetachedFromWindow() { + super.onDetachedFromWindow(); + mAirplane.release(); + } + + public void onClick(View v) { + switch (v.getId()) { + case R.id.network: + onClickNetwork(); + break; + case R.id.settings: + onClickSettings(); + break; + } + } + + private StatusBarManager getStatusBarManager() { + return (StatusBarManager)getContext().getSystemService(Context.STATUS_BAR_SERVICE); + } + + // Network + // ---------------------------- + private void onClickNetwork() { + Slog.d(TAG, "onClickNetwork"); + } + + // Settings + // ---------------------------- + private void onClickSettings() { + Slog.d(TAG, "onClickSettings"); + getContext().startActivity(new Intent(Settings.ACTION_SETTINGS) + .setFlags(Intent.FLAG_ACTIVITY_NEW_TASK)); + getStatusBarManager().collapse(); + } } |