我的Android开源之旅

Google官方Fragment页面框架Navigation和X

2020-10-05  本文已影响0人  xuexiangjys

简介

AndroidJetpack组件。Google官方对它的描述:

今天,我们宣布推出Navigation组件,作为构建您的应用内界面的框架,重点是让单 Activity 应用成为首选架构。利用Navigation组件对 Fragment 的原生支持,您可以获得架构组件的所有好处(例如生命周期和 ViewModel),同时让此组件为您处理 FragmentTransaction 的复杂性。此外,Navigation组件还可以让您声明我们为您处理的转场。它可以自动构建正确的“向上”和“返回”行为,包含对深层链接的完整支持,并提供了帮助程序,用于将导航关联到合适的 UI 小部件,例如抽屉式导航栏和底部导航。

一个非常方便的fragment页面框架,X-Library系列重要组件。设计的初衷是希望能做一个通用的Activity作为壳,Fragment作为页面填充展示,并且能够实现自由的切换和数据交互, 点击了解XPage更多内容.

视频介绍


特性对比

对比特性 Navigation XPage
注册方式 XML注册 json或者@Page注册
参数传递 动态/静态都支持 动态/静态都支持
页面切换动画 动态支持 动态/静态都支持
容器占位数 支持多个占位 仅支持一个占位
便捷性 每次都需要编写navigation导航 无需重复性代码,一个@Page注解搞定
功能性 强大,支持多种使用方式 强大,提供多种常用组件和API
拓展性 优秀,方便拓展 因为追求便捷性,因此牺牲了部分拓展性
目标 去除Activity 去除Activity
生态 AndroidJetpack全家桶,Google官方出品 生态相对薄弱,但是也有X-Library系列支持

通过上面表格的对比可以看出,这两个框架各有特色。


使用对比

以下我仅从集成和页面跳转两个方面进行简单的使用比较,更多使用内容可以参阅本项目源码。项目地址: https://github.com/xuexiangjys/Navigation_XPage

集成

由于是Google出品,所有非常方便,只需要你创建项目(New Project)的时候,选择"Basic Activity"的选项,工程会自动帮你增加Navigation的依赖。如下图:

在这里插入图片描述

如果你不想创建新的项目,也很简单,只需要在项目中增加如下依赖:

dependencies {
    ...
    implementation 'androidx.navigation:navigation-fragment:2.3.0'
    implementation 'androidx.navigation:navigation-ui:2.3.0'
}

XPage的集成相对比较麻烦,不过相对也提供了一个模版工程,直接集成了XPage,拿到手就可以用了。

如果你想集成到自己的项目中,可以参考XPage集成指南

页面跳转

页面跳转的话,XPage就相对简单多了。

1.在res/navigation/中创建navigation导航图。

在这里插入图片描述

2.在Activity的布局中增加Fragment占位容器。下面是使用NavHostFragment进行占位。

<fragment
    android:id="@+id/nav_host_fragment"
    android:name="androidx.navigation.fragment.NavHostFragment"
    android:layout_width="0dp"
    android:layout_height="0dp"
    app:defaultNavHost="true"
    app:navGraph="@navigation/nav_graph" />

3.使用NavController进行页面导航。

NavHostFragment.findNavController(FirstFragment.this)
        .navigate(R.id.action_FirstFragment_to_SecondFragment);

1.随便创建一个类并继承XPageFragment,然后在类上使用@Page进行注解

@Page
public class TestFragment extends XPageFragment {

...

}

2.然后在任意继承了XPageActivity或者XPageFragment类中使用openPage即可。

// 使用类名打开
openPage(TestFragment.class);
// 使用页面标识符打开
openPage("TestFragment");

更多使用对比

更多使用内容可以参阅本项目源码, 项目地址: https://github.com/xuexiangjys/Navigation_XPage .

上一篇下一篇

猜你喜欢

热点阅读