亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pngimage.pas

?? Nadzor國外08年7月分先出遠控代碼
?? PAS
?? 第 1 頁 / 共 5 頁
字號:
      if Assigned(PLTE) then
        Insert(Result, PLTE.Index + 1)
      else if Assigned(IDAT) then
        Insert(Result, IDAT.Index)
      else
        Insert(Result, IHDR.Index + 1)
    end
    else {All other chunks}
      Insert(Result, IEND.Index);
  end {if}
end;

{Returns item from the list}
function TPNGList.GetItem(Index: Cardinal): TChunk;
begin
  Result := inherited GetItem(Index);
end;

{Returns first item from the list using the class from parameter}
function TPNGList.ItemFromClass(ChunkClass: TChunkClass): TChunk;
var
  i: Integer;
begin
  Result := nil; {Initial result}
  FOR i := 0 TO Count - 1 DO
    {Test if this item has the same class}
    if Item[i] is ChunkClass then
    begin
      {Returns this item and exit}
      Result := Item[i];
      break;
    end {if}
end;

{$IFNDEF UseDelphi}

  {TStream implementation}

  {Copies all from another stream}
  function TStream.CopyFrom(Source: TStream; Count: Cardinal): Cardinal;
  const
    MaxBytes = $f000;
  var
    Buffer:  PChar;
    BufSize, N: Cardinal;
  begin
    {If count is zero, copy everything from Source}
    if Count = 0 then
    begin
      Source.Seek(0, soFromBeginning);
      Count := Source.Size;
    end;

    Result := Count; {Returns the number of bytes readed}
    {Allocates memory}
    if Count > MaxBytes then BufSize := MaxBytes else BufSize := Count;
    GetMem(Buffer, BufSize);

    {Copy memory}
    while Count > 0 do
    begin
      if Count > BufSize then N := BufSize else N := Count;
      Source.Read(Buffer^, N);
      Write(Buffer^, N);
      dec(Count, N);
    end;

    {Deallocates memory}
    FreeMem(Buffer, BufSize);
  end;

{Set current stream position}
procedure TStream.SetPosition(const Value: Longint);
begin
  Seek(0, soFromBeginning);
end;

{Returns position}
function TStream.GetPosition: Longint;
begin
  Result := Seek(0, soFromCurrent);
end;

  {Returns stream size}
function TStream.GetSize: Longint;
  var
    Pos: Cardinal;
  begin
    Pos := Seek(0, soFromCurrent);
    Result := Seek(0, soFromEnd);
    Seek(Pos, soFromCurrent);
  end;

  {TFileStream implementation}

  {Filestream object being created}
  constructor TFileStream.Create(Filename: String; Mode: TFileStreamModeSet);
    {Makes file mode}
    function OpenMode: DWORD;
    begin
      Result := 0;
      if fsmRead in Mode then Result := GENERIC_READ;
      if (fsmWrite in Mode) or (fsmCreate in Mode) then
        Result := Result OR GENERIC_WRITE;
    end;
  const
    IsCreate: Array[Boolean] of Integer = (OPEN_ALWAYS, CREATE_ALWAYS);
  begin
    {Call ancestor}
    inherited Create;

    {Create handle}
    fHandle := CreateFile(PChar(Filename), OpenMode, FILE_SHARE_READ or
      FILE_SHARE_WRITE, nil, IsCreate[fsmCreate in Mode], 0, 0);
    {Store mode}
    FileMode := Mode;
  end;

  {Filestream object being destroyed}
  destructor TFileStream.Destroy;
  begin
    {Terminates file and close}
    if FileMode = [fsmWrite] then
      SetEndOfFile(fHandle);
    CloseHandle(fHandle);

    {Call ancestor}
    inherited Destroy;
  end;

  {Writes data to the file}
  function TFileStream.Write(const Buffer; Count: Longint): Cardinal;
  begin
    if not WriteFile(fHandle, Buffer, Count, Result, nil) then
      Result := 0;
  end;

  {Reads data from the file}
  function TFileStream.Read(var Buffer; Count: Longint): Cardinal;
  begin
    if not ReadFile(fHandle, Buffer, Count, Result, nil) then
      Result := 0;
  end;

  {Seeks the file position}
  function TFileStream.Seek(Offset: Integer; Origin: Word): Longint;
  begin
    Result := SetFilePointer(fHandle, Offset, nil, Origin);
  end;

  {Sets the size of the file}
  procedure TFileStream.SetSize(const Value: Longint);
  begin
    Seek(Value, soFromBeginning);
    SetEndOfFile(fHandle);
  end;

  {TResourceStream implementation}

  {Creates the resource stream}
  constructor TResourceStream.Create(Instance: HInst; const ResName: String;
    ResType: PChar);
  var
    ResID: HRSRC;
    ResGlobal: HGlobal;
  begin
    {Obtains the resource ID}
    ResID := FindResource(hInstance, PChar(ResName), RT_RCDATA);
    if ResID = 0 then raise EPNGError.Create('');
    {Obtains memory and size}
    ResGlobal := LoadResource(hInstance, ResID);
    Size := SizeOfResource(hInstance, ResID);
    Memory := LockResource(ResGlobal);
    if (ResGlobal = 0) or (Memory = nil) then EPNGError.Create('');
  end;


  {Setting resource stream size is not supported}
  procedure TResourceStream.SetSize(const Value: Integer);
  begin
  end;

  {Writing into a resource stream is not supported}
  function TResourceStream.Write(const Buffer; Count: Integer): Cardinal;
  begin
    Result := 0;
  end;

  {Reads data from the stream}
  function TResourceStream.Read(var Buffer; Count: Integer): Cardinal;
  begin
    //Returns data
    CopyMemory(@Buffer, Ptr(Longint(Memory) + Position), Count);
    //Update position
    inc(Position, Count);
    //Returns
    Result := Count;
  end;

  {Seeks data}
  function TResourceStream.Seek(Offset: Integer; Origin: Word): Longint;
  begin
    {Move depending on the origin}
    case Origin of
      soFromBeginning: Position := Offset;
      soFromCurrent: inc(Position, Offset);
      soFromEnd: Position := Size + Offset;
    end;

    {Returns the current position}
    Result := Position;
  end;

{$ENDIF}

{TChunk implementation}

{Resizes the data}
procedure TChunk.ResizeData(const NewSize: Cardinal);
begin
  fDataSize := NewSize;
  ReallocMem(fData, NewSize + 1);
end;

{Returns index from list}
function TChunk.GetIndex: Integer;
var
  i: Integer;
begin
  Result := -1; {Avoiding warnings}
  {Searches in the list}
  FOR i := 0 TO Owner.Chunks.Count - 1 DO
    if Owner.Chunks.Item[i] = Self then
    begin
      {Found match}
      Result := i;
      exit;
    end {for i}
end;

{Returns pointer to the TChunkIHDR}
function TChunk.GetHeader: TChunkIHDR;
begin
  Result := Owner.Chunks.Item[0] as TChunkIHDR;
end;

{Assigns from another TChunk}
procedure TChunk.Assign(Source: TChunk);
begin
  {Copy properties}
  fName := Source.fName;
  {Set data size and realloc}
  ResizeData(Source.fDataSize);

  {Copy data (if there's any)}
  if fDataSize > 0 then CopyMemory(fData, Source.fData, fDataSize);
end;

{Chunk being created}
constructor TChunk.Create(Owner: TPngObject);
var
  ChunkName: String;
begin
  {Ancestor create}
  inherited Create;

  {If it's a registered class, set the chunk name based on the class}
  {name. For instance, if the class name is TChunkgAMA, the GAMA part}
  {will become the chunk name}
  ChunkName := Copy(ClassName, Length('TChunk') + 1, Length(ClassName));
  if Length(ChunkName) = 4 then CopyMemory(@fName[0], @ChunkName[1], 4);

  {Initialize data holder}
  GetMem(fData, 1);
  fDataSize := 0;
  {Record owner}
  fOwner := Owner;
end;

{Chunk being destroyed}
destructor TChunk.Destroy;
begin
  {Free data holder}
  FreeMem(fData, fDataSize + 1);
  {Let ancestor destroy}
  inherited Destroy;
end;

{Returns the chunk name 1}
function TChunk.GetChunkName: String;
begin
  Result := fName
end;

{Returns the chunk name 2}
class function TChunk.GetName: String;
begin
  {For avoid writing GetName for each TChunk descendent, by default for}
  {classes which don't declare GetName, it will look for the class name}
  {to extract the chunk kind. Example, if the class name is TChunkIEND }
  {this method extracts and returns IEND}
  Result := Copy(ClassName, Length('TChunk') + 1, Length(ClassName));
end;

{Saves the chunk to the stream}
function TChunk.SaveToStream(Stream: TStream): Boolean;
var
  ChunkSize, ChunkCRC: Cardinal;
begin
  {First, write the size for the following data in the chunk}
  ChunkSize := ByteSwap(DataSize);
  Stream.Write(ChunkSize, 4);
  {The chunk name}
  Stream.Write(fName, 4);
  {If there is data for the chunk, write it}
  if DataSize > 0 then Stream.Write(Data^, DataSize);
  {Calculates and write CRC}
  ChunkCRC := update_crc($ffffffff, @fName[0], 4);
  ChunkCRC := Byteswap(update_crc(ChunkCRC, Data, DataSize) xor $ffffffff);
  Stream.Write(ChunkCRC, 4);

  {Returns that everything went ok}
  Result := TRUE;
end;


{Loads the chunk from a stream}
function TChunk.LoadFromStream(Stream: TStream; const ChunkName: TChunkName;
  Size: Integer): Boolean;
var
  CheckCRC: Cardinal;
  {$IFDEF CheckCRC}RightCRC: Cardinal;{$ENDIF}
begin
  {Copies data from source}
  ResizeData(Size);
  if Size > 0 then Stream.Read(fData^, Size);
  {Reads CRC}
  Stream.Read(CheckCRC, 4);
  CheckCrc := ByteSwap(CheckCRC);

  {Check if crc readed is valid}
  {$IFDEF CheckCRC}
    RightCRC := update_crc($ffffffff, @ChunkName[0], 4);
    RightCRC := update_crc(RightCRC, fData, Size) xor $ffffffff;
    Result := RightCRC = CheckCrc;

    {Handle CRC error}
    if not Result then
    begin
      {In case it coult not load chunk}
      Owner.RaiseError(EPngInvalidCRC, EPngInvalidCRCText);
      exit;
    end
  {$ELSE}Result := TRUE; {$ENDIF}

end;

{TChunktIME implementation}

{Chunk being loaded from a stream}
function TChunktIME.LoadFromStream(Stream: TStream;
  const ChunkName: TChunkName; Size: Integer): Boolean;
begin
  {Let ancestor load the data}
  Result := inherited LoadFromStream(Stream, ChunkName, Size);
  if not Result or (Size <> 7) then exit; {Size must be 7}

  {Reads data}
  fYear := pWord(Data)^;
  fMonth := pByte(Longint(Data) + 2)^;
  fDay := pByte(Longint(Data) + 3)^;
  fHour := pByte(Longint(Data) + 4)^;
  fMinute := pByte(Longint(Data) + 5)^;
  fSecond := pByte(Longint(Data) + 6)^;
end;

{Saving the chunk to a stream}
function TChunktIME.SaveToStream(Stream: TStream): Boolean;
begin
  {Update data}
  ResizeData(7);  {Make sure the size is 7}
  pWord(Data)^ := Year;
  pByte(Longint(Data) + 2)^ := Month;
  pByte(Longint(Data) + 3)^ := Day;
  pByte(Longint(Data) + 4)^ := Hour;
  pByte(Longint(Data) + 5)^ := Minute;
  pByte(Longint(Data) + 6)^ := Second;

  {Let inherited save data}
  Result := inherited SaveToStream(Stream);
end;

{TChunktEXt implementation}

{Assigns from another text chunk}
procedure TChunktEXt.Assign(Source: TChunk);
begin
  fKeyword := TChunktEXt(Source).fKeyword;
  fText := TChunktEXt(Source).fText;
end;

{Loading the chunk from a stream}
function TChunktEXt.LoadFromStream(Stream: TStream;
  const ChunkName: TChunkName; Size: Integer): Boolean;
begin
  {Load data from stream and validate}
  Result := inherited LoadFromStream(Stream, ChunkName, Size);
  if not Result or (Size < 3) then exit;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲妇女屁股眼交7| 亚洲在线成人精品| 欧美四级电影网| 韩国av一区二区三区| 亚洲国产精品一区二区www| 久久久亚洲国产美女国产盗摄| 91免费视频大全| 国产一区二区三区免费| 日本人妖一区二区| 一区二区三区四区国产精品| 久久久一区二区| 日韩午夜小视频| 在线视频观看一区| av激情综合网| 国产91精品在线观看| 精品一区二区三区视频| 亚洲国产精品综合小说图片区| 日韩一区日韩二区| 久久久九九九九| 欧美va亚洲va| 8v天堂国产在线一区二区| 色婷婷综合久久久中文字幕| 成人动漫一区二区三区| 国产在线播放一区三区四| 奇米影视7777精品一区二区| 亚洲大片精品永久免费| 一区二区久久久久久| 国产精品嫩草久久久久| 国产精品久久久久久户外露出| 久久众筹精品私拍模特| 欧美电影精品一区二区| 日韩一区二区三免费高清| 在线播放中文字幕一区| 精品视频免费在线| 欧美日韩小视频| 欧美日韩视频第一区| 成人综合婷婷国产精品久久免费| 国产美女一区二区| 国产成人综合亚洲网站| 国产成人精品亚洲日本在线桃色| 国产乱国产乱300精品| 国产激情精品久久久第一区二区| 国产在线不卡一卡二卡三卡四卡| 国产经典欧美精品| 99久久亚洲一区二区三区青草| 波多野结衣中文字幕一区 | 色素色在线综合| 91老司机福利 在线| 91精品1区2区| 欧美日韩中文国产| 日韩一区二区三区视频| 26uuu亚洲综合色欧美| 国产目拍亚洲精品99久久精品| 国产精品嫩草影院com| 亚洲另类春色校园小说| 日日夜夜精品视频天天综合网| 免费观看成人鲁鲁鲁鲁鲁视频| 久久99精品国产麻豆不卡| 国产麻豆精品视频| 99精品视频中文字幕| 欧美日韩国产大片| 337p粉嫩大胆噜噜噜噜噜91av| 国产精品毛片大码女人| 一二三四区精品视频| 男人的j进女人的j一区| 国产毛片一区二区| 在线免费av一区| 精品久久久久久久久久久久久久久久久 | 久久综合丝袜日本网| 国产精品国产a| 三级一区在线视频先锋 | 亚洲精品中文字幕乱码三区| 亚洲成人午夜电影| 韩国av一区二区三区| 91麻豆精品在线观看| 欧美一区二区三区四区五区| 国产日韩欧美电影| 亚洲国产美女搞黄色| 国产乱色国产精品免费视频| 在线中文字幕不卡| 欧美精品一区二区三区久久久| 中文字幕中文字幕在线一区| 日本vs亚洲vs韩国一区三区二区 | 日本伊人色综合网| 粉嫩av亚洲一区二区图片| 日本韩国欧美一区| 精品免费国产二区三区| 亚洲综合色婷婷| 国产精品一区二区三区网站| 欧美一a一片一级一片| 国产三级精品视频| 婷婷久久综合九色综合绿巨人 | 欧洲av一区二区嗯嗯嗯啊| 日韩一区二区免费电影| 亚洲人成影院在线观看| 精品在线你懂的| 欧美日韩色一区| 亚洲色欲色欲www| 久久精品国产澳门| 欧美性做爰猛烈叫床潮| 国产精品毛片大码女人| 国内精品免费**视频| 欧美蜜桃一区二区三区| 日韩理论片中文av| 国产成人高清在线| 欧美精品一区二区三区蜜桃| 水蜜桃久久夜色精品一区的特点| 91麻豆免费看片| 国产日韩欧美精品电影三级在线 | 成人精品gif动图一区| 日韩美一区二区三区| 午夜精品一区在线观看| 在线视频欧美精品| 亚洲人亚洲人成电影网站色| 国产一区在线观看视频| 欧美大片国产精品| 五月激情综合色| 欧美色网站导航| 亚洲免费观看在线视频| 成人黄动漫网站免费app| 久久久亚洲精品石原莉奈| 美国十次综合导航| 欧美一区二区免费观在线| 天天色天天操综合| 欧美日高清视频| 天天综合天天综合色| 在线成人av影院| 五月天婷婷综合| 欧美一区二区三区日韩视频| 视频一区视频二区在线观看| 欧美久久婷婷综合色| 首页国产欧美日韩丝袜| 欧美日本韩国一区二区三区视频| 亚洲综合免费观看高清完整版| 91国产丝袜在线播放| 一级精品视频在线观看宜春院| 欧洲一区在线电影| 亚洲aaa精品| 日韩精品一区二区三区视频 | 欧美国产精品v| 成人av网站在线观看| 中文字幕一区在线观看视频| 91网站在线观看视频| 亚洲伦理在线精品| 欧美主播一区二区三区美女| 亚洲第一精品在线| 日韩欧美国产一区二区在线播放| 韩国欧美一区二区| 欧美精彩视频一区二区三区| 91在线视频免费91| 亚洲国产美国国产综合一区二区| 91精品婷婷国产综合久久竹菊| 午夜私人影院久久久久| 欧美大白屁股肥臀xxxxxx| 国产乱子伦一区二区三区国色天香| 欧美精品一区二| 波多野结衣中文字幕一区 | 国产乱码精品一品二品| 国产欧美在线观看一区| 99国内精品久久| 五月天久久比比资源色| 久久女同精品一区二区| 色综合久久中文字幕综合网| 日韩—二三区免费观看av| 精品va天堂亚洲国产| 99久久婷婷国产综合精品 | 午夜国产精品影院在线观看| 日韩欧美在线观看一区二区三区| 国产成人精品一区二| 一区二区三区精品在线| 日韩欧美中文一区| aaa欧美大片| 蜜臀久久99精品久久久久久9| 欧美国产日韩a欧美在线观看| 91成人看片片| 国产成人日日夜夜| 午夜精品久久一牛影视| 国产区在线观看成人精品| 欧美日韩视频在线观看一区二区三区| 狠狠色丁香久久婷婷综合丁香| 亚洲伦在线观看| 欧美精品一区二区三区蜜桃视频| 色婷婷精品大在线视频| 国产精品一区二区免费不卡| 亚洲一二三四区不卡| 国产欧美日韩在线看| 欧美猛男gaygay网站| 成人久久18免费网站麻豆| 美女视频黄 久久| 亚洲色图在线视频| 久久综合色婷婷| 欧美精品第1页| 91丨九色porny丨蝌蚪| 国产精品综合一区二区三区| 婷婷国产v国产偷v亚洲高清| 亚洲色图视频免费播放| 国产亚洲欧美在线| 欧美一区二区女人| 欧美三片在线视频观看| 色综合视频在线观看|