/usr/src/castle-game-engine-4.1.1/images/images_ipl.inc is in castle-game-engine-src 4.1.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | {
Copyright 2003-2013 Michalis Kamburelis.
This file is part of "Castle Game Engine".
"Castle Game Engine" is free software; see the file COPYING.txt,
included in this distribution, for details about the copyright.
"Castle Game Engine" is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
----------------------------------------------------------------------------
}
function LoadIPL(Stream: TStream;
const AllowedImageClasses: array of TCastleImageClass): TCastleImage;
{ Implemented looking at iplab_read.m from
http://www.graphics.cornell.edu/online/box/data.html . }
(*
{ Take a number from 0..31 (1111 in binary) and map it to 0..255 range.
Parameter FiveBits is a Word, to safely multiply it in implementation. }
function FiveBitsToByte(fivebits: Word): byte;
begin
Result := fivebits*255 div 31;
end;
*)
const
TypeFlagUChar = 0;
TypeFlagInt16 = 1;
TypeFlagInt32 = 2;
TypeFlagFloat = 3;
TypeFlagUShort = 6;
var
IPLVersion: string;
IPLFormat: byte;
IPLTypeFlag: Word;
IPLWidth, IPLHeight: LongWord;
i, j: Integer;
IPLPixel: Word;
imgPixel: PVector3Byte;
begin
SetLength(IPLVersion, 4);
Stream.ReadBuffer(IPLVersion[1], Length(IPLVersion));
Stream.ReadBuffer(IPLFormat, SizeOf(IPLFormat));
Check(IPLFormat = 0, 'IPLab file format should be 0');
Stream.ReadBuffer(IPLTypeFlag, SizeOf(IPLTypeFlag));
Check((IPLTypeFlag = TypeFlagUShort), 'IPLab file typeflag not supported');
Stream.ReadBuffer(IPLWidth, SizeOf(IPLWidth));
Stream.ReadBuffer(IPLHeight, SizeOf(IPLHeight));
{ skip rest of the header }
Stream.Seek(2105, soFromCurrent);
result := TRGBImage.Create(IPLWidth, IPLHeight);
try
for j := IPLHeight-1 downto 0 do
for i := 0 to IPLWidth-1 do
begin
imgPixel := Result.PixelPtr(i, j);
Stream.ReadBuffer(IPLPixel, SizeOf(IPLPixel));
{imgPixel[0] := FiveBitsToByte((IPLPixel and $7C00) shr 10);
imgPixel[1] := FiveBitsToByte((IPLPixel and $03E0) shr 5);
imgPixel[2] := FiveBitsToByte(IPLPixel and $001F);}
imgPixel^[0] := IPLPixel shr 8;
imgPixel^[1] := imgPixel^[0];
imgPixel^[2] := imgPixel^[0];
end;
except Result.Free; raise end;
end;
|