Android使用supportv7包实现网易云音乐首页titlebar

先上titlebar原图:



1.import android-support-v7-appcompat工程,设置成library。新建工程并将v7包导入。

Activity部分代码

public class MainActivity extends ActionBarActivity {
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
}
<span style="white-space:pre">	</span>@Override
	public boolean onCreateOptionsMenu(Menu menu) {
	    // Inflate the menu
	    getMenuInflater().inflate(R.menu.main_menu, menu);
	    return super.onCreateOptionsMenu(menu);
	}
}
main_menu:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:yourapp="http://schemas.android.com/apk/res-auto" >

    <item
        android:id="@+id/menu_search"
        android:icon="@drawable/desk2_search"
        android:title="@string/search"
        yourapp:showAsAction="always"/>
    <item
        android:id="@+id/more"
        android:icon="@drawable/abs__ic_menu_moreoverflow_normal_holo_light"
        android:title="@string/more"
        yourapp:showAsAction="always">
    </item>

</menu>
效果图:



去掉左侧的图标和文字:

public class MainActivity extends ActionBarActivity {
	private ActionBar mActionBar;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		this.mActionBar = this.getSupportActionBar();
		this.mActionBar.setDisplayOptions(0);//去掉左侧的应用图标和文字
<span style="white-space:pre">	</span>}
}
通过修改style文件改变titlebar的背景:

<style name="AppTheme" parent="@style/Theme.AppCompat.Light">
<span style="white-space:pre">	</span><item name="android:actionBarStyle">@style/EmbeddedActionBar</item> 
</style>
    
<style name="EmbeddedActionBar" parent="Widget.AppCompat.ActionBar.Solid">
        <item name="android:background">@color/red</item>
</style>

效果图:


添加tab,代码如下


public class MainActivity extends ActionBarActivity {
	private ActionBar mActionBar;
	private FragmentManager mFragmentManager;
	private Fragment[] fragments = new Fragment[3];
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		this.mActionBar = this.getSupportActionBar();
		this.mActionBar.setDisplayOptions(0);
		this.mActionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
		for( int i = 0; i < 3; i ++ ) {
			View view = View.inflate(this, R.layout.imageview_item, null);
			ImageView imageView = (ImageView) view.findViewById(R.id.iv);
			if(i == 0)imageView.setImageResource(R.drawable.selector1);
			if(i == 1)imageView.setImageResource(R.drawable.selector2);
			if(i == 2)imageView.setImageResource(R.drawable.selector3);
			this.mActionBar.addTab(this.mActionBar.newTab().setText(i + "").setCustomView(view).setTabListener(tabListener));
		}
	}
}

效果:



将tab按钮设置到顶部需要反射setHasEmbeddedTabs方法,代码如下:

public class ActionBarHelper {
	public static void enableEmbeddedTabs(ActionBar actionBar){
		
        if (actionBar instanceof ActionBarImplJBMR2) {
            //enableEmbeddedTabs(actionBar, true);
        	try {
                Field actionBarField = actionBar.getClass().getSuperclass().getSuperclass().getDeclaredField("mActionBar");
                actionBarField.setAccessible(true);
                enableEmbeddedTabs(actionBarField.get(actionBar), true);
            } catch (Exception e) {
                e.printStackTrace();
            }
        } else if (actionBar instanceof ActionBarImplJB) {
            try {
                Field actionBarField = actionBar.getClass().getSuperclass().getDeclaredField("mActionBar");
                actionBarField.setAccessible(true);
                enableEmbeddedTabs(actionBarField.get(actionBar), true);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

    private static void enableEmbeddedTabs(Object actionBar, boolean flag) {
        try {
            Method setHasEmbeddedTabsMethod = actionBar.getClass().getDeclaredMethod("setHasEmbeddedTabs", boolean.class);
            setHasEmbeddedTabsMethod.setAccessible(true);
            setHasEmbeddedTabsMethod.invoke(actionBar, true);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
在Activity中调用此函数,可以将tab按钮设置到顶部,效果:



通过style文件设置tab的选项卡,图标的位置:

<style name="AppTheme" parent="@style/Theme.AppCompat.Light">
	    <item name="android:actionBarStyle">@style/EmbeddedActionBar</item> 
        <item name="android:actionBarTabStyle">@style/EmbeddedActionBarTabStyle</item>
        <item name="android:actionBarTabBarStyle">@style/EmbeddedActionBarTabBarStyle</item>
    </style>
    
    <style name="EmbeddedActionBar" parent="Widget.AppCompat.ActionBar.Solid">
        <item name="android:background">@color/red</item>
    </style>
    
    <style name="EmbeddedActionBarTabStyle" parent="Widget.AppCompat.Light.ActionBar.TabView">
        <item name="android:background">@drawable/tab_white_indicator</item>
        <item name="android:paddingLeft">8dp</item>
        <item name="android:paddingRight">8dp</item>
        <item name="android:gravity">center</item>
    </style>
    
    <style name="EmbeddedActionBarTabBarStyle" parent="Widget.AppCompat.ActionBar.TabBar">
        <item name="android:divider">@null</item>
    </style>

最终效果:

源码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值