Auto layout how to hide 1 view in a view with 3 equal width views

不问归期 提交于 2019-12-28 18:22:11

问题


Currently I have 3 views inside 1 view (which is pinned to leading edge and trailing edge of superview).

The 3 views look like this currently:

However, in some cases, I wish to hide the indigo view, but still keep the last 2 the same widths like so:

How can I achieve this with autolayout? Or how can I achieve this using IBOutlets for constraints?


回答1:


If the deployment target is iOS9 or later, it is recommended to use UIStackView as the enclosing view. Setting isHidden to true on any view arranged in the UIStackView will not only make the view hidden, but also will the stack view re-organize all the non-hidden views to fill up the space that was taken by the hidden views. This behavior could be tuned by adjusting distribution on UIStackView.


Tj3n's answer works, but it has a drawback that you have to use magic numbers in your code and set constraint properties both in code and IB.

IMHO, a better solution would be setting up all the constraints in IB with different priorities and activating/deactivating them in code. Try this:

  1. Set the leading/trailing constraints as you did before.
  2. Set equal width constraints for all three views with priority high.
  3. Set 0 width constraints for all three views with priority required, but leave them deactivated in IB. And connect them to IBOutlets in code just as connecting views.
  4. Activate any of the 0 width constraints to collapse the view you want, and later deactivate them to expand.

Note that just with 1 and 2 in place, you can achieve the equal-width view layout. And with 3 and 4, you can collapse/expand any of the views selectively.




回答2:


Its pretty easy, you can create equal width constraint A for the 3 view, set its priority is 998, then create another single width constraint B1, B2, B3 for them, set priority is 997, if you want to hide any of the 3 view, set B constraint's constant to 0, and up its priority to 999, then call self.view.layoutIfNeeded, the view will hide and others will scale

The test constraint is the width constraint of the gray view:




回答3:


If it is always the indigo view which can be hidden, you should solve your problem by adding this constraints :

Indigo view : leading to superview + trailing to purpleView + width constraint

Purple view : same width as grayView

Gray View : leading to purpleView + trailing to superview

It should looks like this :

And if you change the width property of your indigoView, all should follow correctly.

Hope that help you.



来源:https://stackoverflow.com/questions/38364555/auto-layout-how-to-hide-1-view-in-a-view-with-3-equal-width-views

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!