(转)Android状态栏定制和修改

大家都知道定制在android开发中的重要性,因为通过定制,你才能制造出差异化的产品,才能满足更多消费者的需求,

像HTC生产的手机都通过了深层次的二次开发,今天我也来分享一下我的状态栏定制。

废话不说了,直接上图:

(转)Android状态栏定制和修改

主要更换了背景,文字颜色以及icon的显示顺序.

2.关键代码部分

a)代码在系统中的位置

statusbar的相关代码位于: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

privatefinalvoidupdateBattery(Intentintent)

{

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字体颜色。
<com.android.server.status.StatusBarView xmlns:android="http://schemas.android.com/apk/res/android" 
    android:background="@drawable/statusbar_background"
    android:orientation="vertical"
    android:focusable="true"
    android:descendantFocusability="afterDescendants"
    >
    <LinearLayout android:id="@+id/icons"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="horizontal">
            
        <com.android.server.status.IconMerger 
         android:id="@+id/notificationIcons"
            android:layout_width="0dip"
            android:layout_weight="1"
            android:layout_height="match_parent"
            android:layout_alignParentRight="true"
            android:paddingLeft="6dip"
            android:gravity="center_vertical"
            android:orientation="horizontal"/>  
            
        <LinearLayout 
         android:id="@+id/statusIcons"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
        android:layout_alignParentLeft="true"
            android:paddingRight="6dip"
            android:gravity="center_vertical"
            android:orientation="horizontal"/>    
    </LinearLayout>
        
    <LinearLayout android:id="@+id/ticker"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:paddingLeft="6dip"
        android:animationCache="false"
        android:orientation="horizontal" >
        <ImageSwitcher android:id="@+id/tickerIcon"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:layout_marginRight="8dip"
            >
            <com.android.server.status.AnimatedImageView
                android:layout_width="25dip"
                android:layout_height="25dip"
                />
            <com.android.server.status.AnimatedImageView
                android:layout_width="25dip"
                android:layout_height="25dip"
                />
        </ImageSwitcher>
        <com.android.server.status.TickerView android:id="@+id/tickerText"
            android:layout_width="0dip"
            android:layout_weight="1"
            android:layout_height="wrap_content"
            android:paddingTop="2dip"
            android:paddingRight="10dip">
            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:singleLine="true"
                android:textColor="#ff000000" />
            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:singleLine="true"
                android:textColor="#ff000000" />
        </com.android.server.status.TickerView>
    </LinearLayout>
    <com.android.server.status.DateView android:id="@+id/date"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:singleLine="true"
        android:textSize="16sp"
        android:textStyle="bold"
        android:gravity="center_vertical|left"
        android:paddingLeft="6px"
        android:paddingRight="6px"
        android:textColor="?android:attr/textColorPrimaryInverse"
        android:background="@drawable/statusbar_background"
        />
</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里面的资源文件控制,原始代码如下:
<string-array name="status_bar_icon_order">
        <item><xliff:g id="id">clock</xliff:g></item>
        <item><xliff:g id="id">secure</xliff:g></item>
        <item><xliff:g id="id">alarm_clock</xliff:g></item>
        <item><xliff:g id="id">battery</xliff:g></item>
        <item><xliff:g id="id">phone_signal</xliff:g></item>
        <item><xliff:g id="id">phone_evdo_signal</xliff:g></item>
        <item><xliff:g id="id">data_connection</xliff:g></item>
        <item><xliff:g id="id">cdma_eri</xliff:g></item>
        <item><xliff:g id="id">tty</xliff:g></item>
        <item><xliff:g id="id">volume</xliff:g></item>
        <item><xliff:g id="id">mute</xliff:g></item>
        <item><xliff:g id="id">speakerphone</xliff:g></item>
        <item><xliff:g id="id">wifi</xliff:g></item>
        <item><xliff:g id="id">tty</xliff:g></item>
        <item><xliff:g id="id">bluetooth</xliff:g></item>
        <item><xliff:g id="id">gps</xliff:g></item>
        <item><xliff:g id="id">sync_active</xliff:g></item>
        <item><xliff:g id="id">sync_failing</xliff:g></item>
        <item><xliff:g id="id">ime</xliff:g></item>
    </string-array>

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

相关推荐