Android状态栏定制和修改

http://blog.csdn.net/litton_van/article/details/6311900

 

 

大家都知道定制在android开发中的重要性,因为通过定制,你才能制造出差异化的产品,才能满足更多消费者的需求,
像HTC生产的手机都通过了深层次的二次开发,今天我也来分享一下我的状态栏定制。
废话不说了,直接上图:

主要更换了背景,文字颜色以及icon的显示顺序.
2.    关键代码部分
a)    代码在系统中的位置
status bar 的相关代码位于:frameworks/base/services/java/com/android/server/status。
其中StatusBarPolicy类主要负责接收action动作,其他一些核心操作全部位于StatusBarService类里面
b)    代码实例:
i.    接收action
   if (action.equals(Intent.ACTION_BATTERY_CHANGED)) 
{
         updateBattery(intent);
    }
ii.    更新icon
  private final void updateBattery(Intent intent)
{
      mBatteryData.iconId = intent.getIntExtra("icon-small", 0);
      mBatteryData.iconLevel = intent.getIntExtra("level", 0);
      mService.updateIcon(mBatteryIcon, mBatteryData, null);
}
c)    资源位置:
Status bar 的相关资源位于:frameworks/base/core/res/res,关键布局为:base/core/res/res/layout/status_bar.xml ,源码如下:重要的是红色字体标注部分,这里可以设置notification字体颜色。

 

  1. <com.android.server.status.StatusBarView xmlns:android="http://schemas.android.com/apk/res/android"   
  2.     android:background="@drawable/statusbar_background"  
  3.     android:orientation="vertical"  
  4.     android:focusable="true"  
  5.     android:descendantFocusability="afterDescendants"  
  6.     >  
  7.     <LinearLayout android:id="@+id/icons"  
  8.         android:layout_width="match_parent"  
  9.         android:layout_height="match_parent"  
  10.         android:orientation="horizontal">  
  11.               
  12.         <com.android.server.status.IconMerger   
  13.          android:id="@+id/notificationIcons"  
  14.             android:layout_width="0dip"  
  15.             android:layout_weight="1"  
  16.             android:layout_height="match_parent"  
  17.             android:layout_alignParentRight="true"  
  18.             android:paddingLeft="6dip"  
  19.             android:gravity="center_vertical"  
  20.             android:orientation="horizontal"/>    
  21.               
  22.         <LinearLayout   
  23.          android:id="@+id/statusIcons"  
  24.             android:layout_width="wrap_content"  
  25.             android:layout_height="match_parent"  
  26.         android:layout_alignParentLeft="true"  
  27.             android:paddingRight="6dip"  
  28.             android:gravity="center_vertical"  
  29.             android:orientation="horizontal"/>      
  30.     </LinearLayout>  
  31.           
  32.     <LinearLayout android:id="@+id/ticker"  
  33.         android:layout_width="match_parent"  
  34.         android:layout_height="match_parent"  
  35.         android:paddingLeft="6dip"  
  36.         android:animationCache="false"  
  37.         android:orientation="horizontal" >  
  38.         <ImageSwitcher android:id="@+id/tickerIcon"  
  39.             android:layout_width="wrap_content"  
  40.             android:layout_height="match_parent"  
  41.             android:layout_marginRight="8dip"  
  42.             >  
  43.             <com.android.server.status.AnimatedImageView  
  44.                 android:layout_width="25dip"  
  45.                 android:layout_height="25dip"  
  46.                 />  
  47.             <com.android.server.status.AnimatedImageView  
  48.                 android:layout_width="25dip"  
  49.                 android:layout_height="25dip"  
  50.                 />  
  51.         </ImageSwitcher>  
  52.         <com.android.server.status.TickerView android:id="@+id/tickerText"  
  53.             android:layout_width="0dip"  
  54.             android:layout_weight="1"  
  55.             android:layout_height="wrap_content"  
  56.             android:paddingTop="2dip"  
  57.             android:paddingRight="10dip">  
  58.             <TextView  
  59.                 android:layout_width="match_parent"  
  60.                 android:layout_height="wrap_content"  
  61.                 android:singleLine="true"  
  62.                 android:textColor="#ff000000" />  
  63.             <TextView  
  64.                 android:layout_width="match_parent"  
  65.                 android:layout_height="wrap_content"  
  66.                 android:singleLine="true"  
  67.                 android:textColor="#ff000000" />  
  68.         </com.android.server.status.TickerView>  
  69.     </LinearLayout>  
  70.     <com.android.server.status.DateView android:id="@+id/date"  
  71.         android:layout_width="wrap_content"  
  72.         android:layout_height="match_parent"  
  73.         android:singleLine="true"  
  74.         android:textSize="16sp"  
  75.         android:textStyle="bold"  
  76.         android:gravity="center_vertical|left"  
  77.         android:paddingLeft="6px"  
  78.         android:paddingRight="6px"  
  79.         android:textColor="?android:attr/textColorPrimaryInverse"  
  80.         android:background="@drawable/statusbar_background"  
  81.         />  
  82. </com.android.server.status.StatusBarView>  

 

3.    简单修改
对status bar 的修改主要包括status bar的背景颜色、icon、字体颜色、icon顺序等。
a)    背景颜色:
背景颜色由frameworks/base/core/res/res/drawable-mdpi/statusbar_background.9.png决定,原始颜色是灰色,我们修改为黑色。
b)    Icon:
Icon根据不同显示项,由不同资源决定,暂时不更改。
c)    字体颜色:
由frameworks/base/services/java/com/android/server/status/ StatusBarIcon类中的代码控制,原始代码为:t.setTextColor(0xff000000),即黑色,我们将其更改为白色:t.setTextColor(0xffffffff)。
d)    icon顺序:
由frameworks/base/core/res/res/values/array里面的资源文件控制,原始代码如下:

 

  1. <string-array name="status_bar_icon_order">  
  2.         <item><xliff:g id="id">clock</xliff:g></item>  
  3.         <item><xliff:g id="id">secure</xliff:g></item>  
  4.         <item><xliff:g id="id">alarm_clock</xliff:g></item>  
  5.         <item><xliff:g id="id">battery</xliff:g></item>  
  6.         <item><xliff:g id="id">phone_signal</xliff:g></item>  
  7.         <item><xliff:g id="id">phone_evdo_signal</xliff:g></item>  
  8.         <item><xliff:g id="id">data_connection</xliff:g></item>  
  9.         <item><xliff:g id="id">cdma_eri</xliff:g></item>  
  10.         <item><xliff:g id="id">tty</xliff:g></item>  
  11.         <item><xliff:g id="id">volume</xliff:g></item>  
  12.         <item><xliff:g id="id">mute</xliff:g></item>  
  13.         <item><xliff:g id="id">speakerphone</xliff:g></item>  
  14.         <item><xliff:g id="id">wifi</xliff:g></item>  
  15.         <item><xliff:g id="id">tty</xliff:g></item>  
  16.         <item><xliff:g id="id">bluetooth</xliff:g></item>  
  17.         <item><xliff:g id="id">gps</xliff:g></item>  
  18.         <item><xliff:g id="id">sync_active</xliff:g></item>  
  19.         <item><xliff:g id="id">sync_failing</xliff:g></item>  
  20.         <item><xliff:g id="id">ime</xliff:g></item>  
  21.     </string-array>  

 

我们将battery与clock的位置更换。

 

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值