1. 使用ViewPager首先要导入android-support-v4.jar,我用的新版ADT,默认就有
2. 上代码:
src/com/wind/actionbar/HelloActionBarActivity.java
res/layout/main.xml
/src/com/wind/actionbar/MyPagerAdapter.java
/src/com/wind/actionbar/Tab1Fragment.java
/src/com/wind/actionbar/Tab2Fragment.java
/src/com/wind/actionbar/Tab3Fragment.java
2. 上代码:
src/com/wind/actionbar/HelloActionBarActivity.java
package com.wind.actionbar;
import android.app.ActionBar;
import android.app.ActionBar.Tab;
import android.app.ActionBar.TabListener;
import android.app.FragmentTransaction;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.Log;
import android.view.Menu;
public class HelloActionBarActivity extends FragmentActivity{
private static final String TAG = "HelloActionBarActivity";
public final static int TAB_INDEX_1 = 0;
public final static int TAB_INDEX_2 = 1;
public final static int TAB_INDEX_3 = 2;
public final static int TAB_COUNT = 3;
private ViewPager mViewPager;
private ActionBar actionBar;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.v(TAG, "onCreate");
setContentView(R.layout.main);
actionBar = getActionBar();
//设置AcitonBar的操作模型
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
//去掉title
actionBar.setDisplayShowHomeEnabled(false);
actionBar.setDisplayShowTitleEnabled(false);
setupTab1();
setupTab2();
setupTab3();
//创建 ViewPager
mViewPager = (ViewPager)findViewById(R.id.pager);
mViewPager.setAdapter(new MyPagerAdapter(getSupportFragmentManager()));
mViewPager.setOnPageChangeListener(new MyPagerListener());
mViewPager.setCurrentItem(TAB_INDEX_2);
}
private void setupTab1() {
Tab tab = this.getActionBar().newTab();
tab.setContentDescription("Tab1");
tab.setText("Tab1");
tab.setTabListener(new MyTabListener());
getActionBar().addTab(tab);
}
private void setupTab2() {
Tab tab = this.getActionBar().newTab();
tab.setContentDescription("Tab2");
tab.setText("Tab2");
tab.setTabListener(new MyTabListener());
getActionBar().addTab(tab);
}
private void setupTab3() {
Tab tab = this.getActionBar().newTab();
tab.setContentDescription("Tab3");
tab.setText("Tab3");
tab.setTabListener(new MyTabListener());
getActionBar().addTab(tab);
}
/**
* 实现ActionBar.TabListener接口
*/
class MyTabListener implements TabListener
{
public MyTabListener() {
super();
}
@Override
public void onTabReselected(Tab tab, FragmentTransaction ft) {
// TODO Auto-generated method stub
}
@Override
public void onTabSelected(Tab tab, FragmentTransaction ft) {
Log.v(TAG, "onTabSelected");
if (mViewPager != null)
mViewPager.setCurrentItem(tab.getPosition());
}
@Override
public void onTabUnselected(Tab tab, FragmentTransaction ft) {
Log.v(TAG, "onTabUnselected");
}
}
class MyPagerListener implements OnPageChangeListener{
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
@Override
public void onPageSelected(int arg0) {
// TODO Auto-generated method stub
getActionBar().selectTab(getActionBar().getTabAt(arg0));
}
};
@Override
public boolean onCreateOptionsMenu(Menu menu) {
//this.getMenuInflater().inflate(R.menu.menu, menu);
return super.onCreateOptionsMenu(menu);
}
}
res/layout/main.xml
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/context"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
</FrameLayout>
/src/com/wind/actionbar/MyPagerAdapter.java
package com.wind.actionbar;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
public class MyPagerAdapter extends FragmentPagerAdapter {
public MyPagerAdapter(FragmentManager fm) {
super(fm);
// TODO Auto-generated constructor stub
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return HelloActionBarActivity.TAB_COUNT;
}
@Override
public Fragment getItem(int arg0) {
switch (arg0) {
case HelloActionBarActivity.TAB_INDEX_1:
return new Tab1Fragment();
case HelloActionBarActivity.TAB_INDEX_2:
return new Tab2Fragment();
case HelloActionBarActivity.TAB_INDEX_3:
return new Tab3Fragment();
}
return null;
}
}
/src/com/wind/actionbar/Tab1Fragment.java
package com.wind.actionbar;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Tab1Fragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
return inflater.inflate(R.layout.custom_action_view, container, false);
//return super.onCreateView(inflater, container, savedInstanceState);
}
}
/src/com/wind/actionbar/Tab2Fragment.java
package com.wind.actionbar;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Tab2Fragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
return inflater.inflate(R.layout.two_button_hor, container, false);
//return super.onCreateView(inflater, container, savedInstanceState);
}
}
/src/com/wind/actionbar/Tab3Fragment.java
package com.wind.actionbar;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Tab3Fragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
return inflater.inflate(R.layout.title, container, false);
}
}