繁体   English   中英

向UISlider添加渐变不起作用

[英]Adding gradient to UISlider doesn't work

我试图像这样在UISlider的左侧添加一个渐变:

let gradientLayer = CAGradientLayer()
gradientLayer.frame = self.frame
gradientLayer.frame.size.height = self.trackHeight
gradientLayer.frame.origin = CGPoint.zero
gradientLayer.colors = [UIColor.blue, UIColor.red]
gradientLayer.startPoint = CGPoint(x: 0.0, y: 0.5)
gradientLayer.endPoint = CGPoint(x: 1.0, y: 0.5)

let trackImage = UIImage.imageWithLayer(layer: gradientLayer)
self.setMinimumTrackImage(trackImage, for: .normal)

UIImage扩展:

class func imageWithLayer(layer: CALayer) -> UIImage {
    UIGraphicsBeginImageContextWithOptions(layer.bounds.size, layer.isOpaque, 0.0)
    layer.render(in: UIGraphicsGetCurrentContext()!)
    let img = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()
    return img!
}

由于某种原因,当我运行该应用程序时,我没有得到渐变,甚至没有得到任何颜色,它只是纯色(alpha)而不是渐变。

知道出了什么问题吗?

谢谢!

CAGradientLayer使用CGColors数组作为输入。 要解决您的问题,请考虑使用CGColor,方法是将以下内容更改为: gradientLayer.colors = [UIColor.blue, UIColor.red]更改为gradientLayer.colors = [UIColor.blue.cgColor, UIColor.red.cgColor]

编辑您可能会在UISlider左边缘上得到一个正方形的边缘(最小轨迹图像)! 因此,为了解决该问题,只需按以下方式更改扩展功能:

class func imageWithLayer(layer: CALayer, cornerRadius: CGFloat) -> UIImage {
    layer.cornerRadius = cornerRadius
    UIGraphicsBeginImageContextWithOptions(layer.bounds.size, false, 0)
    layer.render(in: UIGraphicsGetCurrentContext()!)
    let img = UIGraphicsGetImageFromCurrentImageContext()?.resizableImage(withCapInsets: UIEdgeInsets.zero)
    UIGraphicsEndImageContext()
    return img!
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM