安卓APP_ Fragment(1)—— Fragment概念、基础用法、动态变换、管理栈

摘自:安卓APP_ Fragment(1)—— Fragment概念、基础用法、动态变换、管理栈
作者:丶PURSUING
发布时间: 2021-04-15 23:32:31
网址:https://blog.csdn.net/weixin_44742824/article/details/115716359

目录

  • 一、Fragment是什么
    • Fragment的产生原因
    • Fragment两个重要特性
      • 具备生命周期
      • 寄宿在Activity中运行
  • 二、Fragment基础用法
    • 简单演示
    • (1)New创建一个Activity
    • (2)添加一个空白的Fragment
    • (3)Fragment 绑定到宿主Activity
    • (4)在Activity中创建两个Fragment
    • 具体细节在代码中呈现
  • 三、Fragment的动态变换
    • 简单演示
    • (1)创建FrameLayout布局
    • (2)创建Button的响应事件
    • (3)在点击事件中切换fragment到FragmentLayout
    • (4)实现切换的方法:replaceFragment
    • 具体细节在代码中呈现
  • 四、fagment有属于自己的管理栈

一、Fragment是什么

Fragment的产生原因

Fragment很像是小的,简短的Activity

Fragment在安卓3.0后才开始出现,当时安卓系统开始大量地应用在平板上。为了平板界面动态的灵活设计,为了能够让Activity更加简洁地配置界面,在平板的开发中就大量的使用了Fragment。

具体可以体现在下图中:点击左边的节目列表,就能跳转到对应的新的界面
在这里插入图片描述
而在手机上,新闻列表(Fragment)通常占满一整个屏幕,点击后跳转到具体的内容即新的界面(Fragment),可以让这两个Fragment运行在同一个Activity之上,也可以在不同的Activity上。

而当下,Fragment从原来满足平板设计的需求,也变成了实现UI的转变。

Fragment两个重要特性

具备生命周期

跟以往介绍的view不同,具备有自己的生命周期,因为有生命周期,所以:


(1)可以在一个Activity中组合使用多个Fragment,从而构成多窗格的界面。
(2)可以同时在多个Activity重复使用某一个Fragment
(3)Fragment还可以自己接收输入事件(所以可以在Activity正在运行的时候动态添加和删除Fragment)


这样的效果可以让Fragment相对于Activity更加地灵活,可以将前者视为后者的模块化组成部分。

寄宿在Activity中运行

必须要委托在Activity中才能运行(必须有宿主),意味着Fragment生命周期受到Activity的影响,当Activity生命周期结束时,其也跟着结束。

二、Fragment基础用法

用的最多的就是Fragment + ViewPage 构成的可以滑动切换界面的效果,类似于微信的界面(网图),当然后面深入了才能实现,在这一篇章仅仅是入门。
在这里插入图片描述

简单演示

在同一个Activity中添加两个Fragment,实现如下效果:Fragment中的Button响应了点击事件并把TextView中的内容更改。

在这里插入图片描述

实现过程如下,一起体验Fragment的创建:

(1)New创建一个Activity

新建工程后先把原来自带的Mainactivity.java和其对应的xml布局文件删除,我们自己新建一个Mainactivity.java

在这里插入图片描述创建后,选择加载Activity。
在这里插入图片描述
创建后结果如下图:
在这里插入图片描述与上图对比,删除一些文件,并且修改activity_main.xml为空白模板:
在这里插入图片描述

(2)添加一个空白的Fragment

在这里插入图片描述修改BlankFragment1.java的内容,留下下图中的基本的框架:
在这里插入图片描述
然后在BlankFragment1.java对应的xml文件中添加一个TextView和一个Button方便后续演示
在这里插入图片描述

BlankFragment1.java中解析fragment_blank1.xml
在这里插入图片描述

添加Fragment响应点击事件:
在这里插入图片描述

(3)Fragment 绑定到宿主Activity

activity_main.xml中添加:
在这里插入图片描述

(4)在Activity中创建两个Fragment

如法炮制,暴力复制快速演示:

直接复制原来的BlankFragement1.javaBlankFragement2.java
在这里插入图片描述

activity_main.xml中添加(注意更改id哦)
在这里插入图片描述

具体细节在代码中呈现

MainActivity.java

public class MainActivity extends AppCompatActivity {@Override//onCreat创建一个activity的过程protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity"><!--    这个name意味着我们创建的是BlankFragment1,相当于进行了绑定fragment作为一个特殊的控件,必须存在id--><fragment android:name="com.example.myfragment.BlankFragment1"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_weight="1"android:id="@+id/fragment1"/><fragment android:name="com.example.myfragment.BlankFragment1"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_weight="1"android:id="@+id/fragment2"/></LinearLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

BlankFragment1.javaBlankFragment2.java一毛一样

public class BlankFragment1 extends Fragment {private View root;//创建的全局变量private TextView tv;private Button btn;@Override//在Activity中会使用setContentView进行解析,而Fragment不一样public void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {//因为onCreateView是一个生命周期函数,要先进行判断,为null再解析xmlif(root == null) {//用inflater解析器进行xml解析//                          xml的副本,直接containerroot = inflater.inflate(R.layout.fragment_blank1, container, false);}//创建按键响应事件,按钮按下改变TextViewtv = root.findViewById(R.id.tv);btn = root.findViewById(R.id.btn);btn.setOnClickListener(new View.OnClickListener() {@Override//点击后把Textview中的文字修改public void onClick(View v) {tv.setText("i am find");}});//onCreateView的返回值为Viewreturn root;}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41

fagment_blank1.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:orientation="vertical"tools:context=".BlankFragment1"><!-- TODO: Update blank fragment layout --><TextViewandroid:layout_width="match_parent"android:layout_height="40dp"android:id="@+id/tv"android:textSize="20dp"android:textColor="#ff0000"android:text="hello_blank_fragment" /><Buttonandroid:layout_width="match_parent"android:layout_height="40dp"android:text="how are you?"android:id="@+id/btn"/></LinearLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

三、Fragment的动态变换

简单演示

演示说明:在main_activity.xml中创建有FragmentLayout布局,当点击按钮时,响应点击事件切换fragment到FragmentLayout上。

在这里插入图片描述

(1)创建FrameLayout布局

activity_main.xml中创建FrameLayout的布局。之后进行fragment的切换都是在这个布局上进行。
在这里插入图片描述

(2)创建Button的响应事件

首先要创建两个示例fragment,我这里直接创建的是空白(blank)的和列表(item)的
在这里插入图片描述
按钮监听:
在这里插入图片描述

(3)在点击事件中切换fragment到FragmentLayout

在这里插入图片描述

(4)实现切换的方法:replaceFragment

在这里插入图片描述

具体细节在代码中呈现

为了方便演示,直接new生成两个系统自带的fragment。
在这里插入图片描述
MainActivity.java

public class MainActivity extends AppCompatActivity implements View.OnClickListener{@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);Button button1 = findViewById(R.id.btn_1);//为button设置点击事件的回调函数有两个方法//(1)以前一直用的:直接在括号里面new View.OnClickListener(),产生一个匿名内部类//(2)把接口的实现放到上面的MainActivity,用类的方式来实现button1.setOnClickListener(this);//面向对象原则,自动进行类型的匹配Button button2 = findViewById(R.id.btn_2);button2.setOnClickListener(this);}@Override//当点击按钮时,就会触发这个回调函数,判断是哪个按钮点击后执行事件public void onClick(View v) {switch (v.getId()){case R.id.btn_1://在这里要创建一个空的fragment,然后创建对象,作为参数传入replaceFragment(new BlankFragment1());break;case R.id.btn_2:replaceFragment(new ItemFragment());}}//完成动态切换fragmentprivate void replaceFragment(Fragment fragment) {//专门用于管理fragment的类,用getSupportFragmentManager来获取FragmentManager fragmentManager = getSupportFragmentManager();//fragment的替换动作由transaction来完成FragmentTransaction transaction = fragmentManager.beginTransaction();//事务:把fragment替换到名为fm的FrameLayout上transaction.replace(R.id.fm,fragment);//完成上述事务的提交,这样才能执行transaction.commit();}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42

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="match_parent"android:orientation="vertical"><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/btn_1"android:text="@string/change"/><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/btn_2"android:text="@string/replace"/><!--    除去按钮,剩余的空间都是FrameLayout--><FrameLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"android:id="@+id/fm"android:background="@color/teal_200"/></LinearLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

fragment_blank1.xml

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout 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"tools:context=".BlankFragment1"><!-- TODO: Update blank fragment layout --><TextViewandroid:layout_width="match_parent"android:layout_height="match_parent"android:background="#ffff00"android:textSize="40dp"android:text="@string/hello_blank_fragment" /></FrameLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

四、fagment有属于自己的管理栈

在上一小节 三、Fragment的动态变换 中,点一次返回键后就退出了。

体验fagment的入栈与出栈,理解fagment的管理栈
在这里插入图片描述

效果如下:

在这里插入图片描述
为何点击6此入栈五个呢?因为最后一个点击的正在显示界面。

具体的实现只需要在上一小节 三、Fragment的动态变换 方法中添加一句入栈代码。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/265994.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

谷歌五笔输入法电脑版_“五笔输入法”打字速度更快,为什么却没啥人用?

现如今&#xff0c;随着国内经济水平的不断发展&#xff0c;电脑和手机都已经不再是稀罕玩意&#xff0c;因为现在国内有很多的厂家都在生产手机和电脑&#xff0c;导致这些电子产品的价格下降&#xff0c;所以我们很轻易就能够买得起这样的产品。而在手机、电脑普及之后&#…

安卓APP_ Fragment(2)—— Activity与Fragment的通信

摘自&#xff1a;安卓APP_ Fragment&#xff08;2&#xff09;—— Activity与Fragment的通信 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-16 17:23:44 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/115743009 目录 Activity与Fragm…

java socket 判断Socket连接失效

要判断socket连接链路是否可用时&#xff0c;不能通过socket.isClosed() 和 socket.isConnected() 方法判断&#xff0c;要通过心跳包 socket.sendUrgentData(0xFF) 。 当第一次连接成功后&#xff0c; socket.isClosed() false, socket.isConnected()true&#xff0c;只有在自…

安卓APP_ Fragment(3)—— Fragment的生命周期

摘自&#xff1a;安卓APP_ Fragment&#xff08;3&#xff09;—— Fragment的生命周期 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-16 22:32:12 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/115768202 目录 Fragment生命周期函数一…

安卓APP_ 布局(8) —— 基于 RecyclerView 的 ViewPager2翻页

摘自&#xff1a;安卓APP_ 布局&#xff08;8) —— 基于 RecyclerView 的 ViewPager2翻页 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-20 15:37:54 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/115803077 viewpager2 是对Recycler…

安卓APP_ Fragment(4)—— Fragment + ViewPager2 模拟微信首页 (1)两者联动实现翻页

摘自&#xff1a;安卓APP_ Fragment&#xff08;4&#xff09;—— Fragment ViewPager2 模拟微信首页 &#xff08;1&#xff09;两者联动实现翻页 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-20 17:46:59 网址&#xff1a;https://blog.csdn.net/weixin_4474…

Linux网络编程(Socket)

目录网络编程&#xff08;Socket&#xff09;概述引入网络编程通识扫盲socket套接字套接字描述符字节序socket编程步骤Linux提供的API简析创建套接字即连接协议[socket]&#xff08;服、客&#xff09;绑定IP和端口[bind]&#xff08;服&#xff09;地址转换api字节序转换api监…

嵌入式开发概述(树莓派介绍)

目录嵌入式定义嵌入式芯片选型ARM架构ARM树莓派嵌入式定义 国内普遍认同的嵌入式系统的定义是以应用为中心&#xff0c;以计算机技术为基础&#xff0c;软硬件可裁剪&#xff0c;适应应用系统对功耗、可靠性、成本、体积、功耗等严格要求的专用计算机系统。 嵌入式系统是软件和…

ubuntu 16gcc g++版本降级

打算在ubuntu16上编译linux3.4.66内核&#xff0c;但是遇到 In file included from include/linux/compiler.h:48:0, from include/linux/stddef.h:4, from include/linux/posix_types.h:4, from include/linux/types.h:17, from include/linux/page-flags.h:8, from kern…

android 系统gpu 调试_【资讯】高通公布首批可OTA更新GPU驱动手机:谷歌Pixel 4/三星S10在列...

文章转载自&#xff1a;iT之家原文链接&#xff1a;https://www.ithome.com/0/479/483.htm(IT之家3月25日消息) 谷歌今天宣布了一系列面向游戏开发者的新工具&#xff1a;Google Play Asset Delivery、Android性能调节器&#xff0c;Android GPU检查器和Cloud Firestore等&…

cURL库

一、cURL库可以做什么 1.cURL是一个文件传输工具&#xff0c;支持很多协议 二、cURL库的用法 1.初始化 $urlcurl_init() 2.设置选项 curl_setopt($url,CURLOPT_URL&#xff0c;"http://www.baidu.com") curl_setopt($url,string option,mixed value) 3.执行cURL会话 …

树莓派刷机

目录准备刷机重刷准备 SD卡&#xff08;一般16G以上&#xff0c;这里我用的8G&#xff09; 读卡器 Win32DiskImager&#xff08;将镜像烧到SD卡的软件&#xff09;&#xff0c;在这里下载&#xff1a;https://download.csdn.net/download/zhuguanlin121/18329615?spm1001.201…

linux3.4.2移植总结(s3c2440)

环境&#xff1a;Linux version 3.5.0-23-generic (builddkomainu) (gcc version 4.6.3 (Ubuntu/Linaro 4.6.3-1ubuntu5) ) ubuntu12 目标板&#xff1a;JZ2440 待移植内核&#xff1a;3.4.2 交叉编译器&#xff1a;arm-linux-gcc-4.3.2 1. make s3c2410_defconfig //使…

判断图有无环_浅谈什么是图拓扑排序

1 引言 在工程实践中,一个工程项目往往由若干个子项目组成。这些子项目间往往有两种关系:  (1) 先后关系&#xff0c;即必须在某个项完成后才能开始实施另一个子项目。  (2) 子项目间无关系&#xff0c;即两个子项目可以同时进行,互不影响。例如&#xff1a;在工厂里产品的…

Source Insight 4.0安装教程(PS:附安装包及卸载重新安装等注意事项)

目录一、Source Insight 4.0安装包二、删除配置文件&#xff08;初次安装忽略此步骤&#xff09;1、清除注册表信息&#xff1a;2、删除全局配置信息&#xff1a;三、安装步骤1、解压2、安装3、替换4、破解5、安装提示unable to open or create...解决方案一、Source Insight 4…

通过远程(vnc)无法打开qtcreator

最近打算移植qt程序到板子上于是&#xff0c;在ubuntu物理机上装了qt开发环境&#xff0c;通过远程桌面链接上去写qt。 但是远程老是点不开qtcreator。于是通过命令行启动 出了报错信息&#xff0c;应该和xserver 服务有关&#xff0c;没有深入了解错误 下面是我的解决方案&a…

iOS开发UI篇—使用xib自定义UItableviewcell实现一个简单的团购应用界面布局

iOS开发UI篇—使用xib自定义UItableviewcell实现一个简单的团购应用界面布局 iOS开发UI篇—使用xib自定义UItableviewcell实现一个简单的团购应用界面布局 一、项目文件结构和plist文件 二、实现效果 三、代码示例 1.没有使用配套的类&#xff0c;而是直接使用xib文件控件tag值…

硬件模块化开发的例子:LD3320语音模块与Source Insight的使用

目录硬件模块化开发的行情LD3320语音模块使用手册介绍&#xff1a;语音模块验货测试硬件连接效果图测试结果良好Source Insight代码查看器创建工程修改字体配色方案中文乱码关联代码语音识别模块代码分析语音识别模块二次开发硬件模块化开发的行情 LD3320语音模块使用手册介绍&…

ubuntu 远程桌面及Qt安装

环境&#xff1a; ubunut14 x64 目标&#xff1a;通过vnc远程桌面&#xff0c;在ubuntu 上编写qt程序 1.安装远程桌面 apt-get install xrdp vnc4server xbase-clients dconf-editor #安装xrdp&#xff0c;vnc4server apt-get install gnome-panel gnome-settings-daemon m…

awk分割字符

为什么80%的码农都做不了架构师&#xff1f;>>> str1|_|2|_|3|_||_|4|_|5|_|6|_||_|7|_|8|_|9; 期望分割成 1|_|2|_|3 4|_|5|_|6 7|_|8|_|9 也就是以|_||_|做分割符&#xff0c;但是&#xff0c;字符段长度不确定&#xff0c;有可能分割成3段&#xff0c;也可能会有…