(C语言)将RGB转换为HSV和HSV的算法在两者的范围为0-255范围内
(C language) Algorithm to convert RGB to HSV and HSV to RGB in range 0-255 for both
我正在尝试使用此功能将HSV提高到RGB转换,但是没有使用float的问题……
HsvColor hsv;
unsigned char rgbMin, rgbMax;
rgbMin = rgb.r < rgb.g ? (rgb.r < rgb.b ? rgb.r : rgb.b) : (rgb.g < rgb.b ? rgb.g : rgb.b);
rgbMax = rgb.r > rgb.g ? (rgb.r > rgb.b ? rgb.r : rgb.b) : (rgb.g > rgb.b ? rgb.g : rgb.b);
hsv.v = rgbMax;
if (hsv.v == 0)
{
hsv.h = 0;
hsv.s = 0;
return hsv;
}
hsv.s = 255 * (long int)(rgbMax - rgbMin) / hsv.v;
if (hsv.s == 0)
{
hsv.h = 0;
return hsv;
}
if (rgbMax == rgb.r)
hsv.h = 0 + 43 * (rgb.g - rgb.b) / (rgbMax - rgbMin);
else if (rgbMax == rgb.g)
hsv.h = 85 + 43 * (rgb.b - rgb.r) / (rgbMax - rgbMin);
else
hsv.h = 171 + 43 * (rgb.r - rgb.g) / (rgbMax - rgbMin);
return hsv;
我的问题是我有(rgb.b-rgb.r)<1
,不使用float我的截断值(SO 0)和hsv.h
始终保持在85 ...
hsv.h = 85 43 *(rgb.b -rgb.r)/(rgbmax -rgbmin);
有人对此有想法吗?
精度为3位之后的3位数字,将操作数乘以1000,这样您将拥有1000*(rgb.b-rgb.r) < 1000
而不是(rgb.b-rgb.r) <1
,因此您不会截断与0的区别。确保R和B的类型足够宽以包含255*1000。
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- 错误:未在此范围内声明'reverse'
- 正在将指针转换为范围
- 使用std::transform将一个范围的元素添加到另一个范围中
- 在基于范围的for循环中使用结构化绑定声明
- 如何计算数据类型的范围,例如int
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 在C++中查找范围的长度
- 如何设置一个范围来提取我想要获得的信息
- 并行用于C++17中数组索引范围内的循环
- 为左值和右值的包装器实现C++范围
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 关于:C++中异常对象的范围:为什么我没有得到副本?
- 超出范围时使用对象
- 不计算一个范围内的完美数
- (C语言)将RGB转换为HSV和HSV的算法在两者的范围为0-255范围内
- HSV 中的高效范围,具有循环色调范围
- HSV和范围内方法无法正常工作