Android布局之TabLayout
為了使用Tab,必須使用TabHost和TabWidget,TabHost必須是布局文件中的根節點,它包含了tabWidget顯示tabs,以及FrameLayout來顯示tab的內容。
你可以用以下兩種方式實現你的tab內容:
A.在同一個Acitivity里交換不同的View。
B.每一個Tab使用一個不同的Activity。
在這里先介紹第2種的實現方式,具體步驟如下:
1.創建一個項目HelloTabWidget
2.創建三個不同的Activity用來代表不同的Tab,在此創建了ArtistsActivity
, AlbumsActivity
, 和SongsActivity.具體代碼如下:
ArtistsActivity.java
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
public class ArtistsActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
TextView tv = new TextView(this);
tv.setText("This is the Artists tab");
setContentView(tv);
}
}
AlbumsActivity.java
import android.app.Activity; import android.os.Bundle; import android.widget.TextView; public class AlbumsActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); TextView tv = new TextView(this); tv.setText("This is the Albums tab"); setContentView(tv); } }
SongsActivity.java
import android.app.Activity; import android.os.Bundle; import android.widget.TextView; public class SongsActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); TextView tv = new TextView(this); tv.setText("This is the Songs tab"); setContentView(tv); } }
在這里只是為了演示,三個Acitivity都沒有設置布局文件,只是設置了一個Textview,在實際運用時可以換成需要的布局文件
3. 在AndriodManifest.xml文件中注冊三個Activity。
4.每個tab都需要一組圖片,即包含兩個狀態的圖片,一個是這個tab被選中時的圖片,另一個是沒有被選中時的圖片。建議選中時使用灰色圖片,沒有選中時使用白色圖片。(具體效果如下圖)
在此因為我們要創建三個tab,因此還需要為其他兩個tab準備兩組圖片,為了方便,下面我為每個tab設置的都是這組圖片,自己操作時可以準備好三組圖片。
4.1將圖片保存在res/drawable/
下面
4.2在res/drawable/
下面創建一個名為ic_tab_artists.xml用于定義不同的tab狀態時顯示不同的圖片。
ic_tab_artists.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- When selected, use grey -->
<item android:drawable="@drawable/ic_tab_artists_grey"
android:state_selected="true" />
<!-- When not selected, use white-->
<item android:drawable="@drawable/ic_tab_artists_white"
android:state_selected="false" />
</selector>
ic_tab_artists_grey和 ic_tab_artsits_white為圖片名稱
5.修改main.xml如下
main.xml
<?xml version="1.0" encoding="utf-8"?> <TabHost xmlns:android="http://schemas.android.com/apk/res/android" android:id="@android:id/tabhost" android:layout_width="fill_parent" android:layout_height="fill_parent"> <LinearLayout android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" android:padding="5dp"> <TabWidget android:id="@android:id/tabs" android:layout_width="fill_parent" android:layout_height="wrap_content" /> <FrameLayout android:id="@android:id/tabcontent" android:layout_width="fill_parent" android:layout_height="fill_parent" android:padding="5dp" /> </LinearLayout> </TabHost>
這個文件的設置是按照開篇的第一句話:為了使用Tab,必須使用TabHost和TabWidget,TabHost必須是布局文件中的根節點,它包含了tabWidget顯示tabs,以及FrameLayout來顯示tab的內容。(個人感覺這個就是一個格式,反正按這樣做就行了)
6.修改HelloTabWidget.java的代碼,讓他繼承TabActivity
HelloTabWidget.java
package lin.sdk.tablayout; import android.app.TabActivity; import android.content.Intent; import android.content.res.Resources; import android.os.Bundle; import android.widget.TabHost; public class HelloTabWidget extends TabActivity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); Resources res = getResources(); // Resource object to get Drawables TabHost tabHost = getTabHost(); // The activity TabHost TabHost.TabSpec spec; // Resusable TabSpec for each tab Intent intent; // Reusable Intent for each tab // Create an Intent to launch an Activity for the tab (to be reused) intent = new Intent().setClass(this, ArtistsActivity.class); // Initialize a TabSpec for each tab and add it to the TabHost spec = tabHost .newTabSpec("artists") .setIndicator("Artists", res.getDrawable(R.drawable.ic_tab_artists)) .setContent(intent); tabHost.addTab(spec); // Do the same for the other tabs intent = new Intent().setClass(this, AlbumsActivity.class); spec = tabHost .newTabSpec("albums") .setIndicator("Albums", res.getDrawable(R.drawable.ic_tab_artists)) .setContent(intent); tabHost.addTab(spec); intent = new Intent().setClass(this, SongsActivity.class); spec = tabHost .newTabSpec("songs") .setIndicator("Songs", res.getDrawable(R.drawable.ic_tab_artists)) .setContent(intent); tabHost.addTab(spec); tabHost.setCurrentTab(1); } }
上面可以把后面兩個R.drawable.ic_tab_artsts換成為后面兩個tab設置圖片而創建的類似ic_tab_artists.xml文件
7.修改AndriodManifest.xml文件,去掉Titlebar
<activity android:name=".HelloTabWidget" android:label="@string/app_name" android:theme="@android:style/Theme.NoTitleBar">
整個AndroidManifest.xml如下:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="lin.sdk.tablayout" android:versionCode="1" android:versionName="1.0"> <uses-sdk android:minSdkVersion="10" /> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".HelloTabWidget" android:label="@string/app_name" android:theme="@android:style/Theme.NoTitleBar"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <activity android:name=".AlbumsActivity"/> <activity android:name=".SongsActivity"/> <activity android:name=".ArtistsActivity"/> </application> </manifest>
如果直接復制上面的代碼,需要修改package="lin.sdk.tablayout"為自己項目的包名
程序運行效果如下: