Android之ViewPager(引导界面)(0)

来源:互联网 发布:破解版java游戏大全 编辑:程序博客网 时间:2024/06/05 14:17


创造机会的人是勇者,等待机会的人是愚者。


本讲内容:ViewPager控件的用法


一、ViewPager的介绍

ViewPager如同容器可装载俩类东西,一种是View对象,另一种是Fragment。

将Layout布局转换为View对象的两种方式
1、LayoutInflater lf=getLayoutInflater().from(this);
     lf.inflate(resource,root);
2、View.inflate(context,resource,root);


二、适配器(根据数据源可分为两类,一种View对象,另一种Fragment对象)

1、PagerAdapter  数据源:List<View>    (第次加载三个页卡一组管理)
2、FragmentPagerAdapter 数据源:List<Fragment> (所有页卡都加载进去管理,不能销毁页卡,即每个页卡(Fragment)中的onDestroy()方法永远不能执行)
3、FragmentStatePagerAdapter 数据源:List<Fragment> (与2的区别,可动态销毁页卡)


三、使用步骤:

1、在布局文件里加入

<android.support.v4.view.ViewPager          android:id="@+id/viewPager"          android:layout_width="match_parent"          android:layout_height="match_parent" />  <!-- 注意这个组件是用来显示左右滑动的界面的,如果不加载xml布局文件,他是不会显示内容的。   -->  

2、加载要显示的页卡

3、需要一个适配器



示例一:

  

下面是res/layout/activity_main.xml 布局文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent" >    <android.support.v4.view.ViewPager        android:id="@+id/id_viewPager"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_centerInParent="true"/></RelativeLayout>


下面是res/layout/view1.xml 布局文件:(view2、view3类似)

<?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:orientation="vertical" >        <TextView         android:layout_width="match_parent"        android:layout_height="wrap_content"        android:text="第一个界面"        android:gravity="center"        android:textSize="30sp"/>    </LinearLayout>

下面是ViewPagerAdapter.java文件:

public class ViewPagerAdapter extends PagerAdapter{private List<View> viewList;public ViewPagerAdapter(List<View> viewList) {this.viewList=viewList;}/** * 获得当前页卡的数量     */public int getCount() {return viewList.size();}/** * 判断视图是否由对象产生 */public boolean isViewFromObject(View arg0, Object arg1) {return arg0==arg1;}/** * 实例化页卡   */public Object instantiateItem(ViewGroup container, int position) {container.addView(viewList.get(position));return viewList.get(position);}/** * 删除页卡   */public void destroyItem(ViewGroup container, int position, Object object) {container.removeView(viewList.get(position));}}


下面是MainActivity.java主界面文件:

public class MainActivity extends Activity {private List<View> viewList;private ViewPager pager;private ViewPagerAdapter adapter;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);pager=(ViewPager) findViewById(R.id.id_viewPager);viewList=getData();adapter=new ViewPagerAdapter(viewList);pager.setAdapter(adapter);}/** * 数据源 */private List<View> getData(){viewList=new ArrayList<View>();/** * 通过View对象作为ViewPager的数据源 */View view1=View.inflate(this, R.layout.view1, null);View view2=View.inflate(this, R.layout.view2, null);View view3=View.inflate(this, R.layout.view3, null);viewList.add(view1);viewList.add(view2);viewList.add(view3);return viewList;}}


示例二:PagerTabStrip和PagerTitleStrp的用法(两者用法一样)

  

下面是res/layout/activity_main.xml 布局文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent" >    <android.support.v4.view.ViewPager        android:id="@+id/id_viewPager"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_centerInParent="true" >        <android.support.v4.view.PagerTabStrip            android:id="@+id/id_tab"            android:layout_width="wrap_content"            android:layout_height="wrap_content" >        </android.support.v4.view.PagerTabStrip>    </android.support.v4.view.ViewPager></RelativeLayout>

下面是ViewPagerAdapter.java文件:

public class ViewPagerAdapter extends PagerAdapter{private List<View> viewList;private List<String> titleList;public ViewPagerAdapter(List<View> viewList,List<String>titleList) {this.viewList=viewList;this.titleList=titleList;}/** * 获得当前页卡的数量     */public int getCount() {return viewList.size();}/** * 判断视图是否由对象产生 */public boolean isViewFromObject(View arg0, Object arg1) {return arg0==arg1;}/** * 实例化页卡   */public Object instantiateItem(ViewGroup container, int position) {container.addView(viewList.get(position));return viewList.get(position);}/** * 删除页卡   */public void destroyItem(ViewGroup container, int position, Object object) {container.removeView(viewList.get(position));}/** * 页卡标题 */public CharSequence getPageTitle(int position) {return titleList.get(position);}}

下面是MainActivity.java主界面文件:

public class MainActivity extends Activity {private List<View> viewList;private List<String>titleList;private ViewPager pager;private ViewPagerAdapter adapter;private PagerTabStrip tab;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initViews();viewList=getData();adapter=new ViewPagerAdapter(viewList,titleList);pager.setAdapter(adapter);}/** * 初始化控件 */private void initViews() {pager=(ViewPager) findViewById(R.id.id_viewPager);tab=(PagerTabStrip) findViewById(R.id.id_tab);titleList=new ArrayList<String>();titleList.add("第一页");titleList.add("第二页");titleList.add("第三页");tab.setBackgroundColor(Color.YELLOW);tab.setTabIndicatorColor(Color.BLUE);tab.setDrawFullUnderline(false);//不显示分隔线tab.setTextColor(Color.RED);}/** * 数据源 */private List<View> getData(){viewList=new ArrayList<View>();/** * 通过View对象作为ViewPager的数据源 */View view1=View.inflate(this, R.layout.view1, null);View view2=View.inflate(this, R.layout.view2, null);View view3=View.inflate(this, R.layout.view3, null);viewList.add(view1);viewList.add(view2);viewList.add(view3);return viewList;}}

示例三:ViewPager装载Fragment

  

下面是Fragment1.java文件:(Fragment2、Fragment3类似)

public class Fragment1 extends Fragment {public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {View view = inflater.inflate(R.layout.view1, container, false);return view;}}

下面是MyFragmentPagerAdapter.java文件

public class MyFragmentPagerAdapter extends FragmentPagerAdapter {private List<Fragment> fragments;private List<String> titleList;public MyFragmentPagerAdapter(FragmentManager fm,List<Fragment> fragments,List<String>titleList) {super(fm);this.fragments=fragments;this.titleList=titleList;}public Fragment getItem(int position) {return fragments.get(position);  }public int getCount() {return fragments.size();}public CharSequence getPageTitle(int position) {return titleList.get(position);}}


下面是MainActivity.java主界面文件:

<pre class="java" name="code">public class MainActivity extends FragmentActivity implements OnPageChangeListener{private List<Fragment> fragList;private List<String> titleList;private ViewPager pager;private MyFragmentPagerAdapter adapter;private PagerTabStrip tab;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initViews();fragList=getData();adapter=new MyFragmentPagerAdapter(getSupportFragmentManager(),fragList,titleList);pager.setAdapter(adapter);pager.setOnPageChangeListener(this);}/** * 初始化控件 */private void initViews() {pager=(ViewPager) findViewById(R.id.id_viewPager);tab=(PagerTabStrip) findViewById(R.id.id_tab);titleList=new ArrayList<String>();titleList.add("第一页");titleList.add("第二页");titleList.add("第三页");tab.setBackgroundColor(Color.YELLOW);tab.setTabIndicatorColor(Color.BLUE);tab.setDrawFullUnderline(false);//不显示分隔线tab.setTextColor(Color.RED);}/** * 数据源 */private List<Fragment> getData(){/** * 通过Fragment作为ViewPager的数据源 */fragList=new ArrayList<Fragment>();fragList.add(new Fragment1());fragList.add(new Fragment2());fragList.add(new Fragment3());return fragList;}//当滑动状态改变时调用 public void onPageScrollStateChanged(int state) {}//当前页面被滑动时调用   public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}//当新的页面被选中时调用  public void onPageSelected(int position) {Toast.makeText(this, "这是第"+(position+1)+"个界面", Toast.LENGTH_SHORT).show();}}


Take your time and enjoy it 要原码的、路过的、学习过的请留个言,顶个呗~~












0 0