Неверный CAGradientLayer на 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 неуместны горизонтально, как на следующем снимке экрана.

введите описание изображения здесь

Эта проблема возникает и для UIButtons.

Я запускаю iOS 9.3.

Ответ 1

Вам нужно иметь дело с ограничениями автоопределения. Этот быстрый код представляет собой то, что вам нужно сделать с помощью метода 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
    }

}