将RGB颜色更改为HSV swift
祝你今天愉快。我正在做RGB LED颜色改变应用程序。我正在用HSB做颜色选择。这些颜色具有色调、饱和度、亮度和alpha值。我保存这些值在数据库中。我正在与arduino一起阅读这些数据。但是我如何找出这些颜色值的颜色呢属于那么,我如何找到与我通过arduino选择的颜色相同的颜色呢将RGB颜色更改为HSV swift,swift,arduino,Swift,Arduino,祝你今天愉快。我正在做RGB LED颜色改变应用程序。我正在用HSB做颜色选择。这些颜色具有色调、饱和度、亮度和alpha值。我保存这些值在数据库中。我正在与arduino一起阅读这些数据。但是我如何找出这些颜色值的颜色呢属于那么,我如何找到与我通过arduino选择的颜色相同的颜色呢 import Foundation import UIKit // The view to edit HSB color components. public class EFHSBView: UIVi
import Foundation
import UIKit
// The view to edit HSB color components.
public class EFHSBView: UIView, EFColorView, UITextFieldDelegate {
let EFColorSampleViewHeight: CGFloat = 30.0
let EFViewMargin: CGFloat = 20.0
let EFColorWheelDimension: CGFloat = 200.0
private let colorWheel: EFColorWheelView = EFColorWheelView()
let brightnessView: EFColorComponentView = EFColorComponentView()
private let colorSample: UIView = UIView()
private var colorComponents: HSB = HSB(1, 1, 1, 1)
private var layoutConstraints: [NSLayoutConstraint] = []
weak public var delegate: EFColorViewDelegate?
public var isTouched: Bool {
if self.colorWheel.isTouched {
return true
}
if self.brightnessView.isTouched {
return true
}
return false
}
public var color: UIColor {
get {
return UIColor(
hue: colorComponents.hue,
saturation: colorComponents.saturation,
brightness: colorComponents.brightness,
alpha: colorComponents.alpha
)
}
set {
colorComponents = EFRGB2HSB(rgb: EFRGBColorComponents(color: newValue))
self.reloadData()
}
}
override init(frame: CGRect) {
super.init(frame: frame)
self.ef_baseInit()
}
required public init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
self.ef_baseInit()
}
func reloadData() {
colorSample.backgroundColor = self.color
colorSample.accessibilityValue = EFHexStringFromColor(color: self.color)
self.ef_reloadViewsWithColorComponents(colorComponents: colorComponents)
self.colorWheel.display(self.colorWheel.layer)
}
override public func updateConstraints() {
self.ef_updateConstraints()
super.updateConstraints()
}
// MARK:- Private methods
private func ef_baseInit() {
self.accessibilityLabel = "hsb_view"
colorSample.accessibilityLabel = "color_sample"
colorSample.layer.borderColor = UIColor.black.cgColor
colorSample.layer.borderWidth = 0.5
colorSample.translatesAutoresizingMaskIntoConstraints = false
self.addSubview(colorSample)
colorWheel.translatesAutoresizingMaskIntoConstraints = false
self.addSubview(colorWheel)
brightnessView.title = NSLocalizedString("Brightness", comment: "")
brightnessView.maximumValue = EFHSBColorComponentMaxValue
brightnessView.format = "%.2f"
brightnessView.translatesAutoresizingMaskIntoConstraints = false
brightnessView.setColors(colors: [UIColor.black, UIColor.white])
self.addSubview(brightnessView)
colorWheel.addTarget(
self, action: #selector(ef_colorDidChangeValue(sender:)), for: UIControl.Event.valueChanged
)
brightnessView.addTarget(
self, action: #selector(ef_brightnessDidChangeValue(sender:)), for: UIControl.Event.valueChanged
)
self.setNeedsUpdateConstraints()
}
private func ef_updateConstraints() {
// remove all constraints first
if !layoutConstraints.isEmpty {
self.removeConstraints(layoutConstraints)
}
layoutConstraints = UIUserInterfaceSizeClass.compact == self.traitCollection.verticalSizeClass
? self.ef_constraintsForCompactVerticalSizeClass()
: self.ef_constraintsForRegularVerticalSizeClass()
self.addConstraints(layoutConstraints)
}
private func ef_constraintsForRegularVerticalSizeClass() -> [NSLayoutConstraint] {
let metrics = [
"margin" : EFViewMargin,
"height" : EFColorSampleViewHeight,
"color_wheel_dimension" : EFColorWheelDimension
]
let views = [
"colorSample" : colorSample,
"colorWheel" : colorWheel,
"brightnessView" : brightnessView
]
var layoutConstraints: [NSLayoutConstraint] = []
let visualFormats = [
"H:|-margin-[colorSample]-margin-|",
"H:|-margin-[colorWheel(>=color_wheel_dimension)]-margin-|",
"H:|-margin-[brightnessView]-margin-|",
"V:|-margin-[colorSample(height)]-margin-[colorWheel]-margin-[brightnessView]-(>=margin@250)-|"
]
for visualFormat in visualFormats {
layoutConstraints.append(
contentsOf: NSLayoutConstraint.constraints(
withVisualFormat: visualFormat,
options: NSLayoutConstraint.FormatOptions(rawValue: 0),
metrics: metrics,
views: views
)
)
}
layoutConstraints.append(
NSLayoutConstraint(
item: colorWheel,
attribute: NSLayoutConstraint.Attribute.width,
relatedBy: NSLayoutConstraint.Relation.equal,
toItem: colorWheel,
attribute: NSLayoutConstraint.Attribute.height,
multiplier: 1,
constant: 0)
)
return layoutConstraints
}
private func ef_constraintsForCompactVerticalSizeClass() -> [NSLayoutConstraint] {
let metrics = [
"margin" : EFViewMargin,
"height" : EFColorSampleViewHeight,
"color_wheel_dimension" : EFColorWheelDimension
]
let views = [
"colorSample" : colorSample,
"colorWheel" : colorWheel,
"brightnessView" : brightnessView
]
var layoutConstraints: [NSLayoutConstraint] = []
let visualFormats = [
"H:|-margin-[colorSample]-margin-|",
"H:|-margin-[colorWheel(>=color_wheel_dimension)]-margin-[brightnessView]-(margin@500)-|",
"V:|-margin-[colorSample(height)]-margin-[colorWheel]-(margin@500)-|"
]
for visualFormat in visualFormats {
layoutConstraints.append(
contentsOf: NSLayoutConstraint.constraints(
withVisualFormat: visualFormat,
options: NSLayoutConstraint.FormatOptions(rawValue: 0),
metrics: metrics,
views: views
)
)
}
layoutConstraints.append(
NSLayoutConstraint(
item: colorWheel,
attribute: NSLayoutConstraint.Attribute.width,
relatedBy: NSLayoutConstraint.Relation.equal,
toItem: colorWheel,
attribute: NSLayoutConstraint.Attribute.height,
multiplier: 1,
constant: 0)
)
layoutConstraints.append(
NSLayoutConstraint(
item: brightnessView,
attribute: NSLayoutConstraint.Attribute.centerY,
relatedBy: NSLayoutConstraint.Relation.equal,
toItem: self,
attribute: NSLayoutConstraint.Attribute.centerY,
multiplier: 1,
constant: 0)
)
return layoutConstraints
}
private func ef_reloadViewsWithColorComponents(colorComponents: HSB) {
colorWheel.hue = colorComponents.hue
colorWheel.saturation = colorComponents.saturation
colorWheel.brightness = colorComponents.brightness
self.ef_updateSlidersWithColorComponents(colorComponents: colorComponents)
}
private func ef_updateSlidersWithColorComponents(colorComponents: HSB) {
brightnessView.value = colorComponents.brightness
}
@objc private func ef_colorDidChangeValue(sender: EFColorWheelView) {
colorComponents.hue = sender.hue
colorComponents.saturation = sender.saturation
self.delegate?.colorView(self, didChangeColor: self.color)
self.reloadData()
}
@objc private func ef_brightnessDidChangeValue(sender: EFColorComponentView) {
colorComponents.brightness = sender.value
self.colorWheel.brightness = sender.value
self.delegate?.colorView(self, didChangeColor: self.color)
self.reloadData()
}
}
色调饱和度值模型是一种广泛使用的颜色编码方法 色调是一个周期性参数,这就是为什么它以度(360度=全周期)为单位进行编码的原因。颜色的红色、绿色和蓝色分量沿色调轴周期性地变化,在120度时处于其较低值,然后在60度内上升到较高值,在较高值时保持120度,然后在接下来的60度时再次下降。该循环在360度后重复 红-绿和蓝分量相对移动120度,因此可以对它们之间的任何比例进行编码 在上面的图形中,您可以看到,对于每个H值,一个RGB组件处于上限值,另一个处于下限值,第三个在两者之间变化 值组件对RGB的上限值进行编码。即0%的值等于黑色(无论色调和饱和度值是什么),而100%的值等于最亮的颜色 HSV模型的饱和分量编码相对于V值的RGB分量上下值之间的差异。即,如果值为50%,饱和度为30%,则下限值为35%,上限值为50% 饱和度为零,则颜色为灰色,无论色调值是什么 因此,将HSV转换为RGB的代码可以如下所示:
float h=…,s=…,v=…;//输入值
浮子r,g,b;
浮动d=v*s;//上下值之差
浮点数l=v-d;//计算下限值
//下面的代码假定为0