展会信息港展会大全

Android新手入门教程(十二):初识Fragment
来源:互联网   发布日期:2015-09-29 11:03:33   浏览:1324次  

导读:在之前的教程中,我们已经学习了什么是Activity以及如何使用它。在一个小屏幕的设备上,一个activity通常占据了整个屏幕,同时显示各种UI视图组件。Activity实际上就是视图的容器...

在之前的教程中,我们已经学习了什么是Activity以及如何使用它。在一个小屏幕的设备上,一个activity通常占据了整个屏幕,同时显示各种UI视图组件。Activity实际上就是视图的容器。然后,当一个activity被显示在一个大屏幕的设备上,例如平板电脑,总会显得有些不适应。因为屏幕太大了,activity中的所有UI组件要充满整个屏幕,这样一来,视图的层次结构就很复杂了。一个更好的办法是使用一种“轻量级”的activity,每个“轻量级”activity包含自己的视图,互不干扰。在运行期间,根据屏幕的方向和尺寸,一个activity可以包含一个或多个“轻量级”activity。在Android3.0以上的版本,这种“轻量级”的activity叫做Fragment.

可以把Fragment想象成Activity的另外一种形式。你创建fragments去包含UI组件,就像创建activities那样。但是,Fragment总是被嵌在Activity中。

1.创建一个名为Fragments的工程。

2.在res/layout文件夹下,新建一个叫fragment1.xml的文件。

[java] <?xml version="1.0" encoding="utf-8"?>

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

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:background="#00FF00"

android:orientation="vertical" >

<TextView

android:id="@+id/lblFragment1"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="This is fragment #1"

android:textColor="#000000"

android:textSize="25sp" />

</LinearLayout>

<?xml version="1.0" encoding="utf-8"?>

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

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:background="#00FF00"

android:orientation="vertical" >

<TextView

android:id="@+id/lblFragment1"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="This is fragment #1"

android:textColor="#000000"

android:textSize="25sp" />

</LinearLayout>3.在res/layout文件夹下,新建一个叫fragment2.xml的文件。

[java] <?xml version="1.0" encoding="utf-8"?>

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

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:background="#FFFE00"

android:orientation="vertical" >

<TextView

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="This is fragment #2"

android:textColor="#000000"

android:textSize="25sp" />

<Button

android:id="@+id/btnGetText"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:onClick="onClick"

android:text="Get text in Fragment #1"

android:textColor="#000000" />

</LinearLayout>

<?xml version="1.0" encoding="utf-8"?>

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

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:background="#FFFE00"

android:orientation="vertical" >

<TextView

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="This is fragment #2"

android:textColor="#000000"

android:textSize="25sp" />

<Button

android:id="@+id/btnGetText"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:onClick="onClick"

android:text="Get text in Fragment #1"

android:textColor="#000000" />

</LinearLayout>4.main.xml中的代码。

[java] <?xml version="1.0" encoding="utf-8"?>

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

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:orientation="horizontal" >

<fragment

android:id="@+id/fragment1"

android:name="net.learn2develop.Fragments.Fragment1"

android:layout_width="0px"

android:layout_height="match_parent"

android:layout_weight="1" />

<fragment

android:id="@+id/fragment2"

android:name="net.learn2develop.Fragments.Fragment2"

android:layout_width="0px"

android:layout_height="match_parent"

android:layout_weight="1" />

</LinearLayout>

<?xml version="1.0" encoding="utf-8"?>

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

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:orientation="horizontal" >

<fragment

android:id="@+id/fragment1"

android:name="net.learn2develop.Fragments.Fragment1"

android:layout_width="0px"

android:layout_height="match_parent"

android:layout_weight="1" />

<fragment

android:id="@+id/fragment2"

android:name="net.learn2develop.Fragments.Fragment2"

android:layout_width="0px"

android:layout_height="match_parent"

android:layout_weight="1" />

</LinearLayout>5.新建两个类:Fragment1.java和Fragment2.java。

6.Fragment1.java中的代码。

[java] package net.learn2develop.Fragments;

import android.app.Activity;

import android.app.Fragment;

import android.os.Bundle;

import android.util.Log;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

public class Fragment1 extends Fragment {

@Override

public View onCreateView(LayoutInflater inflater, ViewGroup container,

Bundle savedInstanceState) {

Log.d("Fragment 1", "onCreateView");

// ---Inflate the layout for this fragment---

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

}

}

package net.learn2develop.Fragments;

import android.app.Activity;

import android.app.Fragment;

import android.os.Bundle;

import android.util.Log;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

public class Fragment1 extends Fragment {

@Override

public View onCreateView(LayoutInflater inflater, ViewGroup container,

Bundle savedInstanceState) {

Log.d("Fragment 1", "onCreateView");

// ---Inflate the layout for this fragment---

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

}

}

7.Fragment2.java中的代码。

[java] package net.learn2develop.Fragments;

import android.app.Fragment;

import android.os.Bundle;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import android.widget.Button;

import android.widget.TextView;

import android.widget.Toast;

public class Fragment2 extends Fragment {

@Override

public View onCreateView(LayoutInflater inflater, ViewGroup container,

Bundle savedInstanceState) {

// ---Inflate the layout for this fragment---

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

}

}

package net.learn2develop.Fragments;

import android.app.Fragment;

import android.os.Bundle;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import android.widget.Button;

import android.widget.TextView;

import android.widget.Toast;

public class Fragment2 extends Fragment {

@Override

public View onCreateView(LayoutInflater inflater, ViewGroup container,

Bundle savedInstanceState) {

// ---Inflate the layout for this fragment---

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

}

}

8. 调试。

效果图:

摘自horsttnann的专栏

赞助本站

人工智能实验室

相关热词: android开发 教程

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港