일반적으로 Assets에 고정된 색상을 등록하고 사용하지만 가끔은 서버에서 받은 hex값을 사용하여 색상을 표현해야 하는 경우가 있다.
역시 일반적인 방법으로 Color를 Extension 하여 새로운 이니셜라이저를 추가해준다.
extension Color {
init(hex: String) {
let hex = hex.trimmingCharacters(in: CharacterSet.alphanumerics.inverted)
var int: UInt64 = 0
Scanner(string: hex).scanHexInt64(&int)
let a, r, g, b: UInt64
switch hex.count {
case 3: // RGB (12-bit)
(a, r, g, b) = (255, (int >> 8) * 17, (int >> 4 & 0xF) * 17, (int & 0xF) * 17)
case 6: // RGB (24-bit)
(a, r, g, b) = (255, int >> 16, int >> 8 & 0xFF, int & 0xFF)
case 8: // ARGB (32-bit)
(a, r, g, b) = (int >> 24, int >> 16 & 0xFF, int >> 8 & 0xFF, int & 0xFF)
default:
(a, r, g, b) = (1, 1, 1, 0)
}
self.init(
.sRGB,
red: Double(r) / 255,
green: Double(g) / 255,
blue: Double(b) / 255,
opacity: Double(a) / 255
)
}
}
출처: https://stackoverflow.com/questions/56874133/use-hex-color-in-swiftui
반응형
'ios > swiftUI' 카테고리의 다른 글
SwiftUI - ConfirmationDialog 알아보기, ActionSheet Deprecated (0) | 2022.07.26 |
---|---|
SwiftUI - Preview를 유용하게 사용하는법, previewLayout, 가로모드 Preview (0) | 2022.07.02 |
SwiftUI - 탭하여 키보드 숨기기 (0) | 2022.07.01 |
SwiftUI에서 UIKit의 Alert 사용하기 (0) | 2022.05.10 |
SwiftUI에서 UIkit, StoryBoard 사용하기 (0) | 2022.02.04 |