关于在数据库中存取JPG图像的问题
数据库是sql server 其中有几个字段是存取图形的。
存的代码如下
Var
BlobStream:TBlobStream;
JpegImage:TJpegImage;
begin
try
with query1 do
try
JpegImage:=TJpegImage.Create;
BlobStream:=TBlobStream.Create(TBlobField(FieldByName('photo')),bmWrite);
BlobStream.Position:=0;
JpegImage:=TJpegImage(image1.Picture.Graphic);
JpegImage.SaveToStream(BlobStream);
finally
if Not Assigned(BlobStream) then BlobStream.Free;
if Not Assigned(JpegImage) then JpegImage.Free;
end;
except
end;
end;
显示的时候
var
BS : TBlobStream;
JpegImage : TJpegImage;
begin
JpegImage := TJpegImage.Create;
BS := TBlobStream.Create(TBlobField(query1.FieldByName('Photo'),bmRead);
try
JpegImage.LoadFromStream(BS);
Image1.Picture.Assign(JpegImage);
现在的问题是 如果原来的图像是BMP转成jpg存起来的,那么就得用
B.loadFromStream(BS);
Image1.Picture.Assign(B); //B是TBitMap类型。
如果原图像是jpg 那么就用
JpegImage.LoadFromStream(BS);
Image1.Picture.Assign(JpegImage);
否则出错。
那么多种类型存储以后,源图像包括bmp和jpg,如何正确调用相应的代码显示。
还有什么更好的办法。