我好心问你帮我解决这个问题:

有含DIB的数据和一个字节数组(data: PByte)DIBHeader:


  TDibHeader = record
    size: Cardinal;
    width: Integer;
    height: Integer;
    planes: Word;
    bits: Word;
    compression: Cardinal;
    image_size: Cardinal;
    x_res: Integer;
    y_res: Integer;
    n_colors: Cardinal;
    important_colors: Cardinal;
  end;

如何DIB转化为TBitmap同时保持CPU占用低?

我试图 http://files.codes -sources.com/fichier.aspx?id=43989&f=GdipApi.pas 没有成功。

我已经分配DIB到内存流:


  DibMemStream.Clear;
  DibMemStream.SetSize(header.image_size);
  MoveMemory(DibMemStream.Memory,DibBuffer,header.image_size);

我想应当有Bitmap.LoadFromMemoryStream(DibMemStream)之前DIB头写入某处。不知道在哪里。

任何想法,请?

谢谢!

有帮助吗?

解决方案

我已经使用了以下方案以在内存中的图像转换为TBitmap:

1)填充TBMPHeader结构

  TBMPHeader = packed record
    bmfHeader: TBitmapFileHeader;
    bmiHeader: TBitmapInfoHeader;
    bmiColors: {depends on image format, may be absent};
  end;

2)写入BMPHeader +图像数据的MemoryStream

这MemoryStream的使用TBitmap.LoadFromStream 3)负载TBitmap

您似乎有bmiHeader结构已经填补。添加bmfHeader和(或许)bmiColors。

下面是我用256色的灰度的内存图像转换为TBitmap代码(很多年前,对不起,所以没有详细说明):

procedure TksImage.CopyToBitmap(Bitmap: TBitmap);
var
  Stream: TStream;

begin
  Stream:= TMemoryStream.Create;
  try
    SaveToStream(Stream);
    Stream.Position:= 0;
    Bitmap.LoadFromStream(Stream);
  finally
    Stream.Free;
  end;
end;

procedure TksImage.SaveToStream(Stream: TStream);
type
  TBMPHeader = packed record
    bmfHeader: TBitmapFileHeader;
    bmiHeader: TBitmapInfoHeader;
    bmiColors: array[0..255] of TRGBQuad;
  end;

var
  BMPHeader: TBMPHeader;
  N: LongWord;
  I: Integer;

begin
  FillChar(BMPHeader, SizeOf(BMPHeader), 0);
  with BMPHeader.bmfHeader do begin
    bfType:= $4D42; {'BM'}
    bfOffBits:= SizeOf(BMPHeader);
    if FChannels = 4 then Dec(bfOffBits, SizeOf(BMPHeader.bmiColors));
    bfSize:= bfOffBits + LongWord(FImageSize);
  end;
  with BMPHeader.bmiHeader do begin
    biSize:= SizeOf(BMPHeader.bmiHeader);
    biWidth:= FWidth;
    biHeight:= FHeight;
    biPlanes:= 1;
    biBitCount:= 8 * FChannels;
    biCompression:= BI_RGB;
    biSizeImage:= FImageSize;
    {((((biWidth * biBitCount) + 31) and not 31) shr 3) * biHeight;}
  end;
  N:= 0;
  for I:= 0 to 255 do begin
    LongWord(bmpHeader.bmiColors[I]):= N;
    Inc(N, $010101);
  end;
  Stream.Write(BMPHeader, BMPHeader.bmfHeader.bfOffBits);
  Stream.Write(FImageData^, FImageSize);
end;

其他提示

它一直以来我所做的任何Delphi编码,我已经无法对此进行测试,但如果你能提供的句柄DIB,有一个功能很长一段时间 - hDIBToTBitmap1() - 这应该做的伎俩此链接:

http://www.efg2.com/Lab/Library /Delphi/Graphics/LeadToolsConversions.TXT

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top