日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Masonry自动布局详解一:基本用法

發布時間:2025/3/21 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Masonry自动布局详解一:基本用法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Masonry自動布局詳解一:基本用法


說到iOS自動布局,有很多的解決辦法。有的人使用xib/storyboard自動布局,也有人使用frame來適配。對于前者,筆者并不喜歡,也不支持。對于后者,更是麻煩,到處計算高度、寬度等,千萬大量代碼的冗余,對維護和開發的效率都很低。

筆者在這里介紹純代碼自動布局的第三方庫:Masonry。這個庫使用率相當高,在全世界都有大量的開發者在使用,其star數量也是相當高的。

支持原創,請閱讀原文

效果圖


本節詳解Masonry的基本用法,先看看效果圖:

我們這里要布局使這三個控件的高度一致,而綠色和紅色的控件高度和寬度相待。

核心代碼


看下代碼:

- (void)viewDidLoad {[super viewDidLoad];UIView *greenView = UIView.new;greenView.backgroundColor = UIColor.greenColor;greenView.layer.borderColor = UIColor.blackColor.CGColor;greenView.layer.borderWidth = 2;[self.view addSubview:greenView];UIView *redView = UIView.new;redView.backgroundColor = UIColor.redColor;redView.layer.borderColor = UIColor.blackColor.CGColor;redView.layer.borderWidth = 2;[self.view addSubview:redView];UIView *blueView = UIView.new;blueView.backgroundColor = UIColor.blueColor;blueView.layer.borderColor = UIColor.blackColor.CGColor;blueView.layer.borderWidth = 2;[self.view addSubview:blueView];// 使這三個控件等高CGFloat padding = 10;[greenView mas_makeConstraints:^(MASConstraintMaker *make) {make.top.mas_equalTo(padding);make.left.mas_equalTo(padding);make.right.mas_equalTo(redView.mas_left).offset(-padding);make.bottom.mas_equalTo(blueView.mas_top).offset(-padding);// 三個控件等高make.height.mas_equalTo(@[redView, blueView]);// 紅、綠這兩個控件等高make.width.mas_equalTo(redView);}];[redView mas_makeConstraints:^(MASConstraintMaker *make) {make.top.height.bottom.mas_equalTo(greenView);make.right.mas_equalTo(-padding);make.left.mas_equalTo(greenView.mas_right).offset(padding);}];[blueView mas_makeConstraints:^(MASConstraintMaker *make) {make.height.mas_equalTo(greenView);make.bottom.mas_equalTo(-padding);make.left.mas_equalTo(padding);make.right.mas_equalTo(-padding);}]; }

講解


添加約束的方法是:mas_makeConstraints。我們可以看到,約束可以使用鏈式方式,使用方法很簡單,看起來像一句話。

看這句話:make.top.height.bottom.mas_equalTo(greenView),意思是:使我的頂部、高度和底部都與greenView的頂部、高度和底部相等。因此,只要greenView的約束添加好了,那么redView的頂部、高度和底部也就自動計算出來了。

大多時候,我們并不會將一句話完整地寫出來,而是使用簡寫的方式。如:

make.right.mas_equalTo(-padding);

其完整寫法為:

make.right.mas_equalTo(bludView.superView.mas_right).offset(-padding);

當我們是要與父控件相對約束時,可以省略掉父視圖。注意,并不是什么時候都可以省略,只有約束是同樣的才可以省略。比如,約束都是right才可以。如果是一個left一個是right,那么就不能省略了。

源代碼


大家可以到筆者的github下載源代碼:https://github.com/CoderJackyHuang/MasonryDemo

溫馨提示:本節所講內容對應于BasicController中的內容

關注我


微信公眾號:iOSDevShares
有問必答QQ群:324400294

總結

以上是生活随笔為你收集整理的Masonry自动布局详解一:基本用法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日韩成人短视频 | 国产一区视频网站 | av手机天堂| 超碰国产一区二区三区 | 人人妻人人澡人人爽欧美一区 | 日韩aa视频 | 麻豆久久久午夜一区二区 | 国产欧美一区二区三区国产幕精品 | 婷婷在线免费观看 | 国产日韩欧美成人 | 日韩第一页在线观看 | 在线免费看黄 | 亚洲人妻一区二区三区 | 亚洲色图欧美日韩 | 久操视频在线观看 | 欧美久久久久久久久久久 | 浴室里强摁做开腿呻吟男男 | 黄色av播放 | 秋霞福利影院 | 日韩美女国产精品 | 欧美一区二区公司 | 日韩午夜影院 | 精品久久人人 | 美女黄18以下禁止观看 | 三上悠亚一区二区 | 日本在线中文 | 先锋资源av在线 | 无码精品国产一区二区三区 | hs网站在线观看 | 超碰爱爱 | 日日干夜夜骑 | 国家队动漫免费观看在线观看晨光 | 日韩三区在线观看 | 91黄色免费视频 | 日韩精品xxxx | 国产精品久久久久久久久绿色 | 一级黄色视 | 日韩黄网站 | 国产手机精品视频 | 中文字幕在线播放第一页 | 最新中文字幕在线观看 | www.五月.com| 日本午夜大片 | 日批免费在线观看 | 亚洲裸体视频 | 一级黄色欧美 | 91超碰在线免费观看 | 伊人色综合网 | www.久久精品.com | 午夜精品久久久久久久蜜桃 | 亚洲911精品成人18网站 | 日日碰狠狠添天天爽 | 肥熟女一区二区三肥熟女 | 特级做a爰片毛片免费69 | 欧美一区二区三区在线观看视频 | 国产一级片免费播放 | a天堂在线观看视频 | 视频区图片区小说区 | 尤物视频在线播放 | 久久久久久久久久久久久久久久久久久久 | 国内av自拍| 特级西西人体 | 免费色站 | 美国少妇性做爰 | 中文字幕久久网 | av在线天堂网 | 国产丝袜精品视频 | 国产欧美熟妇另类久久久 | 国产欧美另类 | 美女视频在线观看免费 | 黄色成年网站 | 香蕉综合在线 | 欧美激情综合色综合啪啪五月 | 精品盗摄一区二区三区 | 伊人院| 雨宫琴音一区二区三区 | 成人免费一级视频 | 一本一道波多野结衣一区二区 | 国产精品xxx在线观看 | 天天干,天天操 | 欧美人一级淫片a免费播放 西方av在线 | 91av官网| 久久精品黄色片 | 法国空姐电影在线 | 91羞羞网站 | 中文av网站| 欧美日韩一二区 | 三年在线观看视频 | 91福利视频在线 | 王者后宫yin肉h文催眠 | 在线播放国产一区 | 色婷婷视频在线 | 琪琪射| 狠狠干综合 | 一区二区三区四区免费 | 男女av| 亚洲三区av| 国产熟妇搡bbbb搡bbbb | 黄色三级三级 |