在开发中我们经常会遇到下面图片这种需求
data:image/s3,"s3://crabby-images/0ed9a/0ed9a6512335271d77d8384adb57247c07ee12d9" alt=""
左边一个UIImageView 右边两个UILable,然后这两个lable分别底部和顶部对应imageView的中间,如果用Masonry代码写就比较简答,那如果用xib呢,之前一直回避这个问题,全是用代码写的,今天就研究了下用xib如何实现。
首先建立一个工程,
data:image/s3,"s3://crabby-images/c20f9/c20f92b66fcac688b4fa88e39de7d0a3f75b1954" alt=""
在Main.storyboard里面拖入两个UILable和一个UIImageVIew,和一个UIView,这个UIView是当一个容器来放置label的,这个思路来源于里脊串的一篇博客,具体是这个uiview的中部对应imageview的中部,uiview的top,bottom,left,right对应lable。废话不多说,一步步实现。
1,选中uiimageview,给uiimageview加约束,宽高100,距离左边10,上边10.
data:image/s3,"s3://crabby-images/e2e4a/e2e4af176195067693bf33d0648d61bd42ba7cfe" alt=""
2,把两个uilab拖入空视图中,给第一个lable加约束,距离空白视图顶部0,lef 为0;
data:image/s3,"s3://crabby-images/47017/47017794dbb4212569b00c36eda6aca89ebcde2d" alt=""
3,选中第2个lable,添加约束,距离空白 view left 为0,顶部距离第一个lable底部为0;
data:image/s3,"s3://crabby-images/97e5c/97e5c43834179328dfbac891ac3a4d694ef6a60b" alt=""
4,选中空白uiview按着Ctr键拖动到第2个lable,选择 Bottom Space to Container
data:image/s3,"s3://crabby-images/b9adc/b9adcb90545b4a72bcaf5db235fc4bf41eee2104" alt=""
5,选中空白uiview按着Ctr键拖动到第1个lable(其实第2个也行,到时间就看你那个lable长,依据就是哪一个),选择Trailing Space to Container
data:image/s3,"s3://crabby-images/b0cdc/b0cdce1b9d979ebde9c1fd3aaf8ec1c5d1794e7d" alt=""
6,选中空白uiview按着Ctr键拖动到imageview 选择Center Vertically
data:image/s3,"s3://crabby-images/04e54/04e545dd008ba990e855d82321e3adf4431ec9f7" alt=""
7,选中空白uiview,设置其跟uiimageview的间距是10
data:image/s3,"s3://crabby-images/e1b89/e1b8984eac97f64e433e13ec43d3cc01fb9f7ba5" alt=""
8,然后更新视图 大概会看到这样的视图,跟我们需要的视图还不太一样,接下来修改,
data:image/s3,"s3://crabby-images/e20e2/e20e2fe04fee5b35aa81e3e90b2789b7f1ed5d5a" alt=""
9,选中空白uiview,然后点击右边这个选项,会看到一系列的约束。
data:image/s3,"s3://crabby-images/332be/332be501f1012d1c264decc2e548f94b8c13e0ad" alt=""
其中有两个选项是这样的带有数字,分别表示,uilable的右边到空白view的右边距离是70,和uilable的底部到空白view的底部距离是54,把这两个值修改为0;
data:image/s3,"s3://crabby-images/a86f5/a86f5e002bfa9750ca24448b6aad8559dca97a4c" alt=""
10,接下来如果不出意外的话,视图就是我们想要的效果了。
data:image/s3,"s3://crabby-images/2aa17/2aa171477cfc12090bc788c168489cea8d9b9ddc" alt=""
其实一堆约束拖下来,感觉还没有写起来的约束快,但是有些页面,使用xib拖的话,要不手写的代码快多了,如果你看了觉得我描述不清楚的话,我上传了一个demo,地址在这里https://github.com/yunisSong/YunisTool
里面还包含了两个小工具。
des加解密,
获取地理位置及地理位置坐标
网友评论