正在准备一个项目,需要尊重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"