iOS-基礎視圖約束--Masonry的簡單使用總結

更深月色半人家,北斗闌干南斗斜<小火猴>

簡介:

<strong>Masonry<strong> 是一個輕量級的布局框架 ( 是一個用代碼寫iOS或OS界面的第三方庫犁嗅,可以代替Auto layout期犬。是目前最流行的AutoLayout框架.) 擁有自己的描述語法 采用更優(yōu)雅的鏈式語法封裝自動布局 簡潔明了 并具有高可讀性 而且同時支持 iOS 和 Mac OS X瓤球。能實現(xiàn) AutoLayout 的效果,也就是給我們想要的 View 視圖進行約束,以滿足不同尺寸設備和其他場景的屏幕適配.

下面是操作的一些屬性,我們可以在AutoLayout 里面對應找到可以結合思考

@property (nonatomic, strong, readonly) MASConstraint *left; // 左側
@property (nonatomic, strong, readonly) MASConstraint *top; // 上側
@property (nonatomic, strong, readonly) MASConstraint *right;// 右側
@property (nonatomic, strong, readonly) MASConstraint *bottom;// 下冊
@property (nonatomic, strong, readonly) MASConstraint *leading;// 首部
@property (nonatomic, strong, readonly) MASConstraint *trailing;// 尾部
@property (nonatomic, strong, readonly) MASConstraint *width;// 寬
@property (nonatomic, strong, readonly) MASConstraint *height;// 高
@property (nonatomic, strong, readonly) MASConstraint *centerX;// 橫向的中點
@property (nonatomic, strong, readonly) MASConstraint *centerY;// 縱向中點
@property (nonatomic, strong, readonly) MASConstraint *baseline;//文本基線```

---------------------
####簡單的語法總結:
>with和and
基本沒用過,方法的結果是返回對象本身,就是對其沒有任何的操作.有人說就是為了代碼的可讀性,我道行太淺感覺有與沒有差別不大.

-----
>mas_equalTo 和 equalTo 區(qū)別:
masequalTo 比equalTo多了類型轉換操作带射,一般來說他炊,大多數時候兩個方法都是 通用的,但是對于數值元素使用mas_equalTo姆吭。對于對象或是多個屬性的處理榛做,使用equalTo。
>>mas_equalTo:這個方法會對參數進行封裝( 可以跟數據和對象 )
 equalTo:這個方法不會對參數進行封裝( 后面括號里面必須是對象 )
現(xiàn)在的 mas_equalTo: > equalTo:

------
>mas_makeConstraints 負責新增約束 Autolayout不能同時存在兩條針對于同一對象的約束 否則會報錯
>>給view添加約束内狸,約束方式有幾種检眯,分別是邊距,寬昆淡,高锰瘸,左上右下距離,基準線瘪撇。添加過約束后可以有修正获茬,修正有offset(位移)修正和multipliedBy(倍率)修正。(語法有`make.equalTo or make.greaterThan Or EqualTo or make.lessThanOrEqualTo + 倍數和位移修正`倔既。使用 mas_makeConstraints方法的元素必須事先添加到父元素的中)

>mas_updateConstraints 針對上面的情況 會更新在block中出現(xiàn)的約束 不會導致出現(xiàn)兩個相同約束的情況
mas_remakeConstraints 則會清除之前的所有約束 僅保留最新的約束

------------
####使用的步驟:
>1.把Masonry的文件包拉進工程
2.在需要的地方引入頭文件 `#import "Masonry.h"`
3.建立視圖并添加到父視圖之中
4.調用Masonry封裝的方法進行約束

---------------
####簡單例子太難得我現(xiàn)在也短時間寫不出來
1.首先寫個宏定義:

 ```object
#define MS(MyWeakSelf)  __weak __typeof(&*self)MyWeakSelf = self;

解釋下:這是一個帶參數的宏定義,前面 MS(MyWeakSelf)代替后面的__weak __typeof(&*self)MyWeakSelf = self; 其實就是定義一個與當前self同一個類型的變量(名為你輸入的參數)并且是用__weak修飾的.其目的為了在Block里面進行視圖的一些操作.

2.創(chuàng)建視圖并添加到父視圖上
// 一個背景藍色的View長寬均是400中心在屏幕中心

UIView *centerViewBlue = [UIView new];
    centerViewBlue.backgroundColor = [UIColor blueColor];
    [self.view addSubview:centerViewBlue];

3.使用Masonry方法進行約束


 MS(MS);// 先走一下這個宏定義方法 相當于弱引用MS替代self

// mas_makeConstraints:這個方法只會添加新的約束
    [centerViewBlue mas_makeConstraints:^(MASConstraintMaker *make) {

// 在這個block里面利用make對象創(chuàng)建新的約束
// 尺寸約束
   make.size.mas_equalTo(CGSizeMake(400, 400));

// 位置約束
        make.centerX.mas_equalTo(MS.view.mas_centerX);
        make.centerY.mas_equalTo(MS.view.mas_centerY);
//等價 :make.center.mas_equalTo(CGPointMake(0, 0));這句話的意思是在相對于父視圖偏移量均0也可以寫成make.center.mas_equalTo(MS.view);
        
    }];

藍色View的中心在屏幕中心而且長寬固定400

4.加一個紅色視圖View并約束使其四邊距離藍色的都是100

    UIView *redView = [UIView new];
    redView.backgroundColor = [UIColor redColor];
    [self.view addSubview:redView];
    __weak UIView *blueView = centerViewBlue;
    [redView mas_makeConstraints:^(MASConstraintMaker *make) {

// 四邊的邊距都是固定值
        make.left.equalTo(blueView).offset(100);  // 向右100間距
        make.right.equalTo(blueView).offset(-100); // 向左100間距
        make.top.equalTo(blueView).offset(100); // 向下100間距
        make.bottom.equalTo(blueView).offset(-100); // 向左100間距

//效果和下面的代碼是一樣的
  make.edges.equalTo(blueView).with.insets(UIEdgeInsetsMake(100, 100, 100, 100)
    }];

紅色的View距離藍色的View四面邊距都是100

5,加一個綠色的大小是紅色的一半,位于紅色的中心
// 綠色的控件

    UIView *greeView = [UIView new];
    
    greeView.backgroundColor = [UIColor greenColor];
    
    [self.view addSubview:greeView];

    __weak UIView *redViewTemp = redView;
    
   [greeView mas_makeConstraints:^(MASConstraintMaker *make) {
        // 寬高是紅色視圖的0.5倍
        make.size.mas_equalTo(redViewTemp).multipliedBy(0.5);
        // 中心是紅色視圖的中心
        make.center.mas_equalTo(redViewTemp);
  
    }];

綠色View長寬是紅色View的一半中心一樣

難的,我也掌握不好,有時間再寫點其他復雜的

'

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市鹏氧,隨后出現(xiàn)的幾起案子渤涌,更是在濱河造成了極大的恐慌,老刑警劉巖把还,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件实蓬,死亡現(xiàn)場離奇詭異,居然都是意外死亡吊履,警方通過查閱死者的電腦和手機安皱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來艇炎,“玉大人酌伊,你說我怎么就攤上這事∽鹤伲” “怎么了居砖?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長驴娃。 經常有香客問我奏候,道長,這世上最難降的妖魔是什么唇敞? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任蔗草,我火速辦了婚禮咒彤,結果婚禮上,老公的妹妹穿的比我還像新娘咒精。我一直安慰自己蔼紧,他們只是感情好,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布狠轻。 她就那樣靜靜地躺著奸例,像睡著了一般。 火紅的嫁衣襯著肌膚如雪向楼。 梳的紋絲不亂的頭發(fā)上查吊,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天,我揣著相機與錄音湖蜕,去河邊找鬼逻卖。 笑死,一個胖子當著我的面吹牛昭抒,可吹牛的內容都是我干的评也。 我是一名探鬼主播,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼灭返,長吁一口氣:“原來是場噩夢啊……” “哼盗迟!你這毒婦竟也來了?” 一聲冷哼從身側響起熙含,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤罚缕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后怎静,有當地人在樹林里發(fā)現(xiàn)了一具尸體邮弹,經...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年蚓聘,在試婚紗的時候發(fā)現(xiàn)自己被綠了腌乡。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡夜牡,死狀恐怖与纽,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情氯材,我是刑警寧澤渣锦,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站氢哮,受9級特大地震影響袋毙,放射性物質發(fā)生泄漏。R本人自食惡果不足惜冗尤,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一听盖、第九天 我趴在偏房一處隱蔽的房頂上張望胀溺。 院中可真熱鬧,春花似錦皆看、人聲如沸仓坞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽无埃。三九已至,卻和暖如春毛雇,著一層夾襖步出監(jiān)牢的瞬間嫉称,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工灵疮, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留织阅,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓震捣,卻偏偏與公主長得像荔棉,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蒿赢,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內容