如果用 xib 或者 storyboard 界面布局,我要怎样在代码里获取 view 的 frame

2015-05-22 15:40:28 +08:00
 cheng4741
4056 次点击
所在节点    iDev
15 条回复
xhacker
2015-05-22 15:47:22 +08:00
就 view.frame 就行。
cheng4741
2015-05-22 16:14:02 +08:00
@xhacker 额,我好像没说清楚,我的意思是view.frame在自动布局的情况下根本不适用。
babyname
2015-05-22 16:14:43 +08:00
@cheng4741 为什么不适用,怎么得出的结论。
newtonisaac
2015-05-22 16:15:23 +08:00
代码哪里?是已经生成了view还是之前?
nomemo
2015-05-22 16:18:00 +08:00
@cheng4741 根据约束条件取
cheng4741
2015-05-22 16:21:53 +08:00
@babyname 你试一下你就知道了,view.frame得到的是在xib上的大小,而不是运行时的实际大小
cheng4741
2015-05-22 16:22:40 +08:00
@newtonisaac 已经生成了,现在我要给这 view添加一个layer,需要知道它的大小
cheng4741
2015-05-22 16:24:11 +08:00
@nomemo 你的意思是让我根据条件和屏幕大小算吗?我以前是这么做,但是觉得太罗嗦。
black
2015-05-22 18:04:56 +08:00
这是 iOS 开发的老"坑"了,原因是对 view controller 的生命周期理解不够。

我给两个方案给你:

1. 把代码放到 -(void)viewDidLayoutSubviews 里去吧,你会发现这时 view controller 的 view 大小已经调整好了,但是 [千万要注意!] 这个方法会调用多次。

2. 仍然放在 -(void)viewDidLoad,如下:

- (void)viewDidLoad
{
...
dispatch_async(dispatch_get_main_queue(), ^{
// your code
});
}
dorentus
2015-05-22 18:16:47 +08:00
viewWillAppear 里面的 frame 也应该是正确的了,不过也会有被多次调用的问题

你这种情况也可以 subclass UIView,然后在 layoutSubviews 里面处理 frame 的变化吧
langhua9527
2015-05-22 18:19:18 +08:00
自动布局为什么要取frame?
yoki
2015-05-25 15:06:15 +08:00
你好 之前也遇到过这样的问题 来说一下我的解决办法

自动布局是会在更新视图的时候同步更新frame bounds的 然而有时候我们在代码中获取的时候却得到{(0,0),(0,0)} 或者各种奇怪的结果 这是因为在你用代码获取frame的时候系统还没有更新你的layout

楼上的朋友@dorentus 提供的解决方案应该是可行的 因为在viewWillAppear中一般的视图都更新完layout了 应该是可以获取到的

但是有时候我们想在任意函数中获取怎么办呢

解决方案是在获取之前加上一句[myDemoView layoutIfNeeded];



```
[myDemoView layoutIfNeeded];

NSLog("frame:%@",NSStringFromRect(myDemoView.frame));
```

这个回复是我在PC上打的 拼写也许有错误 希望能帮到你
cheng4741
2015-06-01 11:03:41 +08:00
@yoki 谢谢,被这个困惑好久了,终于明白了
cheng4741
2015-06-01 11:04:31 +08:00
@black 学习了
yh4801480
2015-08-13 13:35:41 +08:00
@cheng4741 牛逼啊

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/193006

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX