欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android實現(xiàn)的狀態(tài)欄定制和修改方法

 更新時間:2015年10月08日 11:35:23   作者:范立濤  
這篇文章主要介紹了Android實現(xiàn)的狀態(tài)欄定制和修改方法,涉及Android針對狀態(tài)欄屬性設置的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了Android實現(xiàn)的狀態(tài)欄定制和修改方法。分享給大家供大家參考。具體如下:

大家都知道定制在android開發(fā)中的重要性,因為通過定制,你才能制造出差異化的產(chǎn)品,才能滿足更多消費者的需求,

像HTC生產(chǎn)的手機都通過了深層次的二次開發(fā),今天我也來分享一下我的狀態(tài)欄定制。

廢話不說了,直接上圖:

主要更換了背景,文字顏色以及icon的顯示順序.

2. 關鍵代碼部分

a) 代碼在系統(tǒng)中的位置

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字體顏色。

<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根據(jù)不同顯示項,由不同資源決定,暫時不更改。

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的位置更換。

希望本文所述對大家的Android程序設計有所幫助。

相關文章

最新評論