在 iPhone 6s 上放错了 CAGradientLayer
Misplaced CAGradientLayer on iPhone 6s
我有一些 UILabels
有彩色背景,我向它们添加了 CAGradientLayers
,如下所示。
CAGradientLayer * gradientLayer = [CAGradientLayer layer];
gradientLayer.colors = [NSArray arrayWithObjects:
(id) [UIColor colorWithWhite:1 alpha:0.3].CGColor,
(id) [UIColor colorWithWhite:0.5 alpha:0.3].CGColor, nil];
gradientLayer.frame = label.bounds;
gradientLayer.cornerRadius = label.layer.cornerRadius;
[label.layer insertSublayer:gradientLayer atIndex:0];
在 iPhone 4 和 iPhone 5s 上它看起来很完美,但在 iPhone 6s 上 CAGradientLayers
像下面的屏幕截图一样水平错位。
UIButton 也会出现此问题。
我是 运行 iOS 9.3。
您需要的是处理自动布局约束。此 swift 代码表示您需要在 viewDidLayoutSubviews
方法中执行的操作:
class ViewController: UIViewController {
@IBOutlet weak var button: UIButton!
let gradientLayer = CAGradientLayer()
override func viewDidLoad() {
super.viewDidLoad()
gradientLayer.colors = [UIColor(white: 1, alpha: 0.3).CGColor,
UIColor(white: 0.5, alpha: 0.3).CGColor]
gradientLayer.frame = button.bounds
gradientLayer.cornerRadius = button.layer.cornerRadius
button.layer.insertSublayer(gradientLayer, atIndex: 0)
}
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
gradientLayer.frame = button.bounds
}
}
我有一些 UILabels
有彩色背景,我向它们添加了 CAGradientLayers
,如下所示。
CAGradientLayer * gradientLayer = [CAGradientLayer layer];
gradientLayer.colors = [NSArray arrayWithObjects:
(id) [UIColor colorWithWhite:1 alpha:0.3].CGColor,
(id) [UIColor colorWithWhite:0.5 alpha:0.3].CGColor, nil];
gradientLayer.frame = label.bounds;
gradientLayer.cornerRadius = label.layer.cornerRadius;
[label.layer insertSublayer:gradientLayer atIndex:0];
在 iPhone 4 和 iPhone 5s 上它看起来很完美,但在 iPhone 6s 上 CAGradientLayers
像下面的屏幕截图一样水平错位。
UIButton 也会出现此问题。
我是 运行 iOS 9.3。
您需要的是处理自动布局约束。此 swift 代码表示您需要在 viewDidLayoutSubviews
方法中执行的操作:
class ViewController: UIViewController {
@IBOutlet weak var button: UIButton!
let gradientLayer = CAGradientLayer()
override func viewDidLoad() {
super.viewDidLoad()
gradientLayer.colors = [UIColor(white: 1, alpha: 0.3).CGColor,
UIColor(white: 0.5, alpha: 0.3).CGColor]
gradientLayer.frame = button.bounds
gradientLayer.cornerRadius = button.layer.cornerRadius
button.layer.insertSublayer(gradientLayer, atIndex: 0)
}
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
gradientLayer.frame = button.bounds
}
}