马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
x
一、初始化
- -(JXCategoryTitleView *)categoryView{
- if (!_categoryView) {
- _categoryView = [[JXCategoryTitleView alloc] init];
- _categoryView.delegate = self;
- _categoryView.titleDataSource = self;
- _categoryView.averageCellSpacingEnabled = NO; //是否平均分配项目之间的间距
- _categoryView.contentEdgeInsetLeft = 24; //靠左显示的边距
- _categoryView.titleLabelVerticalOffset = -5; //标题向上偏移
- _categoryView.cellSpacing = 32; //固定分类项之前的间距
- _categoryView.titles = @[];
- _categoryView.defaultSelectedIndex = 0; //默认选中
- _categoryView.titleColor = RGBA(119, 119, 119, 1); //默认文字颜色
- _categoryView.titleSelectedColor = RGBA(51, 51, 51, 1); //文字选择颜色
- _categoryView.backgroundColor = [UIColor clearColor];
- _categoryView.titleFont = AppFont(16);
- _categoryView.titleSelectedFont = AppBoldFont(16);
-
- //底部指示器
- JXCategoryIndicatorLineView *lineView = [[JXCategoryIndicatorLineView alloc] init];
- lineView.verticalMargin = 10; //默认底部,越大越向上偏移
- lineView.indicatorHeight = 3; //指示器高度
- lineView.indicatorCornerRadius = 0; //是否倒圆角
- lineView.indicatorColor = RGBA(72, 142, 255, 1); //指示器颜色
- lineView.indicatorWidth = 24; //指示器宽度
- lineView.scrollStyle = JXCategoryIndicatorScrollStyleSameAsUserScroll; //指示器滚动样式
- _categoryView.indicators = @[lineView];
-
- }
- return _categoryView;
- }
复制代码 二、关联listContainerView
- -(JXCategoryListContainerView *)listContainerView{
- if (!_listContainerView) {
- _listContainerView = [[JXCategoryListContainerView alloc] initWithType:JXCategoryListContainerType_ScrollView delegate:self];
- _listContainerView.scrollView.scrollEnabled = YES;
- }
- return _listContainerView;
- }
复制代码- self.categoryView.listContainer = self.listContainerView;
复制代码- //子控制器数组
- - (NSArray<__kindof UIViewController *> *)controllers{
- return @[
- self.VC1,
- self.VC2,
- ];
- }
- #pragma mark - JXCategoryListContainerViewDelegate -
- - (id<JXCategoryListContentViewDelegate>)listContainerView:(JXCategoryListContainerView *)listContainerView initListForIndex:(NSInteger)index{
- __kindof UIViewController *vc = self.controllers[index];
- return vc;
- }
- - (NSInteger)numberOfListsInlistContainerView:(JXCategoryListContainerView *)listContainerView {
- return self.controllers.count;
- }
- //定义scrollerview处理手势冲突
- - (Class)scrollViewClassInlistContainerView:(JXCategoryListContainerView *)listContainerView{
- return [ServiceScrollView class];
- }
复制代码 三、titles 重载
可以在初始化时指定titles属性赋值, 如果需要动态显示titles, 则可以在处置惩罚后,通过 reloadData 举行重载
- _categoryView.titles = @[@"项目1",@"项目2"];
复制代码- NSArray *titles;
- if (xxx) {
- titles = @[@"项目1",@"项目2"];
- }else {
- titles = @[@"礼物1",@"礼物2"];
- }
- _categoryView.titles = titles;
- [_categoryView reloadData];
复制代码 四、设置指定项被选中
- [self.categoryView selectItemAtIndex:0];
复制代码 五、代理方法
- #pragma mark - JXCategoryViewDelegate -
- //点击选中的情况才会调用该方法
- - (void)categoryView:(JXCategoryBaseView *)categoryView didClickSelectedItemAtIndex:(NSInteger)index {
-
- }
复制代码 六、listContentView 需实现 listView 方法
- @protocol JXCategoryListContentViewDelegate <NSObject>
- /**
- 如果列表是VC,就返回VC.view
- 如果列表是View,就返回View自己
- @return 返回列表视图
- */
- - (UIView *)listView;
- @optional
- /**
- 可选实现,列表将要显示的时候调用
- */
- - (void)listWillAppear;
- /**
- 可选实现,列表显示的时候调用
- */
- - (void)listDidAppear;
- /**
- 可选实现,列表将要消失的时候调用
- */
- - (void)listWillDisappear;
- .....
复制代码 根据协议声明来看, listView方法需要协议的实现者必须 实现才可以。 由于它是 @required (不指定,则为默认)声明的- #pragma mark - JXCategoryListContainerViewDelegate -
- - (id<JXCategoryListContentViewDelegate>)listContainerView:(JXCategoryListContainerView *)listContainerView initListForIndex:(NSInteger)index{
- __kindof UIViewController *vc = self.controllers[index];
- return vc;
- }
复制代码 - (id)listContainerView JXCategoryListContainerView *)listContainerView initListForIndex NSInteger)index 这个回调需要返回实现了 JXCategoryListContentViewDelegate 的对象(一样平常是viewController)- @implementation MyContentViewController
- //实现 JXCategoryListContentViewDelegate 的代理方法
- - (UIView *)listView{
- return self.view;
- }
- @end
复制代码 免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |