安卓學習筆記20:Fragment入門
文章目錄
- 零、學習目標
- 一、Fragment概述
- 二、Fragment生命週期
- 三、教學案例——切換碎片
- (一)執行效果
- (二)涉及知識點
- (三)實現步驟
- 1、建立安卓應用【SwitchFragment】
- 2、將三張背景圖片拷貝到drawable目錄
- 3、主佈局資原始檔activity_main.xml
- 4、建立第一個碎片 - FirstFragment
- 5、建立第二碎片 - SecondFragment
- 6、建立第三個碎片 - ThirdFragment
- 7、字串資原始檔strings.xml
- 8、主介面類MainActivity
- 9、啟動應用,檢視效果
- 10、第一個碎片介面類 - FirstFragment
- 11、第二個碎片介面類 - SecondFragment
- 12、第三個碎片介面類 - ThirdFragment
- 13、修改主介面類 - MainActivity
- 14、啟動應用,檢視效果
零、學習目標
- 瞭解Fragment與Activity的關係
- 掌握Fragment的生命週期
- 學會編寫多Fragment安卓程式
一、Fragment概述
- Fragment是android3.0引入的心的API,它代表Activity的子模板,所以可以把fragment理解為Activity片段。
- Fragment必須被“嵌入”Avtivity中使用,因此Fragment也擁有自己的生命週期,不過Fragment的生命週期受Activity所控制,也就是說Activity停止的時候,Activity中所有的Fragment都會被停止。其他狀態也是一樣。
二、Fragment生命週期
三、教學案例——切換碎片
(一)執行效果
(二)涉及知識點
- Activity (活動視窗)
- Fragment(碎片、片段) - 碎片化學習(Fragmental Learning)
- TextView(標籤)
- Button(按鈕)
- GestureDetector(手勢偵測器)
- 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、啟動應用,檢視效果
相關文章
- 安卓初學基礎學習筆記安卓筆記
- git入門學習筆記Git筆記
- Docker入門學習筆記Docker筆記
- Unity學習筆記--入門Unity筆記
- TS入門學習筆記筆記
- 【PostgreSQL】入門學習筆記SQL筆記
- JavaScript入門學習學習筆記(上)JavaScript筆記
- 後端工程師入門安卓開發筆記(一)後端工程師安卓筆記
- HTML入門學習筆記(二)HTML筆記
- React入門指南(學習筆記)React筆記
- pandas 學習筆記 (入門篇)筆記
- Go 入門指南學習筆記Go筆記
- MySQL學習筆記---入門使用MySql筆記
- Dubbo學習筆記(一) 入門筆記
- JavaScript入門-學習筆記(一)JavaScript筆記
- 安卓關閉fragment安卓Fragment
- 安卓學習筆記---開篇(目錄結構)安卓筆記
- JavaScript學習筆記1—快速入門JavaScript筆記
- iOS學習筆記39 ReactiveCocoa入門iOS筆記React
- redis學習筆記1: Redis入門Redis筆記
- webpack 學習筆記:入門介紹Web筆記
- node 學習筆記 基礎入門筆記
- python學習筆記——jieba庫入門Python筆記Jieba
- Elasticsearch入門學習重點筆記Elasticsearch筆記
- CANopen學習筆記(一)CANopen入門筆記
- 【Laravel 入門教程】學習筆記 1Laravel筆記
- 【MongoDB學習筆記】MongoDB 快速入門MongoDB筆記
- java學習筆記1(入門級)Java筆記
- 爬蟲入門學習筆記3爬蟲筆記
- 記一次flink入門學習筆記筆記
- 微信小程式入門學習筆記微信小程式筆記
- SpringMVC學習筆記之---簡單入門SpringMVC筆記
- SpringBoot整合ElasticSearch 入門demo學習筆記Spring BootElasticsearch筆記
- webpack4入門學習筆記(一)Web筆記
- webpack4入門學習筆記(二)Web筆記
- 深度學習入門筆記——Transform的使用深度學習筆記ORM
- 深度學習入門筆記——DataLoader的使用深度學習筆記
- substrate學習筆記2:substrate快速入門筆記