使用Masonry對(duì)UIScrollView自動(dòng)布局

之前使用Masonry對(duì)UIScrollView進(jìn)行過(guò)約束非驮,當(dāng)時(shí)是遇到了問(wèn)題的,怎么約束都不對(duì)箍土,因?yàn)橼s進(jìn)度直接改用frame了也沒(méi)有對(duì)問(wèn)題深究肉拓。就這樣過(guò)了很久.........鸭丛,直到前一段換工作的時(shí)候面試官問(wèn)到竞穷,使用Masonry對(duì)UIScrollView自動(dòng)布局應(yīng)該注意些什么?額....鳞溉,猶豫了一段時(shí)間我只能搪塞說(shuō)我一般都是用frame進(jìn)行設(shè)置的瘾带,暫時(shí)沒(méi)有遇到什么問(wèn)題。雖然這么回答也沒(méi)什么熟菲,但是感覺(jué)終歸不是很好看政。出來(lái)混遲早是要還的朴恳!剛好最近公司不忙,想起了這個(gè)問(wèn)題允蚣,那么就研究記錄一下吧于颖!

對(duì)UIScrollView的約束有很多方式,我只講其中一種易懂嚷兔、直觀的方式
UIScrollView約束的關(guān)鍵是設(shè)置它的contentSize的大小森渐,否則無(wú)法進(jìn)行滾動(dòng)顯示。

給UIScrollView添加一個(gè)過(guò)渡視圖containerView谴垫,這個(gè)containerView作為所有子控件的父視圖章母,然后再設(shè)置containerView相對(duì)于UIScrollView的約束constraint和子控件相對(duì)于containerView的約束constraint。
最后再將最后一個(gè)子視圖的右邊距翩剪,或底邊距設(shè)置成containerView的右邊距,或底邊距彩郊,以此來(lái)設(shè)置scrollView的contentSize在水平方向前弯,或垂直方向的大小。

UIScrollView豎向滑動(dòng)時(shí)秫逝,就把containerView的width固定
UIScrollView橫向滑動(dòng)時(shí)恕出,就把containerView的height固定

如果看完上面的描述還沒(méi)有明白,那直接看下面的代碼违帆,UIScrollView的約束其實(shí)都是一樣的浙巫,記住即可

??????下面直接上代碼??????

水平方向

UIScrollView *horizontalScrollView = [[UIScrollView alloc] init];
horizontalScrollView.backgroundColor = [UIColor orangeColor];
horizontalScrollView.pagingEnabled =YES;
// 添加scrollView添加到父視圖,并設(shè)置其約束
[self.view addSubview:horizontalScrollView];
[horizontalScrollView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.and.left.mas_equalTo(10);
        make.right.mas_equalTo(-10);
        make.height.mas_equalTo(100);
}];
// 創(chuàng)建過(guò)渡視圖并設(shè)置contentSize和其約束
UIView *horizontalContainerView = [[UIView alloc] init];
[horizontalScrollView addSubview:horizontalContainerView];
[horizontalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.edges.equalTo(horizontalScrollView);
        make.height.equalTo(horizontalScrollView);#//水平滾動(dòng)高度固定刷后,這個(gè)很重要
}];
//過(guò)渡視圖上添加子視圖
UIView *previousView =nil;
for (int i =0; i <10; i++) {

        UILabel *label = [[UILabelalloc]init];
        label.textAlignment =NSTextAlignmentCenter;
        label.backgroundColor = [UIColorcolorWithHue:(arc4random() %256 / 256.0)
                                          saturation:(arc4random() %128 /256.0) +0.5
                                          brightness:(arc4random() %128 /256.0) +0.5
                                               alpha:1];
        label.text = [NSStringstringWithFormat:@"第 %d個(gè)視圖", i];
      
       //添加到過(guò)渡視圖的畴,并設(shè)置子視圖的約束
        [horizontalContainerView addSubview:label];
        [label mas_makeConstraints:^(MASConstraintMaker *make) {
            make.top.and.bottom.equalTo(horizontalContainerView);
            make.width.equalTo(horizontalScrollView);
            
            if (previousView) {
                make.left.mas_equalTo(previousView.mas_right);
            }
            else {
                make.left.mas_equalTo(0);
            }
        }];
 
        previousView = label;
}
#// 設(shè)置過(guò)渡視圖的右距(此設(shè)置將影響到scrollView的contentSize)這個(gè)也是關(guān)鍵的一步
[horizontalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.right.mas_equalTo(previousView.mas_right);
}];

垂直平方向

UIScrollView *verticalScrollView = [[UIScrollView alloc] init];
verticalScrollView.backgroundColor = [UIColor greenColor];
verticalScrollView.pagingEnabled =YES;
// 添加scrollView添加到父視圖,并設(shè)置其約束
[self.view addSubview:verticalScrollView];
[verticalScrollView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.mas_equalTo(10);
        make.bottom.and.right.mas_equalTo(-10.0);
        make.height.mas_equalTo(100);
}];
// 設(shè)置scrollView的子視圖尝胆,即過(guò)渡視圖contentSize丧裁,并設(shè)置其約束
UIView *verticalContainerView = [[UIView alloc] init];
[verticalScrollView addSubview:verticalContainerView];
[verticalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.left.bottom.and.right.equalTo(verticalScrollView);
        make.width.equalTo(verticalScrollView);#//垂直滾動(dòng)寬度固定,這個(gè)很重要
}];
//過(guò)渡視圖添加子視圖
UIView *lastView =nil;
for (NSInteger index =0; index <10; index++) {

        UILabel *label = [[UILabelalloc]init];
        label.textAlignment =NSTextAlignmentCenter;
        label.backgroundColor = [UIColorcolorWithHue:(arc4random() %256 / 256.0)
                                          saturation:(arc4random() %128 /256.0) +0.5
                                          brightness:(arc4random() %128 /256.0) +0.5
                                               alpha:1];
        label.text = [NSStringstringWithFormat:@"第 %ld個(gè)視圖", index];
        
        
       //添加到過(guò)渡視圖含衔,并設(shè)置子視圖的約束
        [verticalContainerView addSubview:label];
        [label mas_makeConstraints:^(MASConstraintMaker *make) {
            make.left.and.right.equalTo(verticalContainerView);
            make.height.mas_equalTo(verticalScrollView.mas_height);
            
            if (lastView)  {
                make.top.mas_equalTo(lastView.mas_bottom);
            }
            else  {
                make.top.mas_equalTo(0);
            }
        }];
        
        lastView = label;
}
    
#// 設(shè)置過(guò)渡視圖的底邊距(此設(shè)置將影響到scrollView的contentSize)這個(gè)也是關(guān)鍵的一步
[verticalContainerView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.bottom.equalTo(lastView.mas_bottom);
}];

xib對(duì)UIScrollerView的布局可以參考下面的文章
http://www.reibang.com/p/1d3bb3cf7ee5
https://blog.csdn.net/dreams_deng/article/details/80523485

參考資料:https://blog.csdn.net/potato512/article/details/51226747
參考資料:http://www.reibang.com/p/9948d917696b

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末煎娇,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子贪染,更是在濱河造成了極大的恐慌缓呛,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件杭隙,死亡現(xiàn)場(chǎng)離奇詭異哟绊,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)寺渗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門匿情,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)兰迫,“玉大人,你說(shuō)我怎么就攤上這事炬称≈” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵玲躯,是天一觀的道長(zhǎng)据德。 經(jīng)常有香客問(wèn)我,道長(zhǎng)跷车,這世上最難降的妖魔是什么棘利? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮朽缴,結(jié)果婚禮上善玫,老公的妹妹穿的比我還像新娘。我一直安慰自己密强,他們只是感情好茅郎,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著或渤,像睡著了一般系冗。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上薪鹦,一...
    開(kāi)封第一講書(shū)人閱讀 49,166評(píng)論 1 284
  • 那天掌敬,我揣著相機(jī)與錄音,去河邊找鬼池磁。 笑死奔害,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的框仔。 我是一名探鬼主播舀武,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼离斩!你這毒婦竟也來(lái)了银舱?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤跛梗,失蹤者是張志新(化名)和其女友劉穎寻馏,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體核偿,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡诚欠,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片轰绵。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡粉寞,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出左腔,到底是詐尸還是另有隱情唧垦,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布液样,位于F島的核電站振亮,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏鞭莽。R本人自食惡果不足惜坊秸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望澎怒。 院中可真熱鬧褒搔,春花似錦、人聲如沸喷面。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)乖酬。三九已至,卻和暖如春融求,著一層夾襖步出監(jiān)牢的瞬間咬像,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工生宛, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留县昂,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓陷舅,卻偏偏與公主長(zhǎng)得像倒彰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子莱睁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

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