小鱼在桔厂-- Conductor

入职新公司第三天,处于学习App架构阶段,这边的客户端开发架构依赖于自研的Nova Skeleton框架,而该框架的底层实现是基于Conductor框架,我们就先来看看Conductor是个啥。
Conductor按照官方说法就是一个小而全功能的框架,允许构建基于视图的 Android 应用程序。

Conductor特点

Conductor原理简单介绍

Conductor的基本原理就是Activity充当一个容器,布局文件里定义一个ViewGroup当做Container,把这个Container传给Conductor框架,然后所有的UI逻辑实际上就是Conductor在操作这个Container里面的View。


Conductor视图原理

容器化

按照我的理解就是,Conductor就是在Android开发中不依赖于系统本身提供的UI开发套件,而是直接把单一的Activity当成框架的容器来用,基于此容器,上层的UI显示,生命周期管理,传值回调等由自己本身来实现。

看到这块是不是感觉很熟悉,没错,我们来回顾一下客户端跨端技术的演变过程。


跨端技术演进

Hybird实际就是Android的Activity当成WebView容器,内部UI由WebVeiw来完成。

ReactNative实际上也是Android Activity提供一个容器,内部UI由ReactRootVeiw完成。

Flutter的话则更极端一点,Flutter是自渲染的,UI渲染由自己的Skia引擎去完成,但是Flutter引擎也需要一个Android Activity作为承载容器。

所以从思路上来说Conductor和上面这几种跨端技术有一定的相似性。

那么就引出一个思考,为啥Conductor框架放着好好的AndroidUI套件不用,要自实现一套呢?按我的理解是为了模糊View和Page的界限,为了做彻底的组件化做准备。

组件化

首先组件这个词的意思就是可组装的配件,那都可组装了,它最大的特点就出炉了,就是为了复用。要说组件我们要先说页面。

我们先用传统的Android App来说一下,一个完整的App是由多个页面组成的。页面,指的是充满整个屏幕的视图容器。常见的页面包括登录页、首页、个人页等等。Android里页面特指Activity和Fragment。那页面里面的元素,比如登录页面的登录Button,在Android里那就是一个View。

一切皆组件的框架比如React,Vue,Flutter,这些框架就是模糊了页面和View的概念,统一把他用组件来表示,在UI维度组件既可以是一个View,也可以是一个页面,在业务维度,组件就是封装出具备特定业务功能的UI元素组合。

可能初看起来比较奇怪,无非就是换了个概念而已。但是从底层框架实现角度而言,一个概念后面就有一套框架支撑。将两个概念合并,使得整个框架更加简单、清晰。 ----MaxieeWang

Conductor框架实际上就是在Android里一切皆组件的框架,在这个点上,它和React,Vue,Flutter是一致的。

Conductor核心类

Controller 控制器

Controller 是 Fragment 的替代品, 可以把它理解成 Conductor 中的 Fragment.
它是对视图 View 的封装, 并提供生命周期感知功能.
Controller 的实现比 Fragment 的实现要轻, 状态比 Fragment 更加可控, 生命周期更易于打理

Router 路由

Router 负责 Controller 的切换 (在 Conductor 中, Controller 的切换就是切页面)
Router 内部实现了一个返回栈, 用于保存 Controller 事务切换历史
根Router 需要绑定在一个 Activity 和 Activity 提供的一个 ViewGroup container 上面. 其中, ViewGroup container 就是 Controller 界面到时候显示的地方
有一点要注意的是:
Conductor 的 Router 并不直接负责页面切换, 它把切换页面的职责代理了出去
代理给一簇专门的类 ControllerChangeHandler 之所以要加这一层代理, 是因为这样就实现了对酷炫的过场动效的支持, 这一能力支持是 Conductor 比较突出的特性之一

ControllerChangeHandler

前面说 Router 把切换页面的职责代理了出去, 就是代理给了 ControllerChangeHandler
ControllerChangeHandler 的职责是将老的 Controller 的视图切出, 把新的 Controller 的视图切入, 并实现切换时的动画效果
有了 ControllerChangeHandler, 过长动画变得很容易实现. Conductor 框架内置了多种带动效的 ControllerChangeHandler
ControllerChangeHandler 是业务无关的, 在切 Controller 时 new 一个具体的 ControllerChangeHandler 就实现了过场动效

ControllerTransaction

ControllerTransaction 是用于 Router 内部的一个数据接口.
每次我们切页面, 就会创建一个 ControllerTransaction 保存这次切面面相关的上下文 (from controller, to controller, container ViewGroup, applied ControllerChagneHandler)
Router 内部维护了一个 ControllerTransaction 的 list, 刚创建的这个 ControllerTransaction 会入队
Router 会根据这个队列来执行切换操作
也就是说 Router 维护了一个队列来切面, 这样的目的是为了保证切页面的状态是可控的


image.png

image.png

总结

每个框架的产生都有它的理由,在2016年那个时间点Conductor框架的诞生我想也是为了解决当时Android开发的一些问题(Fragment难用,组件化困难等)。之后的Uber ribs架构也借鉴了Conductor的一些思想,我们团队的客户端整体架构,底层也是引入的Conductor。目前来说Android的技术生态也在Google的带领下不断的规范化,Jetpack Compose这种全新的Android UI开发方式甚至也能看到Conductor的影子,从这些方面来看,Conductor无疑是成功的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,717评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,501评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,311评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,417评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,500评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,538评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,557评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,310评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,759评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,065评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,233评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,909评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,548评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,172评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,420评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,103评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,098评论 2 352

推荐阅读更多精彩内容