需求
讓Actionbar 的背景透明,相當(dāng)于漂浮在你的頁面上
思路
- 首先,設(shè)置ActionBar 浮動到主界面上來。
- 然后,設(shè)置ActionBar的背景色,透明或者半透明。
實現(xiàn)
1.在onCreate設(shè)置漂浮,代碼方式實現(xiàn):
getWindow().requestFeature(Window.FEATURE_ACTION_BAR_OVERLAY);
或者使用theme 在style中實現(xiàn):
<item name="android:windowActionBarOverlay">true</item>
2.設(shè)置透明
代碼方式實現(xiàn):
ActionBar actionBar = getActionBar();
actionBar.setBackgroundDrawable(new ColorDrawable(Color.parseColor("#33000000")));
//google的actionbar是分為上下兩欄顯示的,上面的代碼只能設(shè)置頂部actionbar的背景色,
//為了讓下面的背景色一致,還需要添加一行代碼:
actionBar.setSplitBackgroundDrawable(new ColorDrawable(Color.parseColor("#33000000")));
或者使用theme 在style中實現(xiàn):
<resources>
<style name="AppTheme" parent="android:Theme.Holo.Light.DarkActionBar">
<item name="android:windowActionBarOverlay">true</item>
<!-- 讓actionbar漂浮 -->
<item name="android:actionBarStyle">@style/my_actionbar_style</item>
</style>
<style name="my_actionbar_style" parent="@android:style/Widget.Holo.Light.ActionBar">
<!-- 設(shè)置actionbar 背景色 透明 -->
<item name="android:background">#33000000</item>
<item name="android:backgroundStacked">#346c36</item>
<item name="android:backgroundSplit">#33000000</item>
</style>
</resources>
更改actionbar的文本顏色?
<style name="my_actionbar_style" parent="@android:style/Widget.Holo.Light.ActionBar">
<!-- 設(shè)置actionbar 背景色 透明 -->
<item name="android:background">#33000000</item>
<item name="android:backgroundStacked">#346c36</item>
<item name="android:backgroundSplit">#33000000</item>
<item name="android:titleTextStyle">@style/MyActionBarTitleText</item>
</style>
<style name="MyActionBarTitleText" >
<item name="android:textColor">@android:color/white</item>
</style>
獲得actionbar的高度
public static int getActionbarHeight(Activity context) {
int actionBarHeight = 0;
// Calculate ActionBar height
TypedValue tv = new TypedValue();
if (context.getTheme().resolveAttribute(android.R.attr.actionBarSize,
tv, true))
{
actionBarHeight =
TypedValue.complexToDimensionPixelSize(tv.data,context.getResources().getDisplayMetrics());
}
return actionBarHeight;
}