修改系统action bar字体大小、粗细、颜色等样式的方法

来源:互联网 发布:淘宝店铺商品详情模板 编辑:程序博客网 时间:2024/05/16 17:34
     Action bar字体的修改主要还是在xml文件中完成,对actionbar字体的修改主要思路如下:
  • 根据application 的android:theme 属性找到他的style(方便起见,我们成为app_style)定义。
  • 在style中找到name 为android:actionBarStyle 的item,找到android:actionBarStyle 对应的style(方便起见,我们成为actionbar_style)。
  • 在actionbar_style中就可以看到name为android:titleTextStyle的item,再找到对应的style(我们称为titleText_style)
  • 在titleText_style中可以发现里面有个定义了android:textSize的item,但是在这修该的话,不起作用,至于为什么,希望大家补充(PS:actionbar_style、titleText_style都是SDK中定义的,不知道是不是和这个有关)
  • 既然上一个步骤型不同,但是我们可以在app_style所在的文件中定义一个actionbar style,然后在它的item下定义action bar的样式,具体的课参考下面的例子。
     现在我们结合一个例子来说明(以android 4.4的settings应用为例):
  1. 在AndroidManifest文件中找到application中的属性
        <application android:label ="@string/settings_label"
                android:icon= "@mipmap/ic_launcher_settings"
                android:taskAffinity= ""
                android:theme= "@style/Theme.Settings"
                android:hardwareAccelerated="true"
                android:requiredForAllUsers="true"
                android:supportsRtl= "true"
                android:name= ".Screenshot">

  2. 找到android:theme对应的style,Theme.Settings
        <style name ="Theme.Settings" parent= "@android:style/Theme.Holo">
            <item name= "@*android:preferenceHeaderPanelStyle" >@style/PreferenceHeaderPanelSinglePane </item>
            <item name= "@*android:preferencePanelStyle" >@style/PreferencePanelSinglePane </item>
            <item name= "@*android:preferenceListStyle" >@style/PreferenceHeaderListSinglePane </item>
            <item name= "@*android:preferenceFragmentListStyle" >@style/PreferenceFragmentListSinglePane </item>
            <item name= "@*android:preferenceFragmentPaddingSide" >@dimen/settings_side_margin </item>
            <item name= "apnPreferenceStyle">@style/ApnPreference </item>
            <item name= "ic_menu_add">@drawable/ic_menu_add_dark </item>
            <item name= "ic_menu_moreoverflow">@*android:drawable/ic_menu_moreoverflow_holo_dark </item>
            <item name ="ic_wps">@drawable/ic_wps_dark</ item>
            <item name= "wifi_signal">@drawable/wifi_signal_dark </item>
            <item name= "android:actionBarStyle">@android:style/Widget.Holo.ActionBar.Solid </item>
            <item name ="@android:attr/actionBarSize"> 90dp</ item>
        </style >

  3. 找到android:actionBarStyle对应的style(Widget.Holo.ActionBar.Solid )。
        <style name ="Widget.Holo.ActionBar.Solid">
            <item name= "android:titleTextStyle">@android:style/TextAppearance.Holo.Widget.ActionBar.Title </item>
            <item name= "android:subtitleTextStyle">@android:style/TextAppearance.Holo.Widget.ActionBar.Subtitle </item>
            <item name= "android:background">@android:drawable/ab_solid_dark_holo </item>
            <item name= "android:backgroundStacked">@android:drawable/ab_stacked_solid_dark_holo </item>
            <item name= "android:backgroundSplit">@android:drawable/ab_bottom_solid_dark_holo </item>
            <item name= "android:divider">?android:attr/dividerVertical </item>
            <item name= "android:progressBarStyle">@android:style/Widget.Holo.ProgressBar.Horizontal </item>
            <item name= "android:indeterminateProgressStyle" >@android:style/Widget.Holo.ProgressBar </item>
            <item name ="android:progressBarPadding"> 32dip</ item>
            <item name ="android:itemPadding"> 8dip</ item>
        </style >

  4. 找到android:titleTextStyle对应的style(TextAppearance.Holo.Widget.ActionBar.Title)。
        <style name ="TextAppearance.Holo.Widget.ActionBar.Title"
               parent= "TextAppearance.Holo.Medium">
            <item name= "android:textSize">@android:dimen/action_bar_title_text_size </item>
        </style >

  5. 上面说了在TextAppearance.Holo.Widget.ActionBar.Title下面改是行不通的,可以这样做:在Theme.Settings所在的文件下定义
         <style name ="MyActionBarStyle" parent="@android:style/Widget.Holo.ActionBar.Solid" >
             <item name= "android:titleTextStyle">@style/MyActionBar.TitleTextStyle </item>
         </style >
         
         <style name ="MyActionBar.TitleTextStyle"
             parent= "@android:style/TextAppearance.Holo.Widget.ActionBar.Title" >
             <item name ="android:textSize"> 43sp</ item>
             <item name ="android:textColor"> #FF9900</ item>
         </style >
    然后修改<item name="android:actionBarStyle"> @style/MyActionBarStyle</item >

    前后效果对比图如下:




0 0
原创粉丝点击