actionBar兼容2.1及以上版本的做法

正在准备一个项目,需要尊重android design的同时还要做到很好的兼容低版本,于是就先从actionBar开始吧。


1,新建一个android工程startActionBar,minSdkVersion="7",targetSdkVersion="18",用19(暂时最新)的版本编译。

<uses-sdk
        android:minSdkVersion="7"
        android:targetSdkVersion="18" />

2,将sdk下面的v7工程作为一个project导入到eclipse中,名为“android-support-v7-appcompat”的工程。

                 v7工程的路径在sdk的目录中位置:“android\sdk\extras\android\support\v7\appcompat”


3,设置startActionBar工程包含上面的工程源。

startActionBar工程上右键 -> Properties -> Android -> add -> “选择android-support-v7-appcompat” -> 保存ok。

你会看到gen目录下已经有了v7工程的源码。


4,继承ActionBarActivity写一个activity

import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.Menu;

public class MainActivity extends ActionBarActivity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		//加载action items
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

}

5,manifest代码

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.tab"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="7"
        android:targetSdkVersion="18" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.example.tab.MainActivity"
            android:label="@string/app_name" 
            android:theme="@style/Theme.AppCompat.Light">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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

</manifest>

6,res/menu/main.xml 内容

<menu xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:Tab="http://schemas.android.com/apk/res-auto">
    
    <item
        android:id="@+id/action_photo"
        android:orderInCategory="99"
        Tab:showAsAction="ifRoom|withText"
        android:title="@string/photo"
        android:icon="@drawable/collections_view_as_grid"/>
    
    <item
        android:id="@+id/action_text"
        android:orderInCategory="98"
        Tab:showAsAction="ifRoom|withText"
        android:title="@string/text"
        android:icon="@drawable/content_copy"/>
    
    <item
        android:id="@+id/action_settings"
        android:orderInCategory="100"
        android:showAsAction="never"
        android:title="@string/action_settings"/>

</menu>

这里有三点需要特别注意:(1)、“ xmlns:Tab="http://schemas.android.com/apk/res-auto"中的"Tab"是我的工程名称,这里需要写成你自己的工程名。

(2)、Tab:showAsAction="ifRoom|withText" 中的Tab同样也是工程名,目的是为了让这个item成为action button,只要有空间就显示在actionBar上(版本11以下的必须这么写)

(3)、ifRoom是什么意思?就是如果actionBar的空间够,就显示,不够就点击后显示,例如下图中的“下载” 、“信封” 和 “文件夹”图标


最后特别提供一个actionBar素材的下载包:http://developer.android.com/downloads/design/Android_Design_Downloads_20130814.zip

在这个素材库里找到自己喜欢的图片做item的icon就可以了,记得要改下面的代码为自己的图片。

android:icon="@drawable/collections_view_as_grid"

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值