można przekształcić UIColor do CIColor a następnie wyodrębnić składowych koloru z tego jak następuje:
Aktualizacja: Xcode 8.3.2 • Swift 3.1
extension UIColor {
var coreImageColor: CIColor {
return CIColor(color: self)
}
var components: (red: CGFloat, green: CGFloat, blue: CGFloat, alpha: CGFloat) {
let coreImageColor = self.coreImageColor
return (coreImageColor.red, coreImageColor.green, coreImageColor.blue, coreImageColor.alpha)
}
}
wykorzystanie:
let myColor = UIColor(red: 0.5, green: 1, blue: 0.25, alpha: 0.5)
let myCIColor = myColor.coreImageColor
let greencomponent = myColor.components.green
let myColorComponents = myColor.components
print(myColorComponents.red) // 0.5
print(myColorComponents.green) // 1.0
print(myColorComponents.blue) // 0.25
print(myColorComponents.alpha) // 0.5
Można również użyć funkcji getRed() i utworzyć rozszerzenie wyodrębnić składniki następująco ale wynik będzie opcjonalnie:
extension UIColor {
var components: (red: CGFloat, green: CGFloat, blue: CGFloat, alpha: CGFloat)? {
var r: CGFloat = 0, g: CGFloat = 0, b: CGFloat = 0, a: CGFloat = 0
return getRed(&r, green: &g, blue: &b, alpha: &a) ? (r,g,b,a) : nil
}
}
Wykorzystanie
let myColor = UIColor(red: 0.5, green: 1, blue: 0.25, alpha: 0.5)
if let myColorComponents = myColor.components {
print(myColorComponents.red) // 0.5
print(myColorComponents.green) // 1.0
print(myColorComponents.blue) // 0.25
print(myColorComponents.alpha) // 0.5
}
Po co tworzyć 4 wystąpienia "CIColor"? Utwórz jedną, przypisz ją do zmiennej i pobierz z niej 4 komponenty. – rmaddy
Czy ktoś może wyjaśnić dokładnie, jak to działa? Zgaduję, że "komponenty" to krotka, która zawiera elementy. Ale co reszta? Jakiś rodzaj funkcji? – netigger
Mam to. Jego "Ustawienie domyślnej wartości właściwości z zamknięciem lub funkcją" z https://developer.apple.com/library/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Initialization.html#//apple_ref/doc/uid/TP40014097- CH18-ID232 – netigger