getxyz.pas

来自「下载来的一个看图软件的源代码」· PAS 代码 · 共 63 行

PAS
63
字号
program TestXYZ;
uses lcmsdll;


type
     TRGB8 = Packed record
                r, g, b : Byte
     END;

var

     InputProfile, OutputProfile : cmsHPROFILE;
     Transform: cmsHTRANSFORM;
     RGB8: TRGB8;
     XYZ: cmsCIEXYZ;

begin
     InputProfile   := cmsOpenProfileFromFile('profile.icm','r');
     OutputProfile  := cmsCreateXYZProfile();

     Transform := cmsCreateTransform(InputProfile,
                                           TYPE_RGB_8,
                                           OutputProfile,
                                           TYPE_XYZ_DBL,
                                           INTENT_ABSOLUTE_COLORIMETRIC, cmsFLAGS_NOTPRECALC);

     WriteLn('Enter RGB (0-255) or all 0 to end');
     REPEAT

        Write('R?'); ReadLn(RGB8.r);
        Write('G?'); ReadLn(RGB8.g);
        Write('B?'); ReadLn(RGB8.b);


        cmsDoTransform(Transform,
                        @RGB8,
                        @XYZ,
                        1);


        {Transport to radiance}

        XYZ.X := XYZ.X * 100.;
        XYZ.Y := XYZ.Y * 100.;
        XYZ.Z := XYZ.Z * 100.;


        WriteLn; WriteLn('XYZ (as viewed on D50 box)');

        Write('X='); WriteLn(XYZ.X:3:2);
        Write('Y='); WriteLn(XYZ.Y:3:2);
        Write('Z='); WriteLn(XYZ.Z:3:2);

     UNTIL ((RGB8.r = 0) and (RGB8.g = 0) and (RGB8.b = 0));


     cmsDeleteTransform(Transform);
     cmsCloseProfile(InputProfile);
     cmsCloseProfile(OutputProfile)

END.

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?