Android App开发中创建Fragment组件的教程

你可以认为Fragment作为Activity的一个模块部分,有它自己的生命周期,获取它自己的事件,并且你可以在Activity运行的时候添加或者移除它(有点像你可以在不同的Activity中重用的一个”子Activity“)。这节课程讲述如何使用Support Library继承Fragment类,所以你的应用程序仍然是兼容运行的系统版本低于Android1.6的设备。

注意:如果你决定你的应用要求的最低的API级别是11或者更高,你不需要使用Support Library,反而能使用Frameword内的Fragment和相关API。要注意,这节课程主要讲使用Support Library的API,它使用特殊的包名,并且有些时候和包含在平台中版本API的名称略有不同。

在你开始这节课程之前,你必须配置你的Android项目使用Support Library。如果之前你没有使用过Support Library,遵照Support Library Setup文档,配置你的项目使用v4 Library。然而,你也能包含在你的Activity中Action Bar

创建Fragment
你可以把一个Fragment想象成一个Activity的模块区域,它有自己的生命周期,接收它自己的输入事件,并且你可以在Activity运行时添加和删除它(这有点像一个子Activity,你可以在不同的Activity中重用它们)。本节课向你介绍如何使用支持类库来扩展Fragment,以便让你的应用程序能够在像Android1.6那样的较旧版本上的兼容性。

注意:如果因为一些原因,你决定你的应用程序需要的API级别在11以上,那么你就不需要使用支持类库,并且可以使用框架内置的Fragment类和相关的API来代替。要注意的是本课的重点是使用支持类库中的API,它使用一个特殊的包签名,并且某些时候API的名称会比包含在平台内的版本有稍微的不同。

创建Fragment类

要创建一个Fragment,就要继承Fragment类,然后重写关键的生命周期方法,把你的应用程序逻辑插入其中,这跟Activity类类似。

创建Fragment时的一个不同点是,你必须使用onCreateView()回调来定义布局。实际上,为了获得一个正在运行的Fragment,这只是你所需要的唯一的回调方法。例如,下面是一个简单的指定了自己布局的Fragment:

import android.os.Bundle;

import android.support.v4.app.Fragment;

import android.view.LayoutInflater;

import android.view.ViewGroup;

public class ArticleFragment extends Fragment {

  @Override

  public View onCreateView(LayoutInflater inflater, ViewGroup container,

    Bundle savedInstanceState) {

    // Inflate the layout for this fragment

    return inflater.inflate(R.layout.article_view, container, false);

  }

}

就像一个Activity,Fragment应该实现其他的生命周期回调方法,从而允许你管理它在Activity中的状态(添加或删除),以及Activity在它生命周期状态间转换时的状态。例如,当Activity的onPause()方法被调用时,Activity中的任何Fragment也会接收到对onPause()方法的调用。

有关Fragment的生命周期和有效的回调方法,请看Fragments开发指南。

使用XML把一个Fragment添加到一个Activity中

Fragment是可复用的、模块化的UI组件,每个Fragment类的实例都必须跟一个父类是FragmentActivity的Activity相关联。通过在你的Activity布局XML文件内定义每个Fragment可以完成这种关联。

注意:FragmentActivity是一个支持类库中提供的特殊的Activity,它用于处理系统版本是API Level 11以前的Fragment。如果你使用的系统版本最低是API Level 11或更高,那么就就可以使用常规的Activity。

当屏幕被认为足够大时,下例布局文件就会把两个Fragment添加到一个Activity中(该文件被放在由large限定的目录名中)。

res/layout-large/news_articles.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

  android:orientation="horizontal"

  android:layout_width="fill_parent"

  android:layout_height="fill_parent">

  <fragment android:name="com.example.android.fragments.HeadlinesFragment"

       android:id="@+id/headlines_fragment"

       android:layout_weight="1"

       android:layout_width="0dp"

       android:layout_height="match_parent" />

  <fragment android:name="com.example.android.fragments.ArticleFragment"

       android:id="@+id/article_fragment"

       android:layout_weight="2"

       android:layout_width="0dp"

       android:layout_height="match_parent" />

</LinearLayout>

提示:关于给不同屏幕尺寸创建布局的信息,请看支持不同的屏幕尺寸。

以下是使用这个布局的Activity:

import android.os.Bundle;

import android.support.v4.app.FragmentActivity;

public class MainActivity extends FragmentActivity {

  @Override

  public void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);

    setContentView(R.layout.news_articles);

  }

}

注意:当你通过在布局XML文件中定义Fragment的方式把Fragment添加给Activity布局时,你不能在运行时删除该Fragment。如果你打算在用户交互期间切换Fragment,你就必须在Activity被首次启动时把Fragment添加到Activity中。

(0)

相关推荐

  • Android中Fragmen首选项使用自定义的ListPreference的方法

    首选项这个名词对于熟悉Android的朋友们一定不会感到陌生,它经常用来设置软件的运行参数. Android提供了一种健壮并且灵活的框架来处理首选项.它提供了简单的API来隐藏首选项的读取和持久化,并且提供了一个优雅的首选项界面. 几种常见的首选项: (1)CheckBoxPreference:用来打开或关闭某个功能 (2)ListPreference:用来从多个选项中选择一个值: (3)EditTextPreference:用来配置一段文字信息: (4)Preference:用来执行相关的自定

  • Android中Fragment子类及其PreferenceFragment的创建过程演示

    Fragment创建方式 Fragment有两种使用方式:静态方式 和 动态方式. 1. 静态方式 第一步:先定义一个Fragment子类. public class ExampleFragment extends Fragment { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { return inflater.infla

  • 浅谈Android App开发中Fragment的创建与生命周期

    Fragment是activity的界面中的一部分或一种行为.你可以把多个Fragment们组合到一个activity中来创建一个多面界面并且你可以在多个activity中重用一个Fragment.你可以把Fragment认为模块化的一段activity,它具有自己的生命周期,接收它自己的事件,并可以在activity运行时被添加或删除. Fragment不能独立存在,它必须嵌入到activity中,而且Fragment的生命周期直接受所在的activity的影响.例如:当activity暂停时

  • Android中使用DialogFragment编写对话框的实例教程

    Android提供alert.prompt.pick-list,单选.多选,progress.time-picker和date-picker对话框,并提供自定义的dialog.在Android 3.0后,dialog基于fragment,并对之前版本提供兼容支持库,也就是说对于开发者而言,dialog是基于DialogFragment的,但此时需要在应用中加入相关的兼容库. 和Windows或者网页JS的Dialog不同,Android的dialog是异步的,而不是同步的.对于同步的dialog

  • Android中ViewPager实现滑动指示条及与Fragment的配合

    自主实现滑动指示条 先上效果图: 1.XML布局 布局代码如下: <LinearLayout 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

  • Android应用开发中Fragment与Activity间通信示例讲解

    首先,如果你想在android3.0及以下版本使用fragment,你必须引用android-support-v4.jar这个包 然后你写的activity不能再继承自Activity类了,而是要继承android.support.v4.app.FragmentActivity,一些其他的父类也有相应的变化. 由于在android的实现机制中fragment和activity会被分别实例化为两个不相干的对象,他们之间的联系由activity的一个成员对象fragmentmanager来维护.fr

  • Android App在ViewPager中使用Fragment的实例讲解

    据说Android最推荐的是在ViewPager中使用FragMent,即ViewPager中的页面不像前面那样用LayoutInflater直接从布局文件加载,而是一个个Fragment.注意这里的Fragment 是android.support.v4.view包里的Fragment,而不是android.app包里的Fragment. 使用v4包里的Fragment的Activity必须继承自FragmentActivity. 其实使用Fragment与前面不使用Fragment非常类似:

  • Android中用onSaveInstanceState保存Fragment状态的方法

    在Fragment里面,利用onSaveInstanceState保存数据,并可在onActivityCreated里面恢复数据. public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); ... if (savedInstanceState != null) { // Restore the fragment's state here } } p

  • Android中的Fragment类使用进阶

    0.回顾 Fragment 代表 Activity 当中的一项操作或一部分用户界面. 一个 Activity 中的多个 Fragment 可以组合在一起,形成一个多部分拼接而成的用户界面组件,并可在多个 Activity 中复用.一个 Fragment 可被视为 Activity 中一个模块化的部分, 它拥有自己的生命周期,并接收自己的输入事件,在 Activity 运行过程中可以随时添加或移除它 (有点类似"子 Activity",可在不同的 Activity 中重用). Fragm

  • 实例探究Android开发中Fragment状态的保存与恢复方法

    我们都知道,类似 Activity, Fragment 有 onSaveInstanceState() 回调用来保存状态. 在Fragment里面,利用onSaveInstanceState保存数据,并可在onActivityCreated里面恢复数据. public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); ... if (savedInsta

随机推荐