Android实现的状态栏定制和修改方法

前端技术 2023/09/03 Android

本文实例讲述了Android实现的状态栏定制和修改方法。分享给大家供大家参考。具体如下:

大家都知道定制在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字体颜色。

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

希望本文所述对大家的Android程序设计有所帮助。

本文地址:https://www.stayed.cn/item/8630

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。