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