安卓學習筆記20:Fragment入門

howard2005發表於2020-10-27

零、學習目標

  1. 瞭解Fragment與Activity的關係
  2. 掌握Fragment的生命週期
  3. 學會編寫多Fragment安卓程式

一、Fragment概述

  1. Fragment是android3.0引入的心的API,它代表Activity的子模板,所以可以把fragment理解為Activity片段。
  2. Fragment必須被“嵌入”Avtivity中使用,因此Fragment也擁有自己的生命週期,不過Fragment的生命週期受Activity所控制,也就是說Activity停止的時候,Activity中所有的Fragment都會被停止。其他狀態也是一樣。

二、Fragment生命週期

在這裡插入圖片描述

三、教學案例——切換碎片

(一)執行效果

(二)涉及知識點

  1. Activity (活動視窗)
  2. Fragment(碎片、片段) - 碎片化學習(Fragmental Learning)
  3. TextView(標籤)
  4. Button(按鈕)
  5. GestureDetector(手勢偵測器)
  6. GestureListener(手勢監聽器)

(三)實現步驟

1、建立安卓應用【SwitchFragment】

在這裡插入圖片描述
在這裡插入圖片描述

2、將三張背景圖片拷貝到drawable目錄

在這裡插入圖片描述

3、主佈局資原始檔activity_main.xml

在這裡插入圖片描述

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/container"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

</FrameLayout>

4、建立第一個碎片 - FirstFragment

  • 基於模板建立
    在這裡插入圖片描述
  • 設定碎片名稱 - FirstFragment
    在這裡插入圖片描述
    在這裡插入圖片描述
  • 修改第一個碎片的佈局檔案fragment_first.xml
<?xml version="1.0" encoding="utf-8"?>
<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_parent"
    android:background="@drawable/img01"
    android:gravity="center"
    android:orientation="vertical"
    tools:context=".FirstFragment">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="20dp"
        android:text="@string/first_fragment"
        android:textColor="#ff0000"
        android:textSize="25sp" />

    <Button
        android:id="@+id/btnNextFragment"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="doNextFragment"
        android:text="@string/next_fragment"/>

</LinearLayout>

5、建立第二碎片 - SecondFragment

  • 基於模板建立
    在這裡插入圖片描述
    在這裡插入圖片描述
  • 修改第二個碎片的佈局檔案fragment_second.xml
<?xml version="1.0" encoding="utf-8"?>
<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_parent"
    android:background="@drawable/img01"
    android:gravity="center"
    android:orientation="vertical"
    tools:context=".FirstFragment">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="20dp"
        android:text="@string/second_fragment"
        android:textColor="#ff0000"
        android:textSize="25sp" />

    <Button
        android:id="@+id/btnNextFragment"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="doNextFragment"
        android:text="@string/next_fragment"/>

</LinearLayout>

6、建立第三個碎片 - ThirdFragment

  • 基於模板建立
    在這裡插入圖片描述
    在這裡插入圖片描述
  • 修改第三個碎片的佈局檔案fragment_third.xml
<?xml version="1.0" encoding="utf-8"?>
<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_parent"
    android:background="@drawable/img01"
    android:gravity="center"
    android:orientation="vertical"
    tools:context=".FirstFragment">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="20dp"
        android:text="@string/third_fragment"
        android:textColor="#ff0000"
        android:textSize="25sp" />

    <Button
        android:id="@+id/btnNextFragment"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="doNextFragment"
        android:text="@string/next_fragment"/>

</LinearLayout>

7、字串資原始檔strings.xml

在這裡插入圖片描述

<resources>
    <string name="app_name">切換碎片</string>
    <string name="first_fragment">第一個碎片</string>
    <string name="second_fragment">第二個碎片</string>
    <string name="third_fragment">第三個碎片</string>
    <string name="next_fragment">下一個碎片</string>
</resources>

8、主介面類MainActivity

在這裡插入圖片描述

package net.hw.switch_fragment;

import android.os.Bundle;

import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.FragmentManager;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 利用佈局資原始檔設定使用者介面
        setContentView(R.layout.activity_main);

        // 獲取碎片管理器
        FragmentManager fm = getSupportFragmentManager();

        // 在主容器裡新增第一個碎片
        fm.beginTransaction().add(R.id.container, new FirstFragment()).commit();
    }
}

9、啟動應用,檢視效果

在這裡插入圖片描述

  • 此時,單擊【下一個碎片】按鈕,程式會報錯
    在這裡插入圖片描述

10、第一個碎片介面類 - FirstFragment

在這裡插入圖片描述

package net.hw.switch_fragment;

import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import androidx.fragment.app.Fragment;

public class FirstFragment extends Fragment {

    public FirstFragment() {        
    }
    
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);    
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // 用第一個碎片佈局填充介面
        return inflater.inflate(R.layout.fragment_first, container, false);
    }
}

11、第二個碎片介面類 - SecondFragment

在這裡插入圖片描述

package net.hw.switch_fragment;

import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import androidx.fragment.app.Fragment;

public class SecondFragment extends Fragment {  

    public SecondFragment() {        
    }  

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);        
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // 用第二個碎片佈局填充介面
        return inflater.inflate(R.layout.fragment_second, container, false);
    }
}

12、第三個碎片介面類 - ThirdFragment

在這裡插入圖片描述

package net.hw.switch_fragment;

import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import androidx.fragment.app.Fragment;

public class ThirdFragment extends Fragment {
    public ThirdFragment() {
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // 用第三個碎片佈局填充介面
        return inflater.inflate(R.layout.fragment_second, container, false);
    }
}

13、修改主介面類 - MainActivity

package net.hw.switch_fragment;

import android.os.Bundle;
import android.view.View;

import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.FragmentManager;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 利用佈局資原始檔設定使用者介面
        setContentView(R.layout.activity_main);

        // 獲取碎片管理器
        FragmentManager fm = getSupportFragmentManager();

        // 在主容器裡新增第一個碎片
        fm.beginTransaction().add(R.id.container, new FirstFragment()).commit();
    }

    public void doNextFragment(View view) {
        // 獲取返回棧條目個數
        int count = getFragmentManager().getBackStackEntryCount();

        switch (count % 3) {
            case 0:
                getSupportFragmentManager().beginTransaction()
                        .addToBackStack("0")
                        .replace(R.id.container, (new SecondFragment()))
                        .commit();
                break;
            case 1:
                getSupportFragmentManager().beginTransaction()
                        .addToBackStack("1")
                        .replace(R.id.container, new ThirdFragment())
                        .commit();
                break;
            case 2:
                for (int i = 0; i < 2; i++) {
                    getSupportFragmentManager().popBackStack();
                }
                break;
        }
    }
}

14、啟動應用,檢視效果

在這裡插入圖片描述
在這裡插入圖片描述

相關文章