iOS多项选项卡TYTabPagerBar和分页控制器TYPagerController使用小结
最近做项目的时候,用到了顶部选项卡和底部分页控制器相关的功能。之前做的话都是自己手动封装,通过两个UIScrollView联动来实现。公司同事给推荐了一个封装好的库,
TYPagerController,内部也是通过ScrollView的联动来实现的,不过功能确实很强大。有幸研究使用了一下,小结分享备用。
第一步,当然是导入相应的库文件,引用相关的头文件
#import <TYPagerController/TYPagerController.h>
#import <TYPagerController/TYTabPagerBar.h>
,现在用的多的是pod导入;
第二步,就是具体的用法了。引入相关的协议,定义实例变量。
@property (nonatomic, strong) TYTabPagerBar *tabPagerBar;
@property (nonatomic, strong) TYPagerController *pagerController;
-(TYTabPagerBar *)tabPagerBar{
//顶部bar
if (!_tabPagerBar) {
_tabPagerBar = [[TYTabPagerBar alloc]init];
_tabPagerBar.layout.barStyle = TYPagerBarStyleProgressElasticView;
_tabPagerBar.layout.cellSpacing = 20;
_tabPagerBar.layout.cellEdging = 0;
_tabPagerBar.layout.normalTextFont = K_CC_FONT(16);
_tabPagerBar.layout.selectedTextFont = K_CC_FONT_SEMIBOLD(18);
_tabPagerBar.layout.normalTextColor = K_CC_COLOR_STRING(@"#666666");
_tabPagerBar.layout.selectedTextColor = K_CC_COLOR_STRING(@"#6294FF");//K_CC_COLOR_BLUE;
_tabPagerBar.layout.adjustContentCellsCenter = YES;
_tabPagerBar.layout.progressColor = K_CC_COLOR_STRING(@"#6294FF");
_tabPagerBar.layout.textColorProgressEnable=YES;
_tabPagerBar.dataSource = self;
_tabPagerBar.delegate = self;
[_tabPagerBar registerClass:[TYTabPagerBarCell class] forCellWithReuseIdentifier:[TYTabPagerBarCell cellIdentifier]];
}
return _tabPagerBar;
}
-(TYPagerController *)pagerController{
//内容controller
if (!_pagerController) {
_pagerController = [[TYPagerController alloc]init];
_pagerController.layout.prefetchItemCount = 0;//预加载个数
//pagerController.layout.autoMemoryCache = NO;
// 只有当scroll滚动动画停止时才加载pagerview,用于优化滚动时性能
_pagerController.layout.addVisibleItemOnlyWhenScrollAnimatedEnd = YES;
_pagerController.automaticallySystemManagerViewAppearanceMethods = NO;
_pagerController.dataSource = self;
_pagerController.delegate = self;
_pagerController.view.backgroundColor = K_CC_GRAY_BG_COLOR;
_pagerController.scrollView.backgroundColor = K_CC_GRAY_BG_COLOR;
}
return _pagerController;
}
- (UIViewController *)pagerController:(TYPagerController *)pagerController controllerForIndex:(NSInteger)index prefetching:(BOOL)prefetching {
CCHighSeasPoolListViewController *VC = [[CCHighSeasPoolListViewController alloc]init];
//此处需要区分普通用户和管理员
if ([self.marketSeaRole isEqualToString:@"normal"]) {
if (index== 0) {
VC.condition=@"未分配";
}else if (index== 1) {
VC.condition=@"已分配";
}else if (index== 2) {
//客户公海池
if ([self.itemtitle isEqualToString:@"acf202011accmksea"]) {
VC.condition=@"已成交";
}else{
VC.condition=@"已成交";
}
}else {
VC.condition=@"自建";
}
}else{//管理员
if (index== 0) {
VC.condition=@"未分配";
}else if (index== 1) {
VC.condition=@"已分配";
}else if (index== 2) {
VC.condition=@"已废弃";
}else if (index== 3) {
//客户公海池
if ([self.itemtitle isEqualToString:@"acf202011accmksea"]) {
VC.condition=@"已成交";
}else{
VC.condition=@"已成交";
}
}else {
VC.condition=@"自建";
}
}
VC.itemtitle=self.itemtitle;
CCMoreListModel *moreModel=[self.dataSeasList objectAtIndex:self.currentSeasItem];
VC.marketSeaId=moreModel.ID;
VC.dataButtonList=self.dataButtonList;
VC.dataSeasLeftList=self.dataSeasLeftList;
VC.querysize=self.querysize;
VC.marketSeaRole=self.marketSeaRole;
VC.dataSeasPoolList=self.dataSeasList;
return VC;
}
最核心的地方基本就是这些,它强大的地方有三点,一是我可以上下联动,并返回当前选中项索引,可以通过通知刷新相关联的页面;二是我可以动态的设置顶部选项卡的个数,对应文本的大小和颜色;三是,底部可以加载view或者controller。使用过程中遇到的问题主要是,当前版本库里面选中项对应的加粗属性,作者用错变量了,需要去库文件手动改一下;
iOS多项选项卡TYTabPagerBar和分页控制器TYPagerController使用小结的更多相关文章
- iOS开发网络篇—网络请求(HTTP协议)小结
iOS开发网络篇—网络请求(HTTP协议)小结 iOS开发网络篇—网络请求(HTTP协议)小结 1. 聊一下HTTP协议(协议的完整的通信过程) 2.通信过程 1> 请求 * 客户端 --> ...
- Swift - 判断设备类型开发兼容的iOS应用(iPad使用分隔视图控制器)
1,分割视图控制器(UISplitViewController) 在iPhone应用中,使用导航控制器由上一层界面进入下一层界面. 但iPad屏幕较大,通常使用SplitViewController来 ...
- IOS开发之功能模块--自定义导航控制器类常用自定义的代码
前言:本文篇幅不多,但是涉及到的内容却是开发中常用的. 涉及的内容: 1.统一设置导航控制器子控制器的返回按钮. 2.因为修改了系统的返回按钮,所以还需要设置手势事件. 3.隐藏底部的工具条. 这里直 ...
- iOS - 切换rootViewController时,销毁之前的控制器
一.iOS在切换根控制器时,如何销毁之前的控制器?(切换rootViewController时注意的内存泄漏) 首先.在iOS的ARC机制下,任何对象,当没有其他对象对他进行强引用时,都会被自动释放. ...
- IOS UI-控制器的创建和控制器的View的创建
一.控制器的创建和控制器的View的创建 说明:控制器有三种创建方式,下面一一进行说明. 一.第一种创建方式(使用代码直接创建) 1.创建一个空的IOS项目. 2.为项目添加一个控制器类. 3.直接在 ...
- iOS:使用block进行类与类,控制器与控制器之间的传值
介绍:在iOS中类与类,控制器与控制器之间传值的方式有多种,分别是:单例传值.代理传值.通知传值.block传值或者一些偏好设置也可以用来传值.... 每一种传值方式都有各自的优点和缺点,针对不同情况 ...
- iOS 学习笔记三【segmentedControl分段控制器详细使用方法】
在iOS开发过程中,分段控制器的使用频率还是蛮高的,下面是我写的一个简单的demo,大家可以把代码直接复制过去,就可以使用,ios9最新支持. // // ViewController.m // 03 ...
- IOS开发学习笔记034-UIScrollView-xib实现分页
通过xib实现分页功能的封装 1.首先实现xib UIView 的尺寸为300*130,因为准备的图片为600*260. scrollView属性设置如下: 2.新建一个和xib同名的类 2.1 类方 ...
- iOS 切换首页-更改tabbar的容器控制器
最近想到的一个小需求: 首页切换:点击一个切换按钮,能实现首页的风格.排版等变换,原理是用一个新的VC替换掉. 效果如下: ====>====> 实现方式很简单: 以我的Demo为例, ...
- IOS第12天(2,UINavigationController导航控制器)
****HMAppDelegate.m @implementation HMAppDelegate - (BOOL)application:(UIApplication *)application d ...
随机推荐
- 【微信小程序】 列表查询功能
对应本地生活案例: https://www.bilibili.com/video/BV1834y1676P?p=52 HTML代码部分: 就是普通的wx-for指令遍历 <!--pages/cl ...
- 【Java,IDEA】使用IDEA自动生成序列化ID
一.设置序列化的原因: 详细见SE的IO流问题: https://www.cnblogs.com/mindzone/p/12752453.html 简单点理解就是对象的身份证号, 对于一些对象被序列之 ...
- 【OracleDB】 07 分组查询 & 分组函数
分组函数 分组函数作用于一组数据,并对一组数据返回一个值. Oracle中分组函数的种类: - 求平均值 AVG - 计数记录数 COUNT - 求最大值 MAX - 求最小值 MIN - 求和 SU ...
- 【Docker】08 部署挂载本地目录的MySQL
拉取MySQL镜像: docker pull mysql:8.0.21 执行挂载运行MySQL容器的命令: docker run -dit \ --name mysql-test \ -p 3306: ...
- 报错 qt.qpa.plugin: Could not load the Qt platform plugin “xcb“ in ““ even though it was found
参考: https://blog.csdn.net/qq_39938666/article/details/120452028 ==================================== ...
- ffmpeg和ffplay常用指令
FFmpeg 常见用法 1. 基本命令结构 ffmpeg [global_options] -i input_file [input_options] output_file [output_opti ...
- 牛客周赛 Round 8
牛客周赛 Round 8 A-小美的排列询问_牛客周赛 Round 8 (nowcoder.com) 枚举即可 #include<bits/stdc++.h> using i64 = lo ...
- 官网使用conda&pip安装PyTorch命令总结(包含各版本)
原网页https://pytorch.org/get-started/previous-versions/ 因为有时访问该网站比较慢,所以本博客记录该网页内容 Installing previous ...
- win7安装snmp服务
一.安装SNMP Win7操作系统默认情况下是不安装SNMP服务的,今天讲解一下在Win7操作系统下安装SNMP,具体安装步骤如下: 打开控制面板--卸载程序 WIN7操作系统下安装SNMP的步骤如下 ...
- React项目接入代码编辑器aceEditor
不建议去查看aceEditor官方,最好去github查看 安装命令: npm install react-ace 引入包: import AceEditor from 'react-ace'; im ...