解决 IOS的UIScrollView的自动布局

转载于 http://blog.csdn.net/dongtaochen2039/article/details/41749209 感谢博主的分享。ios

最近在研究ios开发,遇到的UIScrollView的自动布局问题,特记录之。xcode

终结的要点有:app

    添加一个AnchorView为UIScrollView的ContentView肯定宽高。框架


操做以下:ide

1.咱们须要作什么。

咱们须要本身完成一个相似于collection view 的功能。完成的效果图以下:布局


上面的标题栏总体是一个view,下面的工做区是scrollview。自动布局后横屏效果以下:url


3.view 结构


最外层的view是根视图,第一个view(包含两个button,和p_w_picpathview的)是标题栏。第二个view(包含scrollview的)是scrollview的滑动区,就是上图的工做区。spa

之因此这么设计就是将复杂的布局简单化,这样原先标题栏好几个视图和scrollview的自动布局就变成一个view和scrollview的自动布局。总体框架图以下:.net



首先先对区域1和区域2的父view进行自动布局,他们的自动布局比较简单,写出上下左右的间距便可。设计

下面咱们主要讲解下区域2的布局。咱们平时对 scrollview进行布局,咱们知道scroll view除了自身的布局须要考虑(x, y, width, height)外,还有一个contentSize属性也必需要在布局的过程当中进行肯定,contentSize是UIScrollView用于肯定它所 要展现的内容尺寸的大小,而这个contentSize在布局中其实是又scroll view的子view :content view的宽和高实现的,注意:咱们不能将content view的宽和高的约束设定为由scroll view决定(如和scroll view等宽、等高),不然,Xcode会有警告:scroll view的content size不肯定!


在这种状况下,咱们必需要对content view的布局约束引入scroll view以外其余参照物,咱们拖进来一个辅助的view做为参照物or锚点,示意图以下:



在storyboard中这3个视图的结构以下:




经过这个参考view,肯定content view的宽度和高度,尽管content view的尺寸能够不依赖于scroll view,但咱们还不得不设定content view 和其父view的关系:具体而言就是要肯定content view和scroll view的top, bottom, leading和trailing contstraints,这个地方可能比较具备迷惑性,缘由是苹果对于这四个约束的使用在scroll view中作了变化:它再也不是肯定content view尺寸的依据,而是帮助scroll view中content view四周的边界(or你能够理解为留白),进而肯定scroll view的contentSize属性。


contentView具体的约束以下:

 

scrllview的约束能够指定充满父view,anchor view左边、右边、上边紧挨父视图。这会xcode会让你指定anchor view的高度,不然会有***的提示信息。这样再指定anchor view的高度就能够了。这会你应该有疑问,anchor view不是用来肯定滑动区域content view的大小的吗?若是把anchor view的大小写死,contentView也不就不能改变大小了吗?咱们须要在代码里面动态的更改anchor view的大小,在咱们的代码里面也就是高度,由于宽度是屏幕宽度,不用更改。anchor view的高度约束以下图所示:





这里我随便付的值,而后在代码里面动态调整高度,修改的代码以下:

[objc] view plaincopy

  1. //计算contentView的高度  

  2. int rowNums = (appDelegate.workerList.count+COLUMN_COUNT-1)/COLUMN_COUNT;  

  3. int totalHeight = VIEW_HEIGHT * rowNums + (rowNums+1)*MIDDLE_GAP+100;  

  4.   

  5. //找到anchor view的高度约束修改高度  

  6. NSArray *arrs = scrollAnchorView.constraints;  

  7. for (NSLayoutConstraint *attr in arrs) {  

  8.     if(attr.firstAttribute == NSLayoutAttributeHeight){  

  9.         attr.constant = totalHeight;  

  10.     }  

  11. }  

  12.   

  13. //更新父视图约束条件  

  14. [scrollAnchorView.superview.superview updateConstraints];  

上面的代码放在你须要动态肯定contentview高度的地方。修改好以后,就能够看到刚开始的效果了。

相关文章
相关标签/搜索