ViewPage+Fragment的使用用法

一、概述

从前面几篇文章,我们知道,实现ViewPager是要有适配器的,我们前面用的适配器是PagerAdapter,而对于fragment,它所使用的适配器是:FragmentPagerAdapter.先看看官方对于这个类的解释:(英文下面有中文解释)

原文:

Class Overview



Implementation of PagerAdapter that represents each page as a Fragment that is persistently kept in the fragment manager as long as the user can return to the page.

This version of the pager is best for use when there are a handful of typically more static fragments to be paged through, such as a set of tabs. The fragment of each page the user visits will be kept in memory, though its view hierarchy may be destroyed when not visible. This can result in using a significant amount of memory since fragment instances can hold on to an arbitrary amount of state. For larger sets of pages, consider FragmentStatePagerAdapter.

When using FragmentPagerAdapter the host ViewPager must have a valid ID set.

Subclasses only need to implement getItem(int) and getCount() to have a working adapter.

译文:(译的不好,大家可在评论中补充)

FragmentPagerAdapter派生自PagerAdapter,它是用来呈现Fragment页面的,这些Fragment页面会一直保存在fragment manager中,以便用户可以随时取用。

这个适配器最好用于有限个静态fragment页面的管理。尽管不可见的视图有时会被销毁,但用户所有访问过的fragment都会被保存在内存中。因此fragment实例会保存大量的各种状态,这就造成了很大的内存开销。所以如果要处理大量的页面切换,建议使用FragmentStatePagerAdapter.

每一个使用FragmentPagerAdapter的ViewPager都要有一个有效的ID集。(没理解什么意思)

对于FragmentPagerAdapter的派生类,只需要重写getItem(int)和getCount()就可以了。

二、具体实现

1、适配器实现——FragmentPagerAdapter

先看完整代码,再细讲:

[java] view plaincopy

  1. public class FragAdapter extends FragmentPagerAdapter {
  2. private List<Fragment> mFragments;
  3. public FragAdapter(FragmentManager fm,List<Fragment> fragments) {
  4. super(fm);
  5. // TODO Auto-generated constructor stub
  6. mFragments=fragments;
  7. }
  8. @Override
  9. public Fragment getItem(int arg0) {
  10. // TODO Auto-generated method stub
  11. return mFragments.get(arg0);
  12. }
  13. @Override
  14. public int getCount() {
  15. // TODO Auto-generated method stub
  16. return mFragments.size();
  17. }
  18. }

这里有三个函数,根据第一部分的官方文档,可知,对于FragmentPagerAdapter的派生类,只重写getItem(int)和getCount()就可以了。

对于构造函数,这里申请了一个Fragment的List对象,用于保存用于滑动的Fragment对象,并在创造函数中初始化:

[java] view plaincopy

  1. public FragAdapter(FragmentManager fm,List<Fragment> fragments) {
  2. super(fm);
  3. // TODO Auto-generated constructor stub
  4. mFragments=fragments;
  5. }

然后在getItem(int arg0)中,根据传来的参数arg0,来返回当前要显示的fragment,下面是getItem的官方解释,难度不大,不再细讲。

public abstract Fragment getItem (int position)

Return the Fragment associated with a specified position.

最后,getCount()返回用于滑动的fragment总数;

从构造函数所以看出,我们要构造Fragment的集合才行,所以下面我们就先产生我们所需要的Fragment类;

2、三个Fragment类

第一个Fragment类:

XML:(layout1.xml)

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:background="#ffffff"
  6. android:orientation="vertical" >
  7. <Button android:id="@+id/fragment1_btn"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. android:text="show toast"
  11. />
  12. </LinearLayout>

在其中加入了一个Btn

Java代码:

[java] view plaincopy

  1. public class Fragment1 extends Fragment {
  2. @Override
  3. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  4. Bundle savedInstanceState) {
  5. // TODO Auto-generated method stub
  6. View view= inflater.inflate(R.layout.layout1, container, false);
  7. //对View中控件的操作方法
  8. Button btn = (Button)view.findViewById(R.id.fragment1_btn);
  9. btn.setOnClickListener(new View.OnClickListener() {
  10. @Override
  11. public void onClick(View v) {
  12. // TODO Auto-generated method stub
  13. Toast.makeText(getActivity(), "点击了第一个fragment的BTN", Toast.LENGTH_SHORT).show();
  14. }
  15. });
  16. return view;
  17. }
  18. }

在onCreateView()中返回要显示的View,上面这段代码简单演示了如何对视图里的控件进行操作,难度不大,不再细讲,如果对Fragment不太熟悉的同学,先看看这篇文章:《Android Fragment完全解析,关于碎片你所需知道的一切》

第二个Fragment类:

XML代码:(layout2.xml)原生代码,没有做任何更改

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:background="#ffff00"
  6. android:orientation="vertical" >
  7. </LinearLayout>

java代码:

[java] view plaincopy

  1. public class Fragment2 extends Fragment {
  2. @Override
  3. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  4. Bundle savedInstanceState) {
  5. // TODO Auto-generated method stub
  6. View view=inflater.inflate(R.layout.layout2, container, false);
  7. return view;
  8. }
  9. }

第三个Fragment类:

XML代码:(layout3.xml)同样,原生代码,没做任何更改

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:background="#ff00ff"
  6. android:orientation="vertical" >
  7. </LinearLayout>

java代码:

[java] view plaincopy

  1. public class Fragment3 extends Fragment {
  2. @Override
  3. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  4. Bundle savedInstanceState) {
  5. // TODO Auto-generated method stub
  6. View view=inflater.inflate(R.layout.layout3, container, false);
  7. return view;
  8. }
  9. }

3、主activity实现

核心代码:

[java] view plaincopy

  1. public class MainActivity extends FragmentActivity {
  2. @Override
  3. protected void onCreate(Bundle savedInstanceState) {
  4. super.onCreate(savedInstanceState);
  5. setContentView(R.layout.activity_main);
  6. //构造适配器
  7. List<Fragment> fragments=new ArrayList<Fragment>();
  8. fragments.add(new Fragment1());
  9. fragments.add(new Fragment2());
  10. fragments.add(new Fragment3());
  11. FragAdapter adapter = new FragAdapter(getSupportFragmentManager(), fragments);
  12. //设定适配器
  13. ViewPager vp = (ViewPager)findViewById(R.id.viewpager);
  14. vp.setAdapter(adapter);
  15. }
  16. }

首先有一个最值得注意的地方:Activity派生自FragmentActivity,其实这是有关Fragment的基础知识,只有FragmentActivity才能内嵌fragment页面,普通Activity是不行的。

这段代码主要分为两步,第一步:构造适配器;第二步:设定适配器。

先看构造适配器的过程:

[java] view plaincopy

  1. //构造适配器
  2. List<Fragment> fragments=new ArrayList<Fragment>();
  3. fragments.add(new Fragment1());
  4. fragments.add(new Fragment2());
  5. fragments.add(new Fragment3());
  6. FragAdapter adapter = new FragAdapter(getSupportFragmentManager(), fragments);

构造一个fragment列表,然后将上面的三个Fragment类对应的实例添加进去,最后生成FragAdapter实例。
至于第二步,设定适配器,没什么好讲的。

4、可能出现的问题

问题:在MainActivity中,当写到这句:fragments.add(new Fragment1()); 向Fragment列表中添加Fragement对象实例时,会提示“无法将Fragment1()转换为fragment”

解决办法 :这是因为导入包不一致,一般的问题在于:在Fragment1中导入的是android.app.Fragment, 而在这里导入类确是:android.support.v4.app.Fragment,包不同当然无法转换,统一导入为android.support.v4.app.Fragment之后就正常了.参考文章《android之cannot convert from Fragment1 to Fragment》

转载出处: ViewPager 详解(五)-----使用Fragment实现ViewPager滑动

时间: 2024-08-04 17:59:01

ViewPage+Fragment的使用用法的相关文章

Android Fragment和FragmentActivity用法

Android Fragment是Android4.0以上才有的:而FragmentActivity是为了兼容4.0以下版本的Fragment使用的. 所以如果你想兼容4.0以下Android版本使用Fragment的话,框架Activity需要继承FragmentActivity,FragmentActivity这个类是在android.support.v4.app.FragmentActivity里的. 下面介绍2种用法: 1.继承Activity的. (这个只针对4.0以上的Android

Android典型界面设计——ViewPage+Fragment实现区域顶部tab滑动切换

一.问题描述 本系列将结合案例应用,陆续向大家介绍一些Android典型界面的设计,首先说说tab导航,导航分为一层和两层(底部区块+区域内头部导航),主要实现方案有RadioGroup+ViewPage+Fragment.Viewpager Indicator.ActionBar Tabs.FragmentTabHost+Fragment等,下面我们先采用RadioGroup+ViewPage+Fragment实现区域头部导航. 如图所示: 二.案例主要组件 1.先看一下MainActivit

高仿微信主界面:ViewPage+Fragment 不预加载Fragment 也不会销毁Fragment

微信支持下面四个Tab滑动,之前做的demo,遇到两个问题,1:Fragment会预加载,2:创建过的Fragment,来回滑动,会销毁重新创建.今天我这个demo,就要解决这两个问题.第一个问题需要导入一个新的V4包,最后我会提供,ViewPage要设置 mViewPager .setOffscreenPageLimit(0);这样的就能解决预加载的问题.第二个问题:我贴上代码: package com.example.fragmentviewpage; import java.util.Ar

android Fragment 内嵌套 ViewPage+Fragment

最近做了一个界面一个Fragment内嵌套ViewPage,ViewPage里显示多个Fragment,遇到问题的总结. 1.在主Fragment初始化适配器要传的FragmentManager 必须是getChildFragmentManager(). 如果使用mActivity.getSupportFragmentManager() 将无法显示ViewPage的内容. 2.其中还是用TabPageIndicator这个ViewPage做指示器,动态更新指示器的内容要要调用TabPageInd

ViewPage+Fragment(仿微信切换带通知)

第一步 : 布局文件 activity_main.xml <?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="m

Fragment的基本用法

一.Fragment主要用到的API: 1.Fragment 类-----用来创建碎片 2.FragmentManager 类 ----为管理Activity中Fragment,用于Activity与Fragment之间进行交互. 3.FragmentTransaction 类 ---用碎片管理器创建碎片事务,用碎片事务来执行碎片的添加,移除,替换,显示,隐藏等操作 二.fragment 可认为是一个轻量级的Activity,但不同与Activity,它是要嵌到Activity中来使用的,它用来

ViewPage+Fragment+indicator+Tabhost效果

下载地址: https://github.com/asijack/ViewPage-Fragment-indicator-TabhostDemo 先看下效果: 我之前一篇文章http://www.cnblogs.com/asijack/p/4239445.html 也是这种滑动的效果,但是那个不是我想要的效果,我要的是这种滑动的时候游标跟着滑动的效果,而不是滑动结束后才动的. demo需要引入一个libraries :ListSamples-library 需要注意的是libraries和dem

android关于fragment的构造函数用法建议

错误信息 Avoid non-default constructors in fragments: use a default constructor plus Fragment#setArguments(Bundle) instead: 因为原生的fragment的管理和在屏幕上显示,是推荐不要在任何继承fragment类里面,去创建类的构造方法,否则在运行时,会出现问题.如果你的fragment没有声明任何的构造函数,系统会自动帮你创建一个构造.除非你有声明一个带参的构造函数,才需要声明一个

Android第十五期 - Viewpage+Fragment页面滑动加载数据

代码已经整理过了,效果如下图: