iOS 顶部视图家滚动视图联动

TOPView.h

#importtypedef void(^MainTopBlock)(NSInteger tag);

@interface RZKMainTopView : UIView

-(instancetype)initWithFrame:(CGRect)frame titleNames:(NSArray *)titles tapView:(MainTopBlock)block;

//block的名字

@property(nonatomic,copy)MainTopBlock block;

-(void)scrolling:(NSInteger)tag;

@end

TOPView.m

#import "RZKMainTopView.h"

#pragma mark -- LineView 的扩展

@interface RZKMainTopView()

@property(nonatomic,strong)UIView * lineView;

@property(nonatomic,strong)NSMutableArray * btns;

@end

@implementation RZKMainTopView

-(NSMutableArray *)btns{

if (!_btns) {

_btns = [NSMutableArray array];

}

return _btns;

}

-(instancetype)initWithFrame:(CGRect)frame titleNames:(NSArray *)titles tapView:(MainTopBlock)block{

self = [super initWithFrame:frame];

if (self) {

self.block = block;

//每个按钮的宽度

CGFloat ButtonWidth =  self.width/titles.count;

//每个按钮的高度

CGFloat ButtonHeight = self.height;

CGFloat btnx;

for (NSInteger i = 0; i < titles.coiunt;i++{

UIButton * titleBtn = [UIButton buttonWithType:UIButtonTypeCustom];

[self.btns addObject:titleBtn];

NSString * vcName = titles[i];

//设置按钮文字

[titleBtn setTitle:vcName forState:UIControlStateNormal];

//设置按钮的颜色

[titleBtn setTintColor:[UIColor whiteColor]];

//设置字体大小

titleBtn.titleLabel.font = [UIFont systemFontOfSize:18];

btnx = i * ButtonWidth;

//设置按钮的tag

titleBtn.tag = i;

//设置frame

titleBtn.frame = CGRectMake(btnx, 0, ButtonWidth, ButtonHeight);

//设置监听 点击事件

[titleBtn addTarget:self action:@selector(titleClick:) forControlEvents:UIControlEventTouchUpInside];

[self addSubview:titleBtn];

if (i == 1) {

CGFloat height = 2;

CGFloat y = 37;

[titleBtn.titleLabel sizeToFit];

self.lineView = [[UIView alloc]init];

self.lineView.backgroundColor = [UIColor whiteColor];

self.lineView.height = height;

self.lineView.width = titleBtn.titleLabel.width;

self.lineView.top = y; // top 就是y值

self.lineView.centerX = titleBtn.centerX;

self.lineView.backgroundColor = [UIColor whiteColor];

[self addSubview:self.lineView];

}

}

}

return self;

}

//MainVc 滚动时调用

-(void)scrolling:(NSInteger)tag{

//根据tag 拿到btn

UIButton * button = self.btns[tag];

[UIView animateWithDuration:0.25 animations:^{

self.lineView.centerX = button.centerX;

}];

}

//点击事件

-(void)titleClick:(UIButton *)button{

self.block(button.tag);

[self scrolling:button.tag];

}


MainVC.h

#import "RZKMainViewController.h"

#import "RZKMainTopView.h"

@interface RZKMainViewController ()@property (weak, nonatomic) IBOutlet UIScrollView *contentScrollView;

@property(nonatomic,strong)NSArray * datalist;

@property(nonatomic,strong)RZKMainTopView * topview;

@end

@implementation RZKMainViewController

- (void)viewDidLoad {

[super viewDidLoad];

[self iniUI];

}

-(void)iniUI{

//添加子视图控制器

[self setupChildViewControllers];

//加载导航栏按钮

[self setupNav];

//    self.view.backgroundColor = [UIColor whiteColor];

}

//导航栏左右按钮

-(void)setupNav{

//topview

self.navigationItem.titleView = self.topview;

self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc]initWithImage:[UIImage imageNamed:@"global_search"] style:UIBarButtonItemStyleDone target:nil action:nil];

self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithImage:[UIImage imageNamed:@"title_button_more"] style:UIBarButtonItemStyleDone target:nil action:nil];

}

//子视图控制器

-(void)setupChildViewControllers{

NSArray * vcNames =@[@"RZKFocuseViewController",@"RZKHotViewController",@"RZKNearViewController"];

for (NSInteger i = 0; i < vcNames.count; i++) {

NSString * vcName = vcNames[i];

UIViewController * vc = [[NSClassFromString(vcName) alloc]init];

vc.title = self.datalist[i];

[self addChildViewController:vc];

}

//将子控制器的View 添加到mainVc 的ScrollerView上

//设置scrollView的ContentSize偏移量

self.contentScrollView.contentSize = CGSizeMake(SCREEN_WIDTH * self.datalist.count,0);

//进入MainView 后 直接跳转到第二个界面

self.contentScrollView.contentOffset= CGPointMake(SCREEN_WIDTH, 0);

self.contentScrollView.pagingEnabled = YES;

self.contentScrollView.delegate = self;

//进入主控制器 加载第一个界面

[self scrollViewDidEndDecelerating:self.contentScrollView];

}

#pragma mark -- 滚动视图动画结束调动代理方法

-(void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{

//得到每一个自控制器View 的宽度

CGFloat width = SCREEN_WIDTH;

CGFloat height = SCREEN_HEIGHT;

CGFloat offset = scrollView.contentOffset.x;

//获取当前控制器的索引

NSInteger index = offset/width;

//索引值联动 topview

[self.topview scrolling:index];

//根据索引值返回vc的引用

UIViewController * vc = self.childViewControllers[index];

//判断当前的Vc是否执行过ViewDidLoad

if ([vc isViewLoaded])return;

//设置子控制器的大小

vc.view.frame = CGRectMake(offset,0,width,height);

//将当前的VC的View 添加到ScrollView 上

[scrollView addSubview:vc.view];

}

#pragma mark -- 滚动视图减速代理方法

//减速结束 调用 加载子视图 控制器view 的方法

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{

//直接调用滚动视图动画结束调动代理方法

[self scrollViewDidEndScrollingAnimation:scrollView];

/**

* 逻辑是 当前的view 加载过了就不添加了

* 没有添加过 就要进行添加

**/

}

-(RZKMainTopView *)topview{

if (!_topview) {

_topview = [[RZKMainTopView alloc]initWithFrame:CGRectMake(0, 0, 200, 44) titleNames:self.datalist tapView:^(NSInteger tag) {

CGPoint point = CGPointMake(tag * SCREEN_WIDTH,self.contentScrollView.contentOffset.y);

[self.contentScrollView setContentOffset:point animated:YES];

}];

}

return _topview;

}

-(NSArray *)datalist{

if (!_datalist ) {

_datalist = @[@"关注",@"热门",@"附近"];

}

return _datalist;

}

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

推荐阅读更多精彩内容