美文网首页花落√莫相思
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