框架与边界和自动布局约束?

Frames vs Bounds and autolayout constraints?

我最近在此处阅读了一个关于框架和边界 属性 视图的精彩问题 - UIView frame, bounds and center。我也尝试使用自动布局对此进行更多试验,现在我发现自己处于一个非常矛盾的场景中。请耐心等待,因为这可能需要一点时间。

我会一一强调它们,所以请帮助我克服所有这些 -

我有什么? -

具有如下约束的视图层次结构 - (设计是在默认的ViewController大小600*600上完成的)

我试图打印出这些视图的框架和边界 -

contentView

 print(contentView.frame)// o/p - (0.0, 64.0, 600.0, 536.0) 
  print(contentView.bounds)//o/p- (0.0, 0.0, 600.0, 536.0)

Q) **a)**为什么屏幕显示600*536我可能运行它。例如。如果我在 4s 屏幕或 iPad 屏幕上 运行 它打印相同?

**b)**而且它总是在我的故事板中推断出我的 VC 的大小!!例如。如果我把屏幕设计成3.5寸VC,那么边框就变成了320.0*416.0.

**c)** 因为它固定在视图的所有边上,所以它应该与视图大小相同,而且它始终固定在边缘上。那么为什么它的大小与 self.view.frame.width*self.view.frame.height

不同呢?

侧视图

print(sideView.frame)//o/p - (520.0, 86.0, 80.0, 128.0) 
   print(sideView.bounds)//o/p - (0,0, 80.0, 128.0)

Q) 如果我以编程方式设计自定义 UIView

let TestView = UIView(frame: CGRectMake(520.0, 86.0, 80.0, 128.0))//Mark:its frame is exactly same as sideView.frame
        TestView.backgroundColor = UIColor.redColor()
        self.contentView.addSubview(TestView)

所以这里的 sideView(contentView 的子视图)应该被 TestView 替换,但不是,o/p 屏幕与之前的情况相同。为什么?

谢谢。

Q) **a)**Why is the frame size showing 600*536 whichever screen I may run it. eg. It prints the same if I run it on a 4s screen or else in an iPad screen?

**b)**And it always infers the size of my VC in my storyboard!!. eg. If i design the screen in a 3.5 inch VC,the frame size becomes 320.0*416.0.

这将取决于何时您检查内容视图(或视图控制器的主视图)的大小。如果您要检查 viewDidLoad() 方法中的大小,您会看到它就是您在 Interface Builder 中看到的大小。这是它在故事板中保存的大小,尚未针对设备调整大小。

但是,如果您在 viewDidAppear() 方法中检查尺寸,它应该是适合设备屏幕的尺寸。

如果您真的想直接弄乱帧,您可能想在 viewDidLayoutSubviews() 中这样做。此时视图已针对设备调整大小,您可以获取更新的测量值并修改框架。虽然通常最好只是正确设置约束,然后让自动布局进行更改。