Blame toonz/sources/stdfx/hsvutil.cpp
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include "trop.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "hsvutil.h"
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
void OLDRGB2HSV(double r, double g, double b,
|
|
Toshihiro Shimizu |
890ddd |
double *h, double *s, double *v)
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
double max, min;
|
|
Toshihiro Shimizu |
890ddd |
double delta;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
12c444 |
max = std::max({r, g, b});
|
|
Shinya Kitaoka |
12c444 |
min = std::min({r, g, b});
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
*v = max;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
if (max != 0)
|
|
Toshihiro Shimizu |
890ddd |
*s = (max - min) / max;
|
|
Toshihiro Shimizu |
890ddd |
else
|
|
Toshihiro Shimizu |
890ddd |
*s = 0;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
if (*s == 0)
|
|
Toshihiro Shimizu |
890ddd |
*h = 0;
|
|
Toshihiro Shimizu |
890ddd |
else {
|
|
Toshihiro Shimizu |
890ddd |
delta = max - min;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
if (r == max)
|
|
Toshihiro Shimizu |
890ddd |
*h = (g - b) / delta;
|
|
Toshihiro Shimizu |
890ddd |
else if (g == max)
|
|
Toshihiro Shimizu |
890ddd |
*h = 2 + (b - r) / delta;
|
|
Toshihiro Shimizu |
890ddd |
else if (b == max)
|
|
Toshihiro Shimizu |
890ddd |
*h = 4 + (r - g) / delta;
|
|
Toshihiro Shimizu |
890ddd |
*h = *h * 60;
|
|
Toshihiro Shimizu |
890ddd |
if (*h < 0)
|
|
Toshihiro Shimizu |
890ddd |
*h += 360;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
void OLDHSV2RGB(double hue, double sat, double value,
|
|
Toshihiro Shimizu |
890ddd |
double *red, double *green, double *blue)
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
int i;
|
|
Toshihiro Shimizu |
890ddd |
double p, q, t, f;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
// if (hue > 360 || hue < 0)
|
|
Toshihiro Shimizu |
890ddd |
// hue=0;
|
|
Toshihiro Shimizu |
890ddd |
if (hue > 360)
|
|
Toshihiro Shimizu |
890ddd |
hue -= ((int)hue / 360) * 360;
|
|
Toshihiro Shimizu |
890ddd |
//hue-=360;
|
|
Toshihiro Shimizu |
890ddd |
if (hue < 0)
|
|
Toshihiro Shimizu |
890ddd |
hue += (1 - (int)hue / 360) * 360;
|
|
Toshihiro Shimizu |
890ddd |
//hue+=360;
|
|
Toshihiro Shimizu |
890ddd |
if (sat < 0)
|
|
Toshihiro Shimizu |
890ddd |
sat = 0;
|
|
Toshihiro Shimizu |
890ddd |
if (sat > 1)
|
|
Toshihiro Shimizu |
890ddd |
sat = 1;
|
|
Toshihiro Shimizu |
890ddd |
if (value < 0)
|
|
Toshihiro Shimizu |
890ddd |
value = 0;
|
|
Toshihiro Shimizu |
890ddd |
if (value > 1)
|
|
Toshihiro Shimizu |
890ddd |
value = 1;
|
|
Toshihiro Shimizu |
890ddd |
if (sat == 0) {
|
|
Toshihiro Shimizu |
890ddd |
*red = value;
|
|
Toshihiro Shimizu |
890ddd |
*green = value;
|
|
Toshihiro Shimizu |
890ddd |
*blue = value;
|
|
Toshihiro Shimizu |
890ddd |
} else {
|
|
Toshihiro Shimizu |
890ddd |
if (hue == 360)
|
|
Toshihiro Shimizu |
890ddd |
hue = 0;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
hue = hue / 60;
|
|
Toshihiro Shimizu |
890ddd |
i = (int)hue;
|
|
Toshihiro Shimizu |
890ddd |
f = hue - i;
|
|
Toshihiro Shimizu |
890ddd |
p = value * (1 - sat);
|
|
Toshihiro Shimizu |
890ddd |
q = value * (1 - (sat * f));
|
|
Toshihiro Shimizu |
890ddd |
t = value * (1 - (sat * (1 - f)));
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
switch (i) {
|
|
Shinya Kitaoka |
d4642c |
case 0:
|
|
Shinya Kitaoka |
d4642c |
*red = value;
|
|
Toshihiro Shimizu |
890ddd |
*green = t;
|
|
Toshihiro Shimizu |
890ddd |
*blue = p;
|
|
Shinya Kitaoka |
d4642c |
break;
|
|
Shinya Kitaoka |
d4642c |
case 1:
|
|
Shinya Kitaoka |
d4642c |
*red = q;
|
|
Toshihiro Shimizu |
890ddd |
*green = value;
|
|
Toshihiro Shimizu |
890ddd |
*blue = p;
|
|
Shinya Kitaoka |
d4642c |
break;
|
|
Shinya Kitaoka |
d4642c |
case 2:
|
|
Shinya Kitaoka |
d4642c |
*red = p;
|
|
Toshihiro Shimizu |
890ddd |
*green = value;
|
|
Toshihiro Shimizu |
890ddd |
*blue = t;
|
|
Shinya Kitaoka |
d4642c |
break;
|
|
Shinya Kitaoka |
d4642c |
case 3:
|
|
Shinya Kitaoka |
d4642c |
*red = p;
|
|
Toshihiro Shimizu |
890ddd |
*green = q;
|
|
Toshihiro Shimizu |
890ddd |
*blue = value;
|
|
Shinya Kitaoka |
d4642c |
break;
|
|
Shinya Kitaoka |
d4642c |
case 4:
|
|
Shinya Kitaoka |
d4642c |
*red = t;
|
|
Toshihiro Shimizu |
890ddd |
*green = p;
|
|
Toshihiro Shimizu |
890ddd |
*blue = value;
|
|
Shinya Kitaoka |
d4642c |
break;
|
|
Shinya Kitaoka |
d4642c |
case 5:
|
|
Shinya Kitaoka |
d4642c |
*red = value;
|
|
Toshihiro Shimizu |
890ddd |
*green = p;
|
|
Toshihiro Shimizu |
890ddd |
*blue = q;
|
|
Shinya Kitaoka |
d4642c |
break;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|