用截图来描述最简单(我所指的“视图”位于每幅图片的右下角):
模拟器: iPhone 8,故事板视图为: iPhone 8-工作完美

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

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

应该正确工作的代码示例,以及在将故事板设置为该型号电话时所做的代码示例,但在其他情况下不这样做:
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)时,它在与上面的图片相同的情况下工作/失败。
这里发生了什么事?只是模拟器出了问题吗?我是不是不正确地使用自动收费表?如果我真的在手机上试用,而不是在模拟器上,这会成功吗?
发布于 2018-11-26 22:17:46
您可以尝试将帧行放入viewDidLayoutSubviews中。
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
gradientLayer.frame = self.view.bounds
}它非常适合与情节提要相同设置的模拟器,因为在viewDidLayoutSubviews提供当前模拟器/设备的正确大小之前,将考虑渲染它的视图大小。
发布于 2018-11-26 22:22:04
您设置的框架不正确。宽度和高度应从self.view.frame导出。
试着使用
gradientLayer.frame = CGRect(x: 0, y:0, width: self.view.frame.width, height: self.view.frame.height)如果你想使用self.view.bounds,
那就试试
gradientLayer.frame = self.view.bounds如果有用的话请告诉我。
https://stackoverflow.com/questions/53489919
复制相似问题