summaryrefslogtreecommitdiffstats
path: root/packages
diff options
context:
space:
mode:
authorDaniel Sandler <dsandler@android.com>2012-06-05 13:44:14 -0400
committerDaniel Sandler <dsandler@android.com>2012-06-07 01:10:11 -0400
commit3d32a24adf02cecca86ec16ac8827ce195daeaec (patch)
tree56ff15d44c8e82003990edaf4ec63c3648ca4184 /packages
parent37e0c3681ef403e5a43a4f3dbca954ec8a4bfb5d (diff)
downloadframeworks_base-3d32a24adf02cecca86ec16ac8827ce195daeaec.zip
frameworks_base-3d32a24adf02cecca86ec16ac8827ce195daeaec.tar.gz
frameworks_base-3d32a24adf02cecca86ec16ac8827ce195daeaec.tar.bz2
Back from the dead: Carrier name, background dimming.
Unlike previous versions of Android, we now show the current wifi SSID in the carrier label if connected to wifi. Bug: 6612419 Bug: 6620626 Change-Id: Ifb5ba8efe6dd387e960efc6a9b1da69a08e97d96
Diffstat (limited to 'packages')
-rw-r--r--packages/SystemUI/res/layout/status_bar_expanded.xml11
-rw-r--r--packages/SystemUI/res/values/dimens.xml5
-rw-r--r--packages/SystemUI/res/values/styles.xml4
-rw-r--r--packages/SystemUI/src/com/android/systemui/statusbar/phone/PhoneStatusBar.java93
-rw-r--r--packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java11
-rw-r--r--packages/SystemUI/src/com/android/systemui/statusbar/policy/NotificationRowLayout.java15
-rw-r--r--packages/SystemUI/src/com/android/systemui/statusbar/policy/OnSizeChangedListener.java23
7 files changed, 152 insertions, 10 deletions
diff --git a/packages/SystemUI/res/layout/status_bar_expanded.xml b/packages/SystemUI/res/layout/status_bar_expanded.xml
index 0966a28..47e5b71 100644
--- a/packages/SystemUI/res/layout/status_bar_expanded.xml
+++ b/packages/SystemUI/res/layout/status_bar_expanded.xml
@@ -29,6 +29,17 @@
android:layout_marginLeft="@dimen/notification_panel_margin_left"
>
+ <TextView
+ android:id="@+id/carrier_label"
+ android:textAppearance="@style/TextAppearance.StatusBar.Expanded.Network"
+ android:layout_height="@dimen/carrier_label_height"
+ android:layout_width="match_parent"
+ android:layout_gravity="bottom"
+ android:layout_marginBottom="@dimen/close_handle_height"
+ android:gravity="center"
+ android:visibility="invisible"
+ />
+
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
diff --git a/packages/SystemUI/res/values/dimens.xml b/packages/SystemUI/res/values/dimens.xml
index 0b362d1..3ed63ed 100644
--- a/packages/SystemUI/res/values/dimens.xml
+++ b/packages/SystemUI/res/values/dimens.xml
@@ -133,7 +133,7 @@
<dimen name="notification_panel_header_height">48dp</dimen>
<!-- Extra space above the panel -->
- <dimen name="notification_panel_padding_top">4dp</dimen>
+ <dimen name="notification_panel_padding_top">0dp</dimen>
<!-- Extra space above the clock in the panel -->
<dimen name="notification_panel_header_padding_top">0dp</dimen>
@@ -145,4 +145,7 @@
<!-- Gravity for the notification panel -->
<!-- 0x37 = fill_horizontal|top -->
<integer name="notification_panel_layout_gravity">0x37</integer>
+
+ <!-- Height of the carrier/wifi name label -->
+ <dimen name="carrier_label_height">24dp</dimen>
</resources>
diff --git a/packages/SystemUI/res/values/styles.xml b/packages/SystemUI/res/values/styles.xml
index a23fe12..1d5bf3c 100644
--- a/packages/SystemUI/res/values/styles.xml
+++ b/packages/SystemUI/res/values/styles.xml
@@ -63,6 +63,10 @@
<item name="android:textAllCaps">true</item>
</style>
+ <style name="TextAppearance.StatusBar.Expanded.Network" parent="@style/TextAppearance.StatusBar.Expanded.Date">
+ <item name="android:textColor">#999999</item>
+ </style>
+
<style name="Animation" />
<style name="Animation.ShirtPocketPanel">
diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/phone/PhoneStatusBar.java b/packages/SystemUI/src/com/android/systemui/statusbar/phone/PhoneStatusBar.java
index 10bb889..0fad7c3 100644
--- a/packages/SystemUI/src/com/android/systemui/statusbar/phone/PhoneStatusBar.java
+++ b/packages/SystemUI/src/com/android/systemui/statusbar/phone/PhoneStatusBar.java
@@ -17,6 +17,7 @@
package com.android.systemui.statusbar.phone;
import android.animation.Animator;
+import android.animation.Animator.AnimatorListener;
import android.animation.AnimatorListenerAdapter;
import android.animation.AnimatorSet;
import android.animation.ObjectAnimator;
@@ -85,6 +86,7 @@ import com.android.systemui.statusbar.policy.BatteryController;
import com.android.systemui.statusbar.policy.DateView;
import com.android.systemui.statusbar.policy.IntruderAlertView;
import com.android.systemui.statusbar.policy.LocationController;
+import com.android.systemui.statusbar.policy.OnSizeChangedListener;
import com.android.systemui.statusbar.policy.NetworkController;
import com.android.systemui.statusbar.policy.NotificationRowLayout;
@@ -104,7 +106,8 @@ public class PhoneStatusBar extends BaseStatusBar {
public static final String ACTION_STATUSBAR_START
= "com.android.internal.policy.statusbar.START";
- private static final boolean DIM_BEHIND_EXPANDED_PANEL = false;
+ private static final boolean DIM_BEHIND_EXPANDED_PANEL = true;
+ private static final boolean SHOW_CARRIER_LABEL = true;
private static final int MSG_OPEN_NOTIFICATION_PANEL = 1000;
private static final int MSG_CLOSE_NOTIFICATION_PANEL = 1001;
@@ -169,6 +172,11 @@ public class PhoneStatusBar extends BaseStatusBar {
View mSettingsButton;
RotationToggle mRotationButton;
+ // carrier/wifi label
+ private TextView mCarrierLabel;
+ private boolean mCarrierLabelVisible = false;
+ private int mCarrierLabelHeight;
+
// drag bar
CloseDragHandle mCloseView;
private int mCloseViewHeight;
@@ -386,6 +394,14 @@ public class PhoneStatusBar extends BaseStatusBar {
mPile = (NotificationRowLayout)mStatusBarWindow.findViewById(R.id.latestItems);
mPile.setLongPressListener(getNotificationLongClicker());
+ if (SHOW_CARRIER_LABEL) {
+ mPile.setOnSizeChangedListener(new OnSizeChangedListener() {
+ @Override
+ public void onSizeChanged(View view, int w, int h, int oldw, int oldh) {
+ updateCarrierLabelVisibility();
+ }
+ });
+ }
mExpandedContents = mPile; // was: expanded.findViewById(R.id.notificationLinearLayout);
mClearButton = mStatusBarWindow.findViewById(R.id.clear_all_button);
@@ -397,6 +413,9 @@ public class PhoneStatusBar extends BaseStatusBar {
mSettingsButton = mStatusBarWindow.findViewById(R.id.settings_button);
mSettingsButton.setOnClickListener(mSettingsButtonListener);
mRotationButton = (RotationToggle) mStatusBarWindow.findViewById(R.id.rotation_lock_button);
+
+ mCarrierLabel = (TextView)mStatusBarWindow.findViewById(R.id.carrier_label);
+ mCarrierLabel.setVisibility(mCarrierLabelVisible ? View.VISIBLE : View.INVISIBLE);
mScrollView = (ScrollView)mStatusBarWindow.findViewById(R.id.scroll);
mScrollView.setVerticalScrollBarEnabled(false); // less drawing during pulldowns
@@ -422,8 +441,17 @@ public class PhoneStatusBar extends BaseStatusBar {
mNetworkController = new NetworkController(mContext);
final SignalClusterView signalCluster =
(SignalClusterView)mStatusBarView.findViewById(R.id.signal_cluster);
+
mNetworkController.addSignalCluster(signalCluster);
signalCluster.setNetworkController(mNetworkController);
+
+ // for wifi-only devices, we show SSID; otherwise, we show PLMN
+ if (mNetworkController.hasMobileDataFeature()) {
+ mNetworkController.addMobileLabelView(mCarrierLabel);
+ } else {
+ mNetworkController.addWifiLabelView(mCarrierLabel);
+ }
+
// final ImageView wimaxRSSI =
// (ImageView)sb.findViewById(R.id.wimax_signal);
// if (wimaxRSSI != null) {
@@ -862,6 +890,45 @@ public class PhoneStatusBar extends BaseStatusBar {
}
}
+ protected void updateCarrierLabelVisibility() {
+ if (!SHOW_CARRIER_LABEL) return;
+ // The idea here is to only show the carrier label when there is enough room to see it,
+ // i.e. when there aren't enough notifications to fill the panel.
+ if (DEBUG) {
+ Slog.d(TAG, String.format("pileh=%d scrollh=%d carrierh=%d",
+ mPile.getHeight(), mScrollView.getHeight(), mCarrierLabelHeight));
+ }
+
+ final boolean makeVisible =
+ mPile.getHeight() < (mScrollView.getHeight() - mCarrierLabelHeight);
+
+ if (mCarrierLabelVisible != makeVisible) {
+ mCarrierLabelVisible = makeVisible;
+ if (DEBUG) {
+ Slog.d(TAG, "making carrier label " + (makeVisible?"visible":"invisible"));
+ }
+ mCarrierLabel.animate().cancel();
+ if (makeVisible) {
+ mCarrierLabel.setVisibility(View.VISIBLE);
+ }
+ mCarrierLabel.animate()
+ .alpha(makeVisible ? 1f : 0f)
+ //.setStartDelay(makeVisible ? 500 : 0)
+ //.setDuration(makeVisible ? 750 : 100)
+ .setDuration(150)
+ .setListener(makeVisible ? null : new AnimatorListenerAdapter() {
+ @Override
+ public void onAnimationEnd(Animator animation) {
+ if (!mCarrierLabelVisible) { // race
+ mCarrierLabel.setVisibility(View.INVISIBLE);
+ mCarrierLabel.setAlpha(0f);
+ }
+ }
+ })
+ .start();
+ }
+ }
+
@Override
protected void setAreThereNotifications() {
final boolean any = mNotificationData.size() > 0;
@@ -919,6 +986,8 @@ public class PhoneStatusBar extends BaseStatusBar {
})
.start();
}
+
+ updateCarrierLabelVisibility();
}
public void showClock(boolean show) {
@@ -1078,6 +1147,8 @@ public class PhoneStatusBar extends BaseStatusBar {
mExpandedVisible = true;
makeSlippery(mNavigationBarView, true);
+ updateCarrierLabelVisibility();
+
updateExpandedViewPos(EXPANDED_LEAVE_ALONE);
// Expand the window to encompass the full screen in anticipation of the drag.
@@ -1933,6 +2004,8 @@ public class PhoneStatusBar extends BaseStatusBar {
panelh = 0;
}
+ if (panelh == mTrackingPosition) return;
+
mTrackingPosition = panelh;
FrameLayout.LayoutParams lp = (FrameLayout.LayoutParams) mNotificationPanel.getLayoutParams();
@@ -1944,13 +2017,17 @@ public class PhoneStatusBar extends BaseStatusBar {
}
mNotificationPanel.setLayoutParams(lp);
+ final int barh = getCloseViewHeight() + getStatusBarHeight();
+ final float frac = saturate((float)(panelh - barh) / (disph - barh));
+
if (DIM_BEHIND_EXPANDED_PANEL && ActivityManager.isHighEndGfx(mDisplay)) {
// woo, special effects
- final int barh = getCloseViewHeight() + getStatusBarHeight();
- final float frac = saturate((float)(panelh - barh) / (disph - barh));
- final int color = ((int)(0xB0 * Math.sin(frac * 1.57f))) << 24;
+ final float k = (float)(1f-0.5f*(1f-Math.cos(3.14159f * Math.pow(1f-frac, 2.2f))));
+ final int color = ((int)(0xB0 * k)) << 24;
mStatusBarWindow.setBackgroundColor(color);
}
+
+ updateCarrierLabelVisibility();
}
void updateDisplaySize() {
@@ -2185,11 +2262,15 @@ public class PhoneStatusBar extends BaseStatusBar {
if (mNotificationPanelGravity <= 0) {
mNotificationPanelGravity = Gravity.CENTER_VERTICAL | Gravity.TOP;
}
- mNotificationPanelMinHeight =
+ final int notificationPanelDecorationHeight =
res.getDimensionPixelSize(R.dimen.notification_panel_padding_top)
+ res.getDimensionPixelSize(R.dimen.notification_panel_header_height)
- + res.getDimensionPixelSize(R.dimen.close_handle_underlap)
+ getNinePatchPadding(res.getDrawable(R.drawable.notification_panel_bg)).bottom;
+ mNotificationPanelMinHeight =
+ notificationPanelDecorationHeight
+ + res.getDimensionPixelSize(R.dimen.close_handle_underlap);
+
+ mCarrierLabelHeight = res.getDimensionPixelSize(R.dimen.carrier_label_height);
if (false) Slog.v(TAG, "updateResources");
}
diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java b/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java
index 273076c..b8f6054 100644
--- a/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java
+++ b/packages/SystemUI/src/com/android/systemui/statusbar/policy/NetworkController.java
@@ -237,6 +237,10 @@ public class NetworkController extends BroadcastReceiver {
mBatteryStats = BatteryStatsService.getService();
}
+ public boolean hasMobileDataFeature() {
+ return mHasMobileDataFeature;
+ }
+
public void addPhoneSignalIconView(ImageView v) {
mPhoneSignalIconViews.add(v);
}
@@ -1049,6 +1053,9 @@ public class NetworkController extends BroadcastReceiver {
+ Integer.toHexString(combinedSignalIconId)
+ "/" + getResourceName(combinedSignalIconId)
+ " combinedActivityIconId=0x" + Integer.toHexString(combinedActivityIconId)
+ + " mobileLabel=" + mobileLabel
+ + " wifiLabel=" + wifiLabel
+ + " combinedLabel=" + combinedLabel
+ " mAirplaneMode=" + mAirplaneMode
+ " mDataActivity=" + mDataActivity
+ " mPhoneSignalIconId=0x" + Integer.toHexString(mPhoneSignalIconId)
@@ -1194,11 +1201,11 @@ public class NetworkController extends BroadcastReceiver {
N = mWifiLabelViews.size();
for (int i=0; i<N; i++) {
TextView v = mWifiLabelViews.get(i);
+ v.setText(wifiLabel);
if ("".equals(wifiLabel)) {
v.setVisibility(View.GONE);
} else {
v.setVisibility(View.VISIBLE);
- v.setText(wifiLabel);
}
}
@@ -1206,11 +1213,11 @@ public class NetworkController extends BroadcastReceiver {
N = mMobileLabelViews.size();
for (int i=0; i<N; i++) {
TextView v = mMobileLabelViews.get(i);
+ v.setText(mobileLabel);
if ("".equals(mobileLabel)) {
v.setVisibility(View.GONE);
} else {
v.setVisibility(View.VISIBLE);
- v.setText(mobileLabel);
}
}
}
diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/policy/NotificationRowLayout.java b/packages/SystemUI/src/com/android/systemui/statusbar/policy/NotificationRowLayout.java
index 0284644..42db8cf 100644
--- a/packages/SystemUI/src/com/android/systemui/statusbar/policy/NotificationRowLayout.java
+++ b/packages/SystemUI/src/com/android/systemui/statusbar/policy/NotificationRowLayout.java
@@ -44,7 +44,7 @@ import java.util.HashMap;
public class NotificationRowLayout
extends LinearLayout
- implements SwipeHelper.Callback, ExpandHelper.Callback
+ implements SwipeHelper.Callback, ExpandHelper.Callback
{
private static final String TAG = "NotificationRowLayout";
private static final boolean DEBUG = false;
@@ -61,6 +61,8 @@ public class NotificationRowLayout
HashMap<View, ValueAnimator> mDisappearingViews = new HashMap<View, ValueAnimator>();
private SwipeHelper mSwipeHelper;
+
+ private OnSizeChangedListener mOnSizeChangedListener;
// Flag set during notification removal animation to avoid causing too much work until
// animation is done
@@ -101,6 +103,10 @@ public class NotificationRowLayout
mSwipeHelper.setLongPressListener(listener);
}
+ public void setOnSizeChangedListener(OnSizeChangedListener l) {
+ mOnSizeChangedListener = l;
+ }
+
@Override
public void onWindowFocusChanged(boolean hasWindowFocus) {
super.onWindowFocusChanged(hasWindowFocus);
@@ -247,4 +253,11 @@ public class NotificationRowLayout
c.restore();
}
}
+
+ @Override
+ protected void onSizeChanged(int w, int h, int oldw, int oldh) {
+ if (mOnSizeChangedListener != null) {
+ mOnSizeChangedListener.onSizeChanged(this, w, h, oldw, oldh);
+ }
+ }
}
diff --git a/packages/SystemUI/src/com/android/systemui/statusbar/policy/OnSizeChangedListener.java b/packages/SystemUI/src/com/android/systemui/statusbar/policy/OnSizeChangedListener.java
new file mode 100644
index 0000000..0377123
--- /dev/null
+++ b/packages/SystemUI/src/com/android/systemui/statusbar/policy/OnSizeChangedListener.java
@@ -0,0 +1,23 @@
+/*
+ * Copyright (C) 2012 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.view.View;
+
+public interface OnSizeChangedListener {
+ void onSizeChanged(View view, int w, int h, int oldw, int oldh);
+}