Android實現(xiàn)的狀態(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程序設計有所幫助。
相關文章
Android優(yōu)化之啟動頁去黑屏實現(xiàn)秒啟動
本文的內(nèi)容主要是講Android啟動頁優(yōu)化,去黑屏實現(xiàn)秒啟動的功能,有需要的小伙伴們可以參考學習。2016-08-08Android開發(fā)工程中集成mob短信驗證碼功能的方法
這篇文章主要介紹了Android開發(fā)工程中集成mob短信驗證碼功能的方法,感興趣的小伙伴們可以參考一下2016-05-05解析android創(chuàng)建快捷方式會啟動兩個應用的問題
本篇文章是對關于android創(chuàng)建快捷方式會啟動兩個應用的問題進行了詳細的分析介紹,需要的朋友參考下2013-06-06Android Navigation TabBar控件實現(xiàn)多彩標簽欄
這篇文章主要為大家詳細介紹了Android Navigation TabBar控件實現(xiàn)多彩標簽欄的相關代碼,感興趣的小伙伴們可以參考一下2016-05-05