ios - 渐变层在 iOS 中不起作用

标签 ios swift gradient

我有制作渐变的代码,但它根本没有显示。如果我更改包含该渐变的 View 颜色,我就能看到它。所以 View 很好,只是渐变有一些问题。这是我的代码:

class KolodaCardView: UIView {
    var helloWorld = "Hello World"
    var userImage = UIImageView()
    var userName = UILabel()
    var parent = UIView()
    var gradient = CAGradientLayer()
    var gradientView = UIView()

    override init(frame: CGRect) {
        super.init(frame: frame)
        parent = self
        parent.backgroundColor = .clear
        parent.layer.cornerRadius = 16
        parent.clipsToBounds = true

        setupUserImage()
        setupUserName()
    }

    override func layoutSubviews() {
        super.layoutSubviews()
        gradient.frame = gradientView.frame
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    func setupUserImage() {
        parent.addSubview(userImage)
        userImage.snp.makeConstraints { make in
            make.top.equalTo(parent)
            make.bottom.equalTo(parent)
            make.left.equalTo(parent)
            make.right.equalTo(parent)
        }
        userImage.contentMode = .scaleAspectFill
        userImage.clipsToBounds = true
        userImage.layer.cornerRadius = 16

        userImage.addSubview(gradientView)
        gradientView.snp.makeConstraints { (make) in
            make.bottom.equalToSuperview()
            make.left.equalToSuperview()
            make.right.equalToSuperview()
            make.height.equalTo(60)
        }
//        gradientView.backgroundColor = .green
        gradient.startPoint = CGPoint(x: 0, y: 0)
        gradient.endPoint = CGPoint(x: 0, y: 1)
        gradient.locations = [0.5,1.0]
        gradient.frame = gradientView.bounds
        gradient.colors = [UIColor.red.cgColor, UIColor.yellow.cgColor]
        gradient.startPoint = CGPoint(x: 0.0, y: 1.0)
        gradient.endPoint = CGPoint(x: 1.0, y: 1.0)
        gradientView.layer.insertSublayer(gradient, at: 0)
    }

    func setupUserName() {
        parent.addSubview(userName)
        userName.snp.makeConstraints { (make) in
            make.left.equalTo(parent).offset(16)
            make.right.equalTo(parent)
            make.height.equalTo(20)
            make.bottom.equalTo(-20)
        }
        userName.textColor = .black
        userName.textAlignment = .left
    }
}

我在这里检查了几个解决方案,但没有任何效果!有人可以检查我是否忽略了什么吗?

enter image description here

最佳答案

在渐变中,您必须提供渐变颜色的位置,以从起点到终点填充图层。

gradientLayer.startPoint = CGPoint(x: 0, y: 0)
gradientLayer.endPoint = CGPoint(x: 0, y: 1)
gradientLayer.colors =  [UIColor.red.cgColor ,UIColor.yellow.cgColor]
gradientLayer.locations = [0.5,1.0]
your_gradientView.layer.insertSublayer(gradientLayer, at: 0)

关于ios - 渐变层在 iOS 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49027224/

相关文章:

css - 你能在背景图片上叠加透明的 css3 渐变吗?

ios - 如何在 View 的图层颜色发生变化时制作不同的颜色外观

iOS - 带有内容插入的粘性标题 - 标题 View 不像单元格那样滚动

iphone - 自定义导航 Controller iOS 6 的问题

ios - 在 Swift 中,如何等待一个动画在下一个动画开始之前完成?

xcode - Swift 2 中的字符串索引

ios - 在解析中更改密码

ios - Metal 角色动画

css - Compass (SASS) 不向线性渐变添加供应商前缀

CSS3 线性渐变在 Firefox 上无法正常工作