TL; DR:
Rápido:
extension UIColor {
var lighterColor: UIColor {
return lighterColor(removeSaturation: 0.5, resultAlpha: -1)
}
func lighterColor(removeSaturation val: CGFloat, resultAlpha alpha: CGFloat) -> UIColor {
var h: CGFloat = 0, s: CGFloat = 0
var b: CGFloat = 0, a: CGFloat = 0
guard getHue(&h, saturation: &s, brightness: &b, alpha: &a)
else {return self}
return UIColor(hue: h,
saturation: max(s - val, 0.0),
brightness: b,
alpha: alpha == -1 ? a : alpha)
}
}
Uso:
let lightColor = somethingDark.lighterColor
Objetivo-C:
- (UIColor *)lighterColorRemoveSaturation:(CGFloat)removeS
resultAlpha:(CGFloat)alpha {
CGFloat h,s,b,a;
if ([self getHue:&h saturation:&s brightness:&b alpha:&a]) {
return [UIColor colorWithHue:h
saturation:MAX(s - removeS, 0.0)
brightness:b
alpha:alpha == -1? a:alpha];
}
return nil;
}
- (UIColor *)lighterColor {
return [self lighterColorRemoveSaturation:0.5
resultAlpha:-1];
}
@rchampourlier estava certo em seu comentário para @ user529758 (A resposta aceita) - As soluções HSB (ou HSV) e RGB oferecem resultados completamente diferentes. O RGB apenas adiciona (ou aproxima a cor) o branco, e a solução HSB aproxima a cor da borda na escala Brigtness - que basicamente começa com preto e termina com a cor pura ...
Basicamente, o brilho (valor) torna a cor menos ou mais próxima do preto, enquanto a saturação a torna menos ou mais próxima do branco ...
Como visto aqui:
Portanto, a solução para fazer uma cor realmente brilhante (ou seja, mais perto de branco ...) será para torná-lo do valor de saturação menor , resultando esta solução:
- (UIColor *)lighterColor {
CGFloat h,s,b,a;
if ([self getHue:&h saturation:&s brightness:&b alpha:&a]) {
return [UIColor colorWithHue:h
saturation:MAX(s - 0.3, 0.0)
brightness:b /*MIN(b * 1.3, 1.0)*/
alpha:a];
}
return nil;
}