首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >视图不正确缩放,除非设备在情节提要中设置(查看为:iPhone5s/8/etc)

视图不正确缩放,除非设备在情节提要中设置(查看为:iPhone5s/8/etc)
EN

Stack Overflow用户
提问于 2018-11-26 22:13:12
回答 2查看 64关注 0票数 3

用截图来描述最简单(我所指的“视图”位于每幅图片的右下角):

模拟器: iPhone 8,故事板视图为: iPhone 8-工作完美

模拟器: iPhone 8+,故事板视图为: iPhone 8-不工作

模拟器: iPhone 8+,故事板视图为: iPhone 8+-工作完美

应该正确工作的代码示例,以及在将故事板设置为该型号电话时所做的代码示例,但在其他情况下不这样做:

代码语言:javascript
复制
gradientLayer.frame = CGRect(x: 0, y:0, width: self.view.bounds.width, height: self.view.bounds.height)
gradientLayer.colors = [Colors().bgRed.cgColor, Colors().mediumBlue.cgColor, Colors().highlitMedBlue.cgColor]
gradientLayer.startPoint = CGPoint(x: 0.1, y: 0.1)
gradientLayer.endPoint = CGPoint(x: 1, y: 1)
self.view.layer.addSublayer(gradientLayer)

其他失败的例子是当我使用view.convert(viewX,to: viewY)时,它在与上面的图片相同的情况下工作/失败。

这里发生了什么事?只是模拟器出了问题吗?我是不是不正确地使用自动收费表?如果我真的在手机上试用,而不是在模拟器上,这会成功吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-11-26 22:17:46

您可以尝试将帧行放入viewDidLayoutSubviews中。

代码语言:javascript
复制
override func viewDidLayoutSubviews() {
  super.viewDidLayoutSubviews() 
  gradientLayer.frame = self.view.bounds 
}

它非常适合与情节提要相同设置的模拟器,因为在viewDidLayoutSubviews提供当前模拟器/设备的正确大小之前,将考虑渲染它的视图大小。

票数 4
EN

Stack Overflow用户

发布于 2018-11-26 22:22:04

您设置的框架不正确。宽度和高度应从self.view.frame导出。

试着使用

代码语言:javascript
复制
gradientLayer.frame = CGRect(x: 0, y:0, width: self.view.frame.width, height: self.view.frame.height)

如果你想使用self.view.bounds,

那就试试

代码语言:javascript
复制
gradientLayer.frame = self.view.bounds

如果有用的话请告诉我。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53489919

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档