Android控件ActionBar浅析及适配2.x的方法介绍

概述:

  在Honeycomb版本系统中,Android引入了全新的操作栏。操作栏不仅取代了显示标题和应用图标的传统标题栏(title bar),还带来了更多其他的功能,例如,安置菜单选项、配置应用图标作为导航按钮,等等。——《Android编程权威指南》


优点:

1.使用方便,避免开发者重复制造轮子。

2.框架成熟,不需要开发者再去做多余的适配不同分辨率及碎片化优化操作。


正常使用(API14及以上):

代码及思路分析:

正常情况下的我们是通过Java代码和xml代码组合来编写actionbar。

xml文件如下:

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

    <item
        android:id="@+id/action_compose"
        android:icon="@drawable/delete_button_normal"
        android:showAsAction="always"
        android:title="@string/action_compose"/>
    
    <item
        android:id="@+id/action_delete"
        android:icon="@drawable/delete_button_normal"
        android:showAsAction="always"
        android:title="@string/action_delete"/>
    
    <item
        android:id="@+id/action_settings"
        android:icon="@drawable/delete_button_normal"
        android:showAsAction="always"
        android:title="@string/action_settings"/>

</menu>
定义3个item,设置其showAsAction属性为always.

关于showAsAction属性的值有以下几个:

always:    这个值会使菜单项一直显示在Action Bar上
ifRoom:    如果有足够的空间,这个值会使菜单项显示在Action Bar上
never:     这个值使菜单项永远都不出现在Action Bar上
withText:  这个值使菜单项和它的图标,菜单文本一起显示


看到上面的标签为menu,就应该知道了,到上面在java代码中是通过菜单来实现了。主要的方法是onCreateOptionsMenu,如下:

public boolean onCreateOptionsMenu(Menu menu) {
		MenuInflater inflater = getMenuInflater();
		inflater.inflate(R.menu.menu, menu);
		return true;
	}

为了去响应左边的返回键(箭头)和Home需要我们在代码做以下逻辑:

ActionBar bar = getActionBar();
bar.setHomeButtonEnabled(true);
bar.setDisplayHomeAsUpEnabled(false);
bar.setDisplayShowHomeEnabled(true);

还有一点就是Home的图标,我们可以在manifest的activity标签中去设置,如下:

<activity
            android:name="com.actionbar.activity.MainActivity"
            android:label="@string/action_bar_title"
            android:logo="@drawable/back_button_normal" >
            
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>


实现效果展示:

技术分享


注:有时候我们在屏幕足够大的时候还是会在最左侧出现一个小箭头,那么如何除掉Actionbar最左侧的箭头呢?可以点击这里查看解决方法。


适配2.x版本:

代码及思路分析:

  对于上面的逻辑方法只是可以在API 14及以上的系统上实现。那么API 14以下的系统要怎么去实现同样的效果呢?在官方出台新的解决方案之前,就有一些大神开始研究且开发出了一套框架——ActionBarSherlock。当然目前Google已经就这个问题提供了一个新的解决方案——android-support-v7-appcompat。我们可以让我们的Activity继承自ActionBarActivity,不过不担心这个ActionBarActivity会对代码有没有什么不良的影响,因为它是继承自FragmentActivity。


  那么要怎么实现呢?我们需要引入一个工具包:android-support-v7-appcompat,并在Android的项目中导入它。是不是到这里就已经大功告成了呢?运行程序后,我们发现并非如此。可是,在基有的代码上我们没有发现任何蛛丝马迹,那我们要怎么去修改这个Bug呢?google吧,孩子。


  后来我们发现我们不能再使用静态的xml代码来创建它了。我们只能动态的在Java代码中通过Java代码动态生成Item,如下:

public boolean onCreateOptionsMenu(Menu menu) {
//		MenuInflater inflater = getMenuInflater();
//		inflater.inflate(R.menu.menu, menu);
//		return super.onCreateOptionsMenu(menu);
		
		MenuCompat.setShowAsAction(menu.add("First").setIcon(android.R.drawable.btn_star), MenuItemCompat.SHOW_AS_ACTION_ALWAYS);
		MenuCompat.setShowAsAction(menu.add("Second").setIcon(android.R.drawable.ic_menu_rotate), MenuItemCompat.SHOW_AS_ACTION_ALWAYS);
		return true;
	}
注释掉的部分就是通过xml静态地创建,事实证明是失败的,需要动态来创建。

运行效果图展示:

技术分享


本人文笔拙劣,可能会有一些表述不够清晰。更详细的代码和细节请在下面的源码连接中去下载查看。还有一点需要注意,如果你的测试机是魅族系列,可能有些地方不能很好适配,请更换测试机重新测试或将属性参数改为SHOW_AS_ACTION_ALWAYS(我用的也是魅族)。


源码下载:

http://download.csdn.net/detail/u013761665/8737119

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。