安卓开发入门教程-Fragment
发布日期:2021-06-29 18:30:14
浏览次数:2
分类:技术文章
本文共 2993 字,大约阅读时间需要 9 分钟。
关注 ,免费获取全套安卓开发学习资料
什么是Fragment
Activity是整个看到的界面,而Activity则可以继续分割出多个Fragment. Fragment最初是为了在平板电脑充分利用空间,但是手机端也经常使用,主要目的是共用屏幕上某一块区域.
如下面一种界面,上面蓝色框是几个功能(推荐、应用、游戏等)共用的显示区域,当用户切换到不同的功能页时,就将共用显示区域内容替换为对应的功能Fragment.使用单个Fragment样例
效果图:
手动创建Fragment
- 在工程目录中单击右键,选择“New>Fragment>Fragment(Blank)”
- 在窗口中设置Fragment名称,对应布局文件名称.
- 默认创建的Fragment有点复杂,简化后如下:
class BlankFragment : Fragment() { override fun onCreateView( inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle? ): View? { return inflater.inflate(R.layout.fragment_blank, container, false) }}
- 在Activity对应布局文件中增加用于容纳Fragment布局容器 修改activity_main.xml,添加一个FrameLayout,命名为containerLayout.
在Activity中加载该Fragment
下面演示点击button1按钮时,从MainActivity跳转到Main2Activity
replaceFragment(BlankFragment(), R.id.containerLayout)
完整代码如下:
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) replaceFragment(BlankFragment(), R.id.containerLayout) } private fun replaceFragment(fragment: Fragment, containerId: Int) = supportFragmentManager.beginTransaction().replace(containerId, fragment).commit()}
使用多个Fragment样例
多个Fragment利用同一块区域进行内容展示,一般可以通过标签页进行切换.
效果图
创建第一个Fragment及对应布局文件
- 第一个Fragment
class FirstFragment : Fragment() { override fun onCreateView( inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle? ): View? { return inflater.inflate(R.layout.fragment_first, container, false) }}
- 第一个Fragment对应布局:fragment_first.xml
创建第二个Fragment及对应布局文件
- 第二个Fragment
class SecondFragment : Fragment() { override fun onCreateView( inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle? ): View? { return inflater.inflate(R.layout.fragment_second, container, false) }}
- 第二个Fragment对应布局:fragment_second.xml
修改Activity对应的布局文件,展示两个底部标签.
下面代码中id为bottomLayout的布局,里面放了两个标签,用来点击切换页面上部containerLayout中的内容.
Activity代码中做Fragment加载及切换
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) //默认加载第一个Fragment replaceFragment(FirstFragment(), R.id.containerLayout) //对page1Tv控件添加点击事件,点击后切换至FirstFragment page1Tv.setOnClickListener { replaceFragment(FirstFragment(), R.id.containerLayout) } //对page2Tv控件添加点击事件,点击后切换至SecondFragment page2Tv.setOnClickListener { replaceFragment(SecondFragment(), R.id.containerLayout) } } private fun replaceFragment(fragment: Fragment, containerId: Int) = supportFragmentManager.beginTransaction().replace(containerId, fragment).commit()}
完整源代码
安卓开发入门教程系列汇总
开发语言学习
UI控件学习系列
关注头条号,第一时间获取最新文章:
转载地址:https://cxyxy.blog.csdn.net/article/details/108092589 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
关注你微信了!
[***.104.42.241]2024年04月24日 04时07分58秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
嵌入式工程师
2019-04-30
嵌入式系统学习入门
2019-04-30
嵌入式系统学习入门-UBOOT
2019-04-30
移植wifi无线网卡到mini2440上全过程
2019-04-30
NFS使用方法详解
2019-04-30
LINUX下的设备驱动程序
2019-04-30
_IO, _IOR, _IOW, _IOWR 宏的用法与解析
2019-04-30
做DSP最应该懂得157个问题
2019-04-30
Jenkins 连接github
2019-04-30
android中是Aspect 进行埋点笔记
2019-04-30
php 魔术方法 __invoke()
2019-04-30
php_sapi_name
2019-04-30
Vue 节流(throttle)和防抖(debounce)
2019-04-30
小程序初始页面地址修改
2019-04-30
微信小程序使用腾讯地图
2019-04-30
http-server的安装和使用(vue 打包后项目运行)
2019-04-30
vuex中使用typescript
2019-04-30