/******************************************************************************
* 下面两个函数实现rgb和hsv的互相转换
* r,g,b 的值在 0 到 1 之间
* h = [0,360], s = [0,1], v = [0,1]
* if s == 0, then h = -1 (undefined)
*****************************************************************************/
void RGBtoHSV( float r, float g, float b, float *h, float *s, float *v )
{
float min, max, delta;
min = MIN( r, g, b );
max = MAX( r, g, b );
*v = max;
delta = max - min;
if( max != 0 )
*s = delta / max;
else
{
// r = g = b = 0
// s = 0, v 未定义
*s = 0;
*h = -1;
return;
}
if( r == max )
*h = ( g - b ) / delta; // 在 yellow & magenta 之间
else if( g == max )
*h = 2 + ( b - r ) / delta; // 在 cyan & yellow 之间
else
*h = 4 + ( r - g ) / delta; // 在 magenta & cyan 之间
*h *= 60; // degrees
if( *h < 0 )
*h += 360;
}
void HSVtoRGB( float *r, float *g, float *b, float h, float s, float v )
{
int i;
float f, p, q, t;
if( s == 0 )
{
// 灰度
*r = *g = *b = v;
return;
}
h /= 60; // 扇区 0 到 5
i = floor( h );
f = h - i;
p = v * ( 1 - s );
q = v * ( 1 - s * f );
t = v * ( 1 - s * ( 1 - f ) );
switch( i )
{
case 0:
*r = v;
*g = t;
*b = p;
break;
case 1:
*r = q;
*g = v;
*b = p;
break;
case 2
*r = p;
*g = v;
*b = t;
break;
case 3:
*r = p;
*g = q;
*b = v;
break;
case 4:
*r = t;
*g = p;
*b = v;
break;
default:
*r = v;
*g = p;
*b = q;
break;
}
}
rgb-hsv.rar_HSV _HSV TO RGB C_RGB HSV_RGB to HSV_rgb
版权申诉
133 浏览量
2022-09-23
07:34:27
上传
评论
收藏 1020B RAR 举报
寒泊
- 粉丝: 74
- 资源: 1万+
最新资源
- pta题库答案c语言之树结构2ListLeaves.zip
- pta题库答案c语言之树结构1树的同构.zip
- 基于C++实现民航飞行与地图简易管理系统可执行程序+说明+详细注释.zip
- pta题库答案c语言之复杂度1最大子列和问题.zip
- 三维装箱问题(Three-Dimensional Bin Packing Problem,3D-BPP)是一个经典的组合优化问题
- 以下是一些关于Linux线程同步的基本概念和方法.txt
- 以下是一个简化的示例,它使用pygame库来模拟烟花动画的框架.txt
- Linux线程同步机制深度解析与实用指南.zip
- PTA题库C语言解题策略与实战.rar
- SVPWM控制技术的simulink建模与仿真【包括simulink模型,参考文献,操作步骤】
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈