You've already forked lazarus-ccr
aarre
applications
bindings
components
ZVDateTimeCtrls
aboutcomponent
acs
beepfp
callite
chelper
cmdline
cmdlinecfg
colorpalette
csvdocument
epiktimer
flashfiler
fpsound
fpspreadsheet
fractions
freetypepascal
geckoport
gradcontrols
iosdesigner
iphonelazext
jujiboutils
jvcllaz
kcontrols
lazautoupdate
lazbarcodes
lclextensions
longtimer
manualdock
mbColorLib
Demo
BAxisColorPicker.dcr
BAxisColorPicker.pas
BColorPicker.dcr
BColorPicker.pas
CColorPicker.dcr
CColorPicker.pas
CIEAColorPicker.dcr
CIEAColorPicker.pas
CIEBColorPicker.dcr
CIEBColorPicker.pas
CIELColorPicker.dcr
CIELColorPicker.pas
GAxisColorPicker.dcr
GAxisColorPicker.pas
GColorPicker.dcr
GColorPicker.pas
HColorPicker.dcr
HColorPicker.pas
HRingPicker.dcr
HRingPicker.pas
HSColorPicker.dcr
HSColorPicker.pas
HSLColorPicker.dcr
HSLColorPicker.pas
HSLRingPicker.dcr
HSLRingPicker.pas
HSVColorPicker.dcr
HSVColorPicker.pas
HTMLColors.pas
HexaColorPicker.dcr
HexaColorPicker.pas
KColorPicker.dcr
KColorPicker.pas
LColorPicker.dcr
LColorPicker.pas
MColorPicker.dcr
MColorPicker.pas
OfficeMoreColorsDialog.dfm
OfficeMoreColorsDialog.lfm
OfficeMoreColorsDialog.pas
PalUtils.pas
PickCursor.res
RAxisColorPicker.dcr
RAxisColorPicker.pas
RColorPicker.dcr
RColorPicker.pas
RGBCIEUtils.pas
RGBCMYKUtils.pas
RGBHSLUtils.pas
RGBHSVUtils.pas
Readme.rtf
SColorPicker.dcr
SColorPicker.pas
SLColorPicker.dcr
SLColorPicker.pas
SLHColorPicker.dcr
SLHColorPicker.pas
Scanlines.pas
ScreenWin.dfm
ScreenWin.lfm
ScreenWin.pas
SelPropUtils.pas
VColorPicker.dcr
VColorPicker.pas
XPLibIntegration.txt
YColorPicker.dcr
YColorPicker.pas
clean.bat
clear history.bat
mbBasicPicker.pas
mbColorLibD10.dpk
mbColorLibD5.dpk
mbColorLibD7.dpk
mbColorLibD9.dpk
mbColorList.dcr
mbColorList.pas
mbColorPalette.dcr
mbColorPalette.pas
mbColorPickerControl.pas
mbColorPreview.dcr
mbColorPreview.pas
mbColorTree.dcr
mbColorTree.pas
mbDeskPickerButton.dcr
mbDeskPickerButton.pas
mbOfficeColorDialog.dcr
mbOfficeColorDialog.pas
mbTrackBarPicker.pas
mbcolorliblaz.lpk
mbutils.pas
mxs.inc
mplayer
multithreadprocs
nvidia-widgets
onguard
orpheus
playsoundpackage
poweredby
powerpdf
rgbgraphics
richmemo
richview
rtfview
rx
scrolltext
smnetgradient
spktoolbar
svn
tdi
thtmlport
tparadoxdataset
tvplanit
virtualtreeview
virtualtreeview-new
xdev_toolkit
zlibar
examples
lclbindings
wst
173 lines
3.8 KiB
ObjectPascal
173 lines
3.8 KiB
ObjectPascal
![]() |
unit RGBHSVUtils;
|
||
|
|
||
|
{$IFDEF FPC}
|
||
|
{$MODE DELPHI}
|
||
|
{$ENDIF}
|
||
|
|
||
|
interface
|
||
|
|
||
|
uses
|
||
|
{$IFDEF FPC}
|
||
|
LCLIntf, LCLType,
|
||
|
{$ELSE}
|
||
|
Windows,
|
||
|
{$ENDIF}
|
||
|
SysUtils, Classes, Graphics, Math, Scanlines;
|
||
|
|
||
|
function RGBtoRGBTriple(R, G, B: byte): TRGBTriple;
|
||
|
function RGBtoRGBQuad(R, G, B: byte): TRGBQuad;
|
||
|
function RGBTripleToColor(Triple: TRGBTriple): TColor;
|
||
|
procedure RGBToHSV(R,G,B: integer; var H,S,V: integer);
|
||
|
function HSVtoRGBTriple(H, S, V: integer): TRGBTriple;
|
||
|
function HSVtoRGBQuad(H, S, V: integer): TRGBQuad;
|
||
|
function HSVtoColor(H, S, V: integer): TColor;
|
||
|
function GetHValue(Color: TColor): integer;
|
||
|
function GetVValue(Color: TColor): integer;
|
||
|
function GetSValue(Color: TColor): integer;
|
||
|
|
||
|
implementation
|
||
|
|
||
|
function RGBtoRGBTriple(R, G, B: byte): TRGBTriple;
|
||
|
begin
|
||
|
with Result do
|
||
|
begin
|
||
|
rgbtRed := R;
|
||
|
rgbtGreen := G;
|
||
|
rgbtBlue := B;
|
||
|
end
|
||
|
end;
|
||
|
|
||
|
function RGBtoRGBQuad(R, G, B: byte): TRGBQuad;
|
||
|
begin
|
||
|
with Result do
|
||
|
begin
|
||
|
rgbRed := R;
|
||
|
rgbGreen := G;
|
||
|
rgbBlue := B;
|
||
|
rgbReserved := 0;
|
||
|
end
|
||
|
end;
|
||
|
|
||
|
function RGBTripleToColor(Triple: TRGBTriple): TColor;
|
||
|
begin
|
||
|
Result := TColor(RGB(Triple.rgbtRed, Triple.rgbtGreen, Triple.rgbtBlue));
|
||
|
end;
|
||
|
|
||
|
procedure RGBToHSV(R, G, B: integer; var H, S, V: integer);
|
||
|
var
|
||
|
Delta, Min, H1, S1: real;
|
||
|
begin
|
||
|
h1 := h;
|
||
|
s1 := s;
|
||
|
Min := MinIntValue([R, G, B]);
|
||
|
V := MaxIntValue([R, G, B]);
|
||
|
Delta := V - Min;
|
||
|
if V = 0.0 then S1 := 0 else S1 := Delta / V;
|
||
|
if S1 = 0.0 then
|
||
|
H1 := 0
|
||
|
else
|
||
|
begin
|
||
|
if R = V then
|
||
|
H1 := 60.0 * (G - B) / Delta
|
||
|
else
|
||
|
if G = V then
|
||
|
H1 := 120.0 + 60.0 * (B - R) / Delta
|
||
|
else
|
||
|
if B = V then
|
||
|
H1 := 240.0 + 60.0 * (R - G) / Delta;
|
||
|
if H1 < 0.0 then H1 := H1 + 360.0;
|
||
|
end;
|
||
|
h := round(h1);
|
||
|
s := round(s1*255);
|
||
|
end;
|
||
|
|
||
|
function HSVtoRGBTriple(H, S, V: integer): TRGBTriple;
|
||
|
const
|
||
|
divisor: integer = 255*60;
|
||
|
var
|
||
|
f, hTemp, p, q, t, VS: integer;
|
||
|
begin
|
||
|
if H > 360 then H := H - 360;
|
||
|
if H < 0 then H := H + 360;
|
||
|
if s = 0 then
|
||
|
Result := RGBtoRGBTriple(V, V, V)
|
||
|
else
|
||
|
begin
|
||
|
if H = 360 then hTemp := 0 else hTemp := H;
|
||
|
f := hTemp mod 60;
|
||
|
hTemp := hTemp div 60;
|
||
|
VS := V*S;
|
||
|
p := V - VS div 255;
|
||
|
q := V - (VS*f) div divisor;
|
||
|
t := V - (VS*(60 - f)) div divisor;
|
||
|
case hTemp of
|
||
|
0: Result := RGBtoRGBTriple(V, t, p);
|
||
|
1: Result := RGBtoRGBTriple(q, V, p);
|
||
|
2: Result := RGBtoRGBTriple(p, V, t);
|
||
|
3: Result := RGBtoRGBTriple(p, q, V);
|
||
|
4: Result := RGBtoRGBTriple(t, p, V);
|
||
|
5: Result := RGBtoRGBTriple(V, p, q);
|
||
|
else Result := RGBtoRGBTriple(0,0,0)
|
||
|
end;
|
||
|
end;
|
||
|
end;
|
||
|
|
||
|
function HSVtoRGBQuad(H, S, V: integer): TRGBQuad;
|
||
|
const
|
||
|
divisor: integer = 255*60;
|
||
|
var
|
||
|
f, hTemp, p, q, t, VS: integer;
|
||
|
begin
|
||
|
if H > 360 then H := H - 360;
|
||
|
if H < 0 then H := H + 360;
|
||
|
if s = 0 then
|
||
|
Result := RGBtoRGBQuad(V, V, V)
|
||
|
else
|
||
|
begin
|
||
|
if H = 360 then hTemp := 0 else hTemp := H;
|
||
|
f := hTemp mod 60;
|
||
|
hTemp := hTemp div 60;
|
||
|
VS := V*S;
|
||
|
p := V - VS div 255;
|
||
|
q := V - (VS*f) div divisor;
|
||
|
t := V - (VS*(60 - f)) div divisor;
|
||
|
case hTemp of
|
||
|
0: Result := RGBtoRGBQuad(V, t, p);
|
||
|
1: Result := RGBtoRGBQuad(q, V, p);
|
||
|
2: Result := RGBtoRGBQuad(p, V, t);
|
||
|
3: Result := RGBtoRGBQuad(p, q, V);
|
||
|
4: Result := RGBtoRGBQuad(t, p, V);
|
||
|
5: Result := RGBtoRGBQuad(V, p, q);
|
||
|
else Result := RGBtoRGBQuad(0,0,0)
|
||
|
end;
|
||
|
end;
|
||
|
end;
|
||
|
|
||
|
function HSVtoColor(H, S, V: integer): TColor;
|
||
|
begin
|
||
|
Result := RGBTripleToColor(HSVtoRGBTriple(H, S, V));
|
||
|
end;
|
||
|
|
||
|
function GetHValue(Color: TColor): integer;
|
||
|
var
|
||
|
s, v: integer;
|
||
|
begin
|
||
|
RGBToHSV(GetRValue(Color), GetGValue(Color), GetBValue(Color), Result, s, v);
|
||
|
end;
|
||
|
|
||
|
function GetSValue(Color: TColor): integer;
|
||
|
var
|
||
|
h, v: integer;
|
||
|
begin
|
||
|
RGBToHSV(GetRValue(Color), GetGValue(Color), GetBValue(Color), h, Result, v);
|
||
|
end;
|
||
|
|
||
|
function GetVValue(Color: TColor): integer;
|
||
|
var
|
||
|
h, s: integer;
|
||
|
begin
|
||
|
RGBToHSV(GetRValue(Color), GetGValue(Color), GetBValue(Color), h, s, Result);
|
||
|
end;
|
||
|
|
||
|
end.
|