WMPageController (顶部tab切换效果)的使用

首先贴上WMPageController的地址,也有swift版本哦,再次感谢作者的开源。:github地址:WMPageController

具体效果图:


顶部tab切换效果图.gif

使用:

1、具体引入方式,作者已经写得很清楚了,支持手动和CocoaPods集成方式。代码简单容易上手。

2、实现方式:

创建一个控制器VC继承自WMPageController, 可以通过两种方式来初始化控制器

1.通过 Class 创建
使用以下方法创建控制器:

- (instancetype)initWithViewControllerClasses:(NSArray *)classes andTheirTitles:(NSArray *)titles;

其中,Classes是要传人显示的控制器的类型,比如[UITableViewController class], titles是要显示的控制对应的标题。

这里需要注意的一点,当你的WMPageController在tabbarController的时候,初始化必须放在一起,在重写- (instancetype)initWithViewControllerClasses:(NSArray *)classes andTheirTitles:(NSArray *)titles这个方法是不可以的。如图:
这里重写是可以的.png

2.使用 datasource
使用方法和 UITableView 相似,在子类中实现以下数据源方法即可:

- (NSInteger)numbersOfChildControllersInPageController:(WMPageController *)pageController;
- (__kindof UIViewController *)pageController:(WMPageController *)pageController viewControllerAtIndex:(NSInteger)index;
- (NSString *)pageController:(WMPageController *)pageController titleAtIndex:(NSInteger)index;

相对而言,第一种方法比较简单省事,我使用的是第一种方法集成。
但是这里有两个地方需要注意一下:

1.假如你顶部切换tab有很多个childVC,你的根控制器又是在tabbarController里,在你初始化的时候,很不方便,这时需要把所有的childVC都要引入进来,导致本来tabbarController的VC就够多了,在加上这些VC,显得很乱。所以作者有一个很好的办法,设置你所需要的属性,在调用一下reloadData方法就OK了。下图的栗子:tab5个VC,第二个tab带有顶部切换效果,还带有三个childVC,本来在设置tabbarController,又引入了三个不一样的VC。根据代码简洁之道,这要写不好。

放在那里就是不爽.png

解决办法:在你需要带有顶部切换VC初始化方法中,重写设置切换VC以及其属性。

我觉得比较好的方法.png

这样就很简单的实现了顶部切换效果了。。

2.传值问题
假如你的切换childVC创建的时候,需要传值过去,就要用到keys和values属性。
注意:keys必须是是你childVC的属性名,values对应要传的值,必须一一对应,且keys数量必须与childVC的数量一致 这时候你说,要是我某一个VC需要多个传值怎么办? 解决办法:将多个传值组合成一个model或是字典进行传值

单参数要一一对应各自的属性哦.png

当某一个VC需要传多个参数的时候,(这时候选择使用DataSource代理的形式集成是非常不错的选择),我这里用的是init方法集成:

多参数产值要封装为一个哦.png

上面这种方法,当你是后期集成这个库到你的项目中,可能会有点局限性。
集成tabVC的时候,需要传多个参数值,但是在其他地方跳转过来的时候,可能只需要一个参数。这时候你在集成的时候将多个参数封装成一个字典,其他所有跳转这个VC的地方都要将传参改成字典形式,很麻烦。

在原来代码的基础上,我做了一点改进:在集成tabVC的时候,不管多少个参数,都封装成字典,keys的名称随便写,也不需要去tabVC里新添加这个属性,values还是和之前一样,是你要传参的值。。其他地方还保持原来的样式不需要任何改变。具体代码见:NEW WMPageController README 文件里有添加介绍。
改进的WMPageController.png

更新:在与作者取得沟通之后,才知道作者已经做了这方面的处理,假如传值很复杂的情况,最好使用代理方法集成。代理方法更适用于传值复杂的情况,条理也比较清晰。再次感谢作者的开源。

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

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,089评论 4 62
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • 过新都桥,转塔公草原,朝丹巴方向前行,经过 一个叫八美镇的地方,属道孚县,打听到有个4A级风景区墨石公园,原来叫八...
    心影梦画阅读 1,011评论 0 0
  • swift调用环信录音的方法 ##### 五级标题
    就想随便看看还不行吗阅读 178评论 0 0
  • 忽悠这个词很有意思。 首先,ta不算“骗人”,因为动机是诓你。 再而,ta不算“实话”,因为目的是诓你。 介于两者...
    Will阅读 394评论 1 1