Java类
/**
* ViewPager 引导页面
*/
public class ViewPagerActivity extends FragmentActivity {
private ViewPager mVPActivity;
private Fragment1 mFragment1;
private Fragment2 mFragment2;
private Fragment3 mFragment3;
private List<Fragment> mListFragment = new ArrayList<Fragment>();
private PagerAdapter mPgAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_viewpager);
initView();
}
private void initView() {
mVPActivity = (ViewPager) findViewById(R.id.vp_activity);
mFragment1 = new Fragment1();
mFragment2 = new Fragment2();
mFragment3 = new Fragment3();
mListFragment.add(mFragment1);
mListFragment.add(mFragment2);
mListFragment.add(mFragment3);
mPgAdapter = new ViewPagerAdapter(getSupportFragmentManager(),
mListFragment);
mVPActivity.setAdapter(mPgAdapter);
}
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<android.support.v4.view.ViewPager
android:id="@+id/vp_activity"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</android.support.v4.view.ViewPager>
</LinearLayout>
public class ViewPagerAdapter extends FragmentPagerAdapter {
private List<Fragment> fragmentList=new ArrayList<Fragment>();
public ViewPagerAdapter(FragmentManager fm) {
super(fm);
}
public ViewPagerAdapter(FragmentManager fragmentManager,List<Fragment> arrayList) {
super(fragmentManager);
this.fragmentList=arrayList;
}
@Override
public Fragment getItem(int arg0) {
return fragmentList.get(arg0);
}
@Override
public int getCount() {
return fragmentList.size();
}
}
如果是三个页面 弄三个Fragment 对应的布局文件
Fragment1.java 第二个省略
public class Fragment1 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
super.onCreateView(inflater, container, savedInstanceState);
View view = inflater.inflate(R.layout.fragment_1, container, false);
return view;
}
}
对应的布局文件fragment_1.xml 第二个布局省略
?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/guide_1" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="horizontal"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_marginBottom="45dp">
<ImageView
android:layout_width="wrap_content"
android:layout_height="15dp"
android:src="@android:drawable/presence_online"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="15dp"
android:src="@android:drawable/presence_invisible"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@android:drawable/presence_invisible"/>
</LinearLayout>
</RelativeLayout>
Fragment3.java
public class Fragment3 extends Fragment {
private SharedPreferences sp;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
super.onCreateView(inflater, container, savedInstanceState);
View view = inflater.inflate(R.layout.fragment_3, container, false);
/*
* 第三个Fragment点击Button跳到MainActivity
* */
Button btStart= (Button) view.findViewById(R.id.btStart);
btStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
sp = getActivity().getSharedPreferences("config", Context.MODE_PRIVATE);
//点击以后 说明新手引导页面已经展示过了 下次就不展示了
sp.edit().putBoolean("viewPagerShow",true).commit();
Intent intent = new Intent(getActivity(), MainActivity.class);
startActivity(intent);
}
});
return view;
}
}
fragment_3.xml 布局文件
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/guide_3" >
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="开始体验"
android:textColor="@drawable/button_text_selector"
android:textSize="24dp"
android:padding="15dp"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="88dp"
android:background="@drawable/button_red_selector"
android:id="@+id/btStart" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="horizontal"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_marginBottom="45dp">
<ImageView
android:layout_width="wrap_content"
android:layout_height="15dp"
android:src="@android:drawable/presence_invisible"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@android:drawable/presence_invisible"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="15dp"
android:src="@android:drawable/presence_online"/>
</LinearLayout>
</RelativeLayout>