我想根据背景图像的颜色更改UILabel的文本颜色。例如,当存在深色背景图像时,将UILabel文本颜色的颜色更改为白色,反之亦然。
答案 0 :(得分:1)
这是一种方法-这不是我的工作...我在https://gist.github.com/adamcichy/2d00c7a54009b4a9751ba513749c485e找到了它(将其重新发布在这里,因为将来链接可能会失败):
extension CGImage {
var isDark: Bool {
get {
guard let imageData = self.dataProvider?.data else { return false }
guard let ptr = CFDataGetBytePtr(imageData) else { return false }
let length = CFDataGetLength(imageData)
let threshold = Int(Double(self.width * self.height) * 0.45)
var darkPixels = 0
for i in stride(from: 0, to: length, by: 4) {
let r = ptr[i]
let g = ptr[i + 1]
let b = ptr[i + 2]
let luminance = (0.299 * Double(r) + 0.587 * Double(g) + 0.114 * Double(b))
if luminance < 150 {
darkPixels += 1
if darkPixels > threshold {
return true
}
}
}
return false
}
}
}
extension UIImage {
var isDark: Bool {
get {
return self.cgImage?.isDark ?? false
}
}
}
然后您可以使用(例如):
// default to false (meaning, the image is not dark)
let b = myImageView.image?.isDark ?? false
if b {
// use a light-color for textColor
} else {
// use a dark-color for textColor
}
虽然还不那么简单...您的图像可能有明暗区域,因此您只需要计算将在标签后面的图像区域。但这是一个很好的起点。
编辑:正如rmaddy所说,这可能无法为您提供所需的结果。图像(尤其是照片)的明暗像素/区域不同。例如,对于明亮的天空,您可能有一栋黑暗的建筑物---如果标签从建筑物开始并在天空结束,则检查边界矩形的“暗度”对您没有多大帮助。
一种替代方法是使用白色文字,并在文字后面加上深色,半透明的矩形(圆角,软边)。