|
BOOL AdjustDIBColor(HDIB hDib, int nColorModel, int v1, int v2, int v3)
{
BYTE r, g, b, c, m, y, k;
int dr, dg, db, dc, dm, dy;
double dh, ds, dv, dl, h, s, v, l;
if (hDib == NULL)
return FALSE;
BITMAPINFO *bmi = (BITMAPINFO *)GlobalLock(hDib);
if (! bmi)
return FALSE;
WaitCursorBegin();
switch (nColorModel)
{
case RGB_COLOR:
dr = v1;
dg = v2;
db = v3;
break;
case CMYK_COLOR:
dc = v1;
dm = v2;
dy = v3;
break;
case HSI_COLOR:
if (v1 < 0)
v1 += 360;
dh = v1;
ds = v2;
dv = v3;
break;
case HLS_COLOR:
if (v1 < 0)
v1 += 360;
dh = v1;
dl = v2/100.0;
ds = v3/100.0;
break;
}
// get color number
WORD wNumColors = DIBNumColors((LPBYTE)bmi);
if (wNumColors) // There is palette
{
WORD i;
switch (nColorModel)
{
case RGB_COLOR:
for (i=0; i
{
bmi->bmiColors.rgbRed = BOUND(bmi->bmiColors.rgbRed+dr, 0, 255);
bmi->bmiColors.rgbGreen = BOUND(bmi->bmiColors.rgbGreen+dg, 0, 255);
bmi->bmiColors.rgbBlue = BOUND(bmi->bmiColors.rgbBlue+db, 0, 255);
}
break;
case CMYK_COLOR:
for (i=0; i
{
r = bmi->bmiColors.rgbRed;
g = bmi->bmiColors.rgbGreen;
b = bmi->bmiColors.rgbBlue;
RGBtoCMYK(r, g, b, &c, &m, &y, &k);
c += dc;
m += dm;
y += dy;
CMYKtoRGB(c, m, y, k, &r, &g, &b);
bmi->bmiColors.rgbRed = r;
bmi->bmiColors.rgbGreen = g;
bmi->bmiColors.rgbBlue = b;
}
break;
case HSI_COLOR:
for (i=0; i
{
r = bmi->bmiColors.rgbRed;
g = bmi->bmiColors.rgbGreen;
b = bmi->bmiColors.rgbBlue;
RGBtoHSI(r, g, b, &h, &s, &v);
h += dh;
s += ds;
v += dv;
HSItoRGB(h, s, v, &r, &g, &b);
bmi->bmiColors.rgbRed = r;
bmi->bmiColors.rgbGreen = g;
bmi->bmiColors.rgbBlue = b;
}
break;
case HLS_COLOR:
for (i=0; i
{
r = bmi->bmiColors.rgbRed;
g = bmi->bmiColors.rgbGreen;
b = bmi->bmiColors.rgbBlue;
RGBtoHLS(r, g, b, &h, &l, &s);
if (h != UNDEFINED)
h = BOUND(h+dh, 0.0, 360.0);
l = BOUND(l+dl, 0.0, 1.0);
s = BOUND(s+ds, 0.0, 1.0);
HLStoRGB(h, l, s, &r, &g, &b);
bmi->bmiColors.rgbRed = r;
bmi->bmiColors.rgbGreen = g;
bmi->bmiColors.rgbBlue = b;
}
break;
}
}
else // No palette
{
// bits position
LPBITMAPINFOHEADER lpbi = (LPBITMAPINFOHEADER)bmi;
LPBYTE lpBits = (LPBYTE)lpbi + lpbi->biSize;
int nDelta = WIDTHBYTES(lpbi->biBitCount*lpbi->biWidth) - lpbi->biWidth*lpbi->biBitCount/8;
int nx, ny;
switch (nColorModel)
{
case RGB_COLOR:
for (ny=0; nybiHeight; ny++)
{
for (nx=0; nxbiWidth; nx++)
{
b = (BYTE)*(lpBits);
g = (BYTE)*(lpBits+1);
r = (BYTE)*(lpBits+2);
*lpBits++ = BOUND(b+db, 0, 255);
*lpBits++ = BOUND(g+dg, 0, 255);
*lpBits++ = BOUND(r+dr, 0, 255);
}
lpBits += nDelta;
}
break;
case CMYK_COLOR:
for (ny=0; nybiHeight; ny++)
{
for (nx=0; nxbiWidth; nx++)
{
b = (BYTE)*(lpBits);
g = (BYTE)*(lpBits+1);
r = (BYTE)*(lpBits+2);
RGBtoCMYK(r, g, b, &c, &m, &y, &k);
c += dc;
m += dm;
y += dy;
CMYKtoRGB(c, m, y, k, &r, &g, &b);
*lpBits++ = b;
*lpBits++ = g;
*lpBits++ = r;
}
lpBits += nDelta;
}
break;
case HSI_COLOR:
for (ny=0; nybiHeight; ny++)
{
for (nx=0; nxbiWidth; nx++)
{
b = (BYTE)*(lpBits);
g = (BYTE)*(lpBits+1);
r = (BYTE)*(lpBits+2);
RGBtoHSI(r, g, b, &h, &s, &v);
h += dh;
s += ds;
v += dv;
HSItoRGB(h, s, v, &r, &g, &b);
*lpBits++ = b;
*lpBits++ = g;
*lpBits++ = r;
}
lpBits += nDelta;
}
break;
case HLS_COLOR:
for (ny=0; nybiHeight; ny++)
{
for (nx=0; nxbiWidth; nx++)
{
b = (BYTE)*(lpBits);
g = (BYTE)*(lpBits+1);
r = (BYTE)*(lpBits+2);
RGBtoHLS(r, g, b, &h, &l, &s);
if (h != UNDEFINED)
h = BOUND(h+dh, 0.0, 360.0);
l = BOUND(l+dl, 0.0, 1.0);
s = BOUND(s+ds, 0.0, 1.0);
HLStoRGB(h, l, s, &r, &g, &b);
*lpBits++ = b;
*lpBits++ = g;
*lpBits++ = r;
}
lpBits += nDelta;
}
break;
}
}
GlobalUnlock(hDib);
WaitCursorEnd();
return TRUE;
}
BOOL AdjustDIBBrightness(HDIB hDib, int v)
{
if (hDib == NULL)
return FALSE;
BITMAPINFO *bmi = (BITMAPINFO *)GlobalLock(hDib);
if (! bmi)
return FALSE;
WaitCursorBegin();
// get color number
WORD wNumColors = DIBNumColors((LPBYTE)bmi);
if (wNumColors) // There is palette
{
for (WORD i=0; i
{
ChangeBrightness(v,
&(bmi->bmiColors.rgbRed),
&(bmi->bmiColors.rgbGreen),
&(bmi->bmiColors.rgbBlue));
}
}
else // No palette
{
// bits position
LPBITMAPINFOHEADER lpbi = (LPBITMAPINFOHEADER)bmi;
LPBYTE lpBits = (LPBYTE)lpbi + lpbi->biSize;
int nDelta = WIDTHBYTES(lpbi->biBitCount*lpbi->biWidth) - lpbi->biWidth*lpbi->biBitCount/8;
BYTE r, g, b;
for (int ny=0; nybiHeight; ny++)
{
for (int nx=0; nxbiWidth; nx++)
{
b = (BYTE)*(lpBits);
g = (BYTE)*(lpBits+1);
r = (BYTE)*(lpBits+2);
ChangeBrightness(v, &r, &g, &b);
*lpBits++ = b;
*lpBits++ = g;
*lpBits++ = r;
}
lpBits += nDelta;
}
}
GlobalUnlock(hDib);
WaitCursorEnd();
return TRUE;
}
BOOL AdjustDIBContrast(HDIB hDib, int v)
{
if (hDib == NULL)
return FALSE;
BITMAPINFO *bmi = (BITMAPINFO *)GlobalLock(hDib);
if (! bmi)
return FALSE;
WaitCursorBegin();
// get color number
WORD wNumColors = DIBNumColors((LPBYTE)bmi);
if (wNumColors) // There is palette
{
for (WORD i=0; i
{
ChangeContrast(v,
&(bmi->bmiColors.rgbRed),
&(bmi->bmiColors.rgbGreen),
&(bmi->bmiColors.rgbBlue));
}
}
else // No palette
{
// bits position
LPBITMAPINFOHEADER lpbi = (LPBITMAPINFOHEADER)bmi;
LPBYTE lpBits = (LPBYTE)lpbi + lpbi->biSize;
int nDelta = WIDTHBYTES(lpbi->biBitCount*lpbi->biWidth) - lpbi->biWidth*lpbi->biBitCount/8;
BYTE r, g, b;
for (int ny=0; nybiHeight; ny++)
{
for (int nx=0; nxbiWidth; nx++)
{
b = (BYTE)*(lpBits);
g = (BYTE)*(lpBits+1);
r = (BYTE)*(lpBits+2);
ChangeContrast(v, &r, &g, &b);
*lpBits++ = b;
*lpBits++ = g;
*lpBits++ = r;
}
lpBits += nDelta;
}
}
GlobalUnlock(hDib);
WaitCursorEnd();
return TRUE;
} |
|