美文网首页花落√莫相思
67-Swift 之颜色管理(UIColor)

67-Swift 之颜色管理(UIColor)

作者: NetWork小贱 | 来源:发表于2017-09-05 15:35 被阅读40次

前言

在App的开发中,色彩的绚丽往往能够吸引大量用户。颜色的配比和管理也就显的非常重要。今天我们就一起探究 Swift 的颜色管理类 UIColor

颜色的使用

1、 颜色的基本使用

// MARK: 颜色类的介绍
func introduceColor() -> UIColor {
    var color:UIColor!
    
    // TODO: 控制白色的色值(0~1)和透明度(0~1)
    color = UIColor.init(white: 0.4, alpha: 0.5)
    
    // TODO: 使用图片作为颜色,取色范围是从左上角开始。
    color = UIColor.init(patternImage: UIImage.init(named: "colors.jpg")!)
    
    // TODO: 通过控制 红、绿、蓝 的色值和透明度来获取数值。
    color = UIColor.init(red: 0.5, green: 0.4, blue: 0.2, alpha: 1.0)
    
    // 现在标准的颜色转化(sRGB)相比 RGB 颜色稍微平淡一些。
    color = UIColor.init(displayP3Red: 0.6, green: 0.2, blue: 0.8, alpha: 1.0)
    
    // 通过色调、饱和、亮度、透明度来创建颜色,它们的取值范围是(0~1.0)
    color = UIColor.init(hue: 0.6, saturation: 0.4, brightness: 0.7, alpha: 1.0)
    
    // 原始的颜色转化
    color = UIColor.init(colorLiteralRed: 0.6, green: 0.2, blue: 0.6, alpha: 1.0)
    
    // 通过 cgColor 对象来创建颜色
    color = UIColor.init(cgColor: UIColor.red.cgColor)
    
    // 通过 ciColor 来创建对象
    color = UIColor.init(ciColor: CIColor.init(red: 0.4, green: 0.5, blue: 0.8, alpha: 1.0))
    
    // 可以直接调用的颜色
    color = UIColor.red
    color = UIColor.black
    
    // 颜色透明度设置
    color.withAlphaComponent(1.0)
    return color
}

2、 颜色在上下文(绘图)中的方法

//  TODO: 颜色设置   
open func set()
// TODO: 颜色的填充设置   
open func setFill()
// TODO: 路径的颜色设置
open func setStroke()

3、颜色十六进制的转换

extension String {
    func color() -> UIColor {
        var doString = self
        // 去除空格
        doString = doString.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines).uppercased()
        var length = doString.characters.count
        // 判断是否含有 “#”
        if doString.hasPrefix("#"){
            let index = doString.index(doString.startIndex, offsetBy:1)
            doString = doString.substring(from: index)
            length = doString.characters.count
        }
        if length == 6 {
            let rRang = doString.index(doString.startIndex, offsetBy: 2)
            let redStr = doString.substring(to: rRang)
            doString = doString.substring(from: rRang)
            let gRang = doString.index(doString.startIndex, offsetBy: 2)
            let greenStr = doString.substring(to: gRang)
            doString = doString.substring(from: gRang)
            let blueRang = doString.index(doString.startIndex, offsetBy: 2)
            let blueStr = doString.substring(to: blueRang)
            // 声明三个变量
            var r:CUnsignedInt = 0 ,g:CUnsignedInt = 0, b:CUnsignedInt = 0
            // 获取其值
            Scanner.init(string: redStr).scanHexInt32(&r)
            Scanner.init(string: greenStr).scanHexInt32(&g)
            Scanner.init(string: blueStr).scanHexInt32(&b)
            return UIColor.init(displayP3Red: CGFloat(r)/255.0, green: CGFloat(g)/255.0, blue: CGFloat(b)/255.0, alpha: 1.0)
        }
        return UIColor.white
    }
}

使用方法:

override func viewDidLoad() {
    super.viewDidLoad()
    let  View = UIView.init(frame: CGRect.init(x: 100, y: 100, width: 100, height: 100))
    View.backgroundColor = "fff333".color()
    self.view.addSubview(View)
}

相关文章

网友评论

    本文标题:67-Swift 之颜色管理(UIColor)

    本文链接:https://www.haomeiwen.com/subject/wnrujxtx.html