-
Notifications
You must be signed in to change notification settings - Fork 18
/
color.c
129 lines (118 loc) · 1.98 KB
/
color.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
#include "color.h"
hsv rgb2hsv(rgb in)
{
hsv out;
double min, max, delta;
min = in.r < in.g ? in.r : in.g;
min = min < in.b ? min : in.b;
max = in.r > in.g ? in.r : in.g;
max = max > in.b ? max : in.b;
out.v = max;
delta = max - min;
if(max > 0.0)
{
out.s = (delta / max);
}
else
{
out.s = 0.0;
out.h = 0.0; /* NaN */
return out;
}
if(in.r == max)
{
out.h = (in.g - in.b) / delta;
}
else if(in.g == max)
{
out.h = 2.0 + (in.b - in.r) / delta;
}
else
{
out.h = 4.0 + (in.r - in.g) / delta;
}
out.h *= 60.0;
if(out.h < 0.0)
{
out.h += 360.0;
}
return out;
}
rgb hsv2rgb(hsv in)
{
double p, q, t, ff;
long i;
rgb out;
if(in.s <= 0.0)
{
out.r = in.v;
out.g = in.v;
out.b = in.v;
return out;
}
if(in.s > 1.0)
{
in.s = 1.0;
}
while(in.h >= 360.0)
{
in.h -= 360.0;
}
while(in.h < 0.0)
{
in.h += 360.0;
}
in.h /= 60.0;
i = (long)in.h;
ff = in.h - i;
p = in.v * (1.0 - in.s);
q = in.v * (1.0 - (in.s * ff));
t = in.v * (1.0 - (in.s * (1.0 - ff)));
switch(i)
{
case 0:
{
out.r = in.v;
out.g = t;
out.b = p;
break;
}
case 1:
{
out.r = q;
out.g = in.v;
out.b = p;
break;
}
case 2:
{
out.r = p;
out.g = in.v;
out.b = t;
break;
}
case 3:
{
out.r = p;
out.g = q;
out.b = in.v;
break;
}
case 4:
{
out.r = t;
out.g = p;
out.b = in.v;
break;
}
case 5:
default:
{
out.r = in.v;
out.g = p;
out.b = q;
break;
}
}
return out;
}