WKTitleScroll 的使用

實(shí)際項(xiàng)目中我們可能經(jīng)常遇到一個(gè)界面有很多的子視圖,就如今日頭條的那樣, 因此在下在這里簡單的寫了一個(gè) demo 來解決, 并附上github 地址https://github.com/wyxlh/WKTitleScorll

  • 1,導(dǎo)入頭文件 并定義 并實(shí)現(xiàn) UIScrollViewDelegate協(xié)議 還需要一些宏定義,具體的看
//獲取設(shè)備的物理高度
#define ScreenHeight [UIScreen mainScreen].bounds.size.height
//獲取設(shè)備的物理寬度
#define ScreenWidth  [UIScreen mainScreen].bounds.size.width
#define WS(weakSelf)  __weak __typeof(&*self)weakSelf = self;
#define SKOrangeColor    [UIColor colorWithRed:250/255. green:50/255. blue:100/255. alpha:1]


#import "TitleScrollView.h"
#import "UIView+Frame.h"
@property (nonatomic,strong)TitleScrollView *titleScroll;
  • 2 實(shí)現(xiàn)
- (TitleScrollView *)titleScroll
{
if (!_titleScroll)
{
WS(weakSelf)
_titleScroll = [[TitleScrollView alloc] initWithFrame:CGRectMake(0,64, ScreenWidth, 47)  TitleArray:self.titleArr selectedIndex:0 scrollEnable:NO lineEqualWidth:YES isLarger:YES selectColor:SKOrangeColor defaultColor:[UIColor blackColor] SelectBlock:^(NSInteger index) {
[weakSelf titleClick:index];
}];
_titleScroll.backgroundColor = [UIColor whiteColor];

[self.view addSubview:_titleScroll];
}
return _titleScroll;
}
  • 3添加子視圖 并 實(shí)現(xiàn)對應(yīng)的協(xié)議
#pragma mark 底部的scrollview
-(void)setupContentView {
//不要自動調(diào)整inset
self.automaticallyAdjustsScrollViewInsets = NO;

UIScrollView *contentView = [[UIScrollView alloc] init];
contentView.frame = CGRectMake(0, self.titleScroll.height, ScreenWidth, ScreenHeight);
contentView.delegate = self;
contentView.contentSize = CGSizeMake(contentView.width * self.childViewControllers.count, 0);
contentView.pagingEnabled = YES;
[self.view insertSubview:contentView atIndex:0];

self.contentView = contentView;
self.contentView.contentOffset = CGPointMake(0*ScreenWidth, 0);
//添加第一個(gè)控制器的view
[self scrollViewDidEndScrollingAnimation:contentView];

}
#pragma mark 便簽欄按鈕點(diǎn)擊
-(void)titleClick:(NSInteger)index {
//滾動,切換子控制器
CGPoint offset = self.contentView.contentOffset;
offset.x = index * self.contentView.width;
[self.contentView setContentOffset:offset animated:YES];
}
#pragma mark -UIScrollViewDelegate
-(void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{
//添加子控制器的view
//當(dāng)前索引
NSInteger index = scrollView.contentOffset.x / scrollView.width;
//取出子控制器
UIViewController *vc = self.childViewControllers[index];
vc.view.x = scrollView.contentOffset.x;
vc.view.y = 0;//設(shè)置控制器的y值為0(默認(rèn)為20)
vc.view.height = scrollView.height;//設(shè)置控制器的view的height值為整個(gè)屏幕的高度(默認(rèn)是比屏幕少20)
[scrollView addSubview:vc.view];
}

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {
[self scrollViewDidEndScrollingAnimation:scrollView];
//當(dāng)前索引
NSInteger index = scrollView.contentOffset.x / scrollView.width;
//點(diǎn)擊butto
[self.titleScroll setSelectedIndex:index];
}


-(void)addChildViewControllers{
for (int i = 0; i < self.titleArr.count; i++) {
WKChildViewController *child = [[WKChildViewController alloc]init];
child.index = i;
[self addChildViewController:child];
}
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末晌块,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌尸执,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蕾盯,死亡現(xiàn)場離奇詭異朗若,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)镰矿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來俘种,“玉大人秤标,你說我怎么就攤上這事≈媪酰” “怎么了苍姜?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長悬包。 經(jīng)常有香客問我衙猪,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任垫释,我火速辦了婚禮丝格,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘棵譬。我一直安慰自己显蝌,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布订咸。 她就那樣靜靜地躺著曼尊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪脏嚷。 梳的紋絲不亂的頭發(fā)上骆撇,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天,我揣著相機(jī)與錄音父叙,去河邊找鬼艾船。 笑死,一個(gè)胖子當(dāng)著我的面吹牛高每,可吹牛的內(nèi)容都是我干的屿岂。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼鲸匿,長吁一口氣:“原來是場噩夢啊……” “哼爷怀!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起带欢,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤运授,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后乔煞,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吁朦,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年渡贾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了逗宜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,722評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡空骚,死狀恐怖纺讲,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情囤屹,我是刑警寧澤熬甚,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站肋坚,受9級特大地震影響乡括,放射性物質(zhì)發(fā)生泄漏肃廓。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一诲泌、第九天 我趴在偏房一處隱蔽的房頂上張望盲赊。 院中可真熱鬧,春花似錦档礁、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至惨险,卻和暖如春羹幸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背辫愉。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工栅受, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人恭朗。 一個(gè)月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓屏镊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親痰腮。 傳聞我的和親對象是個(gè)殘疾皇子而芥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容