首页
/ Fragivity:像使用Activity一样使用Fragment

Fragivity:像使用Activity一样使用Fragment

2024-08-16 17:29:50作者:魏侃纯Zoe

在Android开发的世界里,Fragment一直是构建复杂用户界面的强大工具。然而,Fragment的生命周期和导航管理常常让开发者感到头疼。今天,我们要介绍的是一个革命性的开源项目——Fragivity,它让Fragment的使用变得像Activity一样简单直观。

项目介绍

Fragivity是一个基于Kotlin的开源库,旨在简化Fragment的管理和导航。通过Fragivity,开发者可以轻松实现单Activity架构的APP,同时享受到与Activity一致的生命周期管理、多种启动模式、转场动画、高效的通信机制以及友好的回退处理。

项目技术分析

Fragivity的核心优势在于其对Fragment生命周期的优化处理。它通过代理Fragment工厂确保Fragment的onStart/onStop方法正常调用,从而实现更合理的生命周期表现。此外,Fragivity支持多种启动模式(如Standard、SingleTop、SingleTask),并提供了丰富的转场动画选项,包括传统的动画和共享元素动画。

项目及技术应用场景

Fragivity适用于需要复杂导航和生命周期管理的Android应用。无论是电商应用、社交平台还是企业级应用,Fragivity都能帮助开发者构建流畅、高效的用户界面。特别是对于追求单Activity架构的开发者,Fragivity提供了一个优雅的解决方案。

项目特点

  • 更合理的Lifecycle:页面跳转、返回等Lifecycle表现与Activity一致。
  • 多种启动模式:支持Standard、SingleTop、SingleTask等多种LaunchMode。
  • 转场动画:支持Transition、SharedElement等动画方式实现页面切换。
  • 更高效的通信:可以基于Callback通信,简单直接。
  • 更友好的回退处理:支持OnBackPressed事件拦截、支持滑动返回。
  • Deep Links:通过URI跳转到指定Fragment。
  • Dialog:支持DialogFragment显示。

安装与快速开始

由于JCenter停服,Fragivity的依赖方式已改为JitPack。以下是安装步骤和快速开始指南:

安装

// 在根build.gradle中添加JitPack仓库
allprojects {
    repositories { 
        ...
        maven { url 'https://jitpack.io' }
    }
}

// 添加Fragivity依赖
implementation 'com.github.vitaviva.fragivity:core:$latest_version'

快速开始

  1. 声明NavHostFragment
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/container"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:fitsSystemWindows="true">

    <androidx.fragment.app.FragmentContainerView
        android:id="@+id/nav_host"
        android:name="androidx.navigation.fragment.NavHostFragment"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:defaultNavHost="true" />
</FrameLayout>
  1. 在Activity中加载HomeFragment
class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        proxyFragmentFactory()
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val navHostFragment = supportFragmentManager
            .findFragmentById(R.id.nav_host) as NavHostFragment

        navHostFragment.loadRoot(HomeFragment::class)
    }
}
  1. 导航到目标Fragment
// 在HomeFragment中
navigator.push(DestinationFragment::class) {
    arguments = bundleOf(KEY_ARGUMENT1 to "arg1", KEY_ARGUMENT2 to "arg2")
}

结语

Fragivity不仅简化了Fragment的管理,还提供了丰富的功能和灵活的配置选项。无论你是经验丰富的Android开发者还是刚入门的新手,Fragivity都能帮助你构建出更加优雅、高效的应用。赶快尝试一下,体验Fragment开发的全新境界吧!


参考文档

  • [Fragivity:像使用Activity一样使用Fragment](https://juejin.cn/post/6918693610359619592
热门项目推荐
相关项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
266
55
国产编程语言蓝皮书国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区
65
17
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
196
45
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
53
44
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
268
69
qwerty-learnerqwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
333
27
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
896
0
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
419
108
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
144
24
HarmonyOS-Cangjie-CasesHarmonyOS-Cangjie-Cases
参考 HarmonyOS-Cases/Cases,提供仓颉开发鸿蒙 NEXT 应用的案例集
Cangjie
58
4