为何不能存入扩展名为.JPG格式的图片?

cjs5210 2004-09-13 02:01:09
数据库使用的是 sqlserver2000
图片字段类型为 image

如果存入的是.bmp格式的就没有问题,如果是.jpg格式的就会出现以下错误,请各位大哥指教!
procedure TForm1.Button1Click(Sender: TObject);
var
strm:tmemorystream;
ext:string;

JPEGImage:TJPEGImage;
begin
if image1.picture.Graphic <> nil then //避免image1中无图像保存出错
begin
ext:=extractfileext(openpicturedialog1.FileName ); //取出文件的扩展名
strm := tmemorystream.Create ;
try
image1.Picture.Graphic.SaveToStream(strm);
adoquery1.Append;
strm.Position :=0;
tblobfield(adoquery1.FieldByName('image')).LoadFromStream(strm);//执行到此处就出现“Bitmap images is not valid”的错误
adoquery1.Post ;
finally
strm.Free ;
end;
end;
end;
...全文
325 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
railgunman 2004-09-17
  • 打赏
  • 举报
回复
帮你up
  • 打赏
  • 举报
回复
加一个字段标识文件类型也可以,以前我使用的是TRY语句嵌套的方法来显示bmp,jpeg文件,这样可以免去一个字段的空间大小。建议楼主试试,存入无限制,取出时使用try finall进行嵌套显示流格式不同的图像。
vipxch 2004-09-14
  • 打赏
  • 举报
回复
同意 RamjetZhang(万花从中一点红,玉树临风王小桃是也) 思路,把我实现的过程大概说一下希望能给你一点启发,不对之处请各位指正;
数据库使用sql2000,我用image控件显示数据库中的jpeg图象,jpeg格式图象用dbimage无法显示,具体代码忘记了,主要就是在表中有个字段来区图象格式(bmp或者jpeg),在保存的时候久区分开来,从数据库中根据图象格式不同用不同的类来存储(bmp,用TPicture,jepg的用TJPEGImage)并显示在Timage中即可,大概思路是这样!!!
天行归来 2004-09-14
  • 打赏
  • 举报
回复
我的那种方法和文件类型是无关的,只是把文件当成流存在数据库中。
如果保证是bmp,用不着用这些方法。直接用dbimage就可以解决。
  • 打赏
  • 举报
回复
您是不是要用 TDBImage 顯示 jpeg?
是的話改這樣子的方式試試:

var
jpg: TJpegImage;
bmp: TBitmap;
begin
if OpenPictureDialog1.Execute then
begin
jpg := TJpegImage.Create;
try
jpg.LoadFromFile(OpenPictureDialog1.FileName);
bmp := TBitmap.Create;
try
bmp.Width := jpg.Width;
bmp.Height := jpg.Height;
bmp.Assign(jpg);
TBlobField(EmInfoQuery.FieldByName('Pics')).Assign(bmp);
finally
bmp.Free;
end;
finally
jpg.Free;
end;
end;
end;
  • 打赏
  • 举报
回复
http://blog.csdn.net/ghyghost/archive/2003/07/21/15773.aspx
http://blog.csdn.net/ghyghost/archive/2003/07/21/15774.aspx
cdsgajxlp 2004-09-14
  • 打赏
  • 举报
回复
cjs5210 2004-09-13
  • 打赏
  • 举报
回复
楼上的几位大哥,你们的操作对bmp可以,但是对jpg就是有时行有时不行啊,我jpeg单元也引用了
求高手再给解解惑!
cxz7531 2004-09-13
  • 打赏
  • 举报
回复
不要用TMemoryStream 这样
存入
TBlobField(adoquery1.FieldByName('image')).LoadFromFile('c:\c.jpg');
adoquery1.post;
读出

TBlobField(adoquery1.FieldByName('image')).SaveToFile('c:\cc.jpg');


天行归来 2004-09-13
  • 打赏
  • 举报
回复
//把文件当作流存在数据库里面,需要记住文件类型,便于今后决定如何打开。
procedure SaveFileToDB();
var
Dlg: TOpenDialog;
Stream: TMemoryStream;
begin

Dlg := TOpenDialog.Create(Self);
Dlg.Title := '请选择文件!';
if Dlg.Execute then
begin
Stream := TMemoryStream.Create;
Stream.LoadFromFile(Dlg.FileName);
adsFile.Append;
TBlobField(adsFile.FieldByName('File')).LoadFromStream(Stream);
adsFile['FileName'] := ExtractFileName(Dlg.FileName);
adsFile.Post;
Stream.Free;
Dlg.Free;
ShowMessage('文件保存到数据库操作完毕!');
end;

end;

//从数据库取文件,并打开浏览。
procedure ViewFileFromDB();
var
BlobS: TBlobStream;
MemoryStream: TMemoryStream;
FileName: String;
begin

if (adsFile.RecordCount<=0) or (adsFile.FieldByName('File').IsNull) then Exit;
BlobS := TBlobStream(adsFile.CreateBlobStream(adsFile.FieldByName('File'),bmRead));
MemoryStream := TMemoryStream.Create;
MemoryStream.LoadFromStream(Blobs);
FileName := adsFile['FileName'];
MemoryStream.SaveToFile(FileName);
MemoryStream.Free;
ShellExecute(Handle,'Open',PChar(FileName),nil,nil,SW_SHOWNORMAL);

end;
cjs5210 2004-09-13
  • 打赏
  • 举报
回复
楼上兄弟,可否贴出代码??
RamjetZhang 2004-09-13
  • 打赏
  • 举报
回复
uses jpeg;
建议不要当图像读入,而用file stream读入直接保存,再加一个列说明文件类型。
部分使用说明: 点击开始菜单-运行命令,在对话框输入: "jhead –命令参数 jpeg文件" 例如: “jhead -de D:\A.jpg” 删除D盘盘根目录下A.jpg文件的exif信息。 “jhead -de D:\*.jpg” 删除D盘根目录下所有jpg文件的exif信息。其中星号是通配符。 二、通用指令参数 -te 将其他jpeg文件的eixf导入目标jpeg。例如"jhead –te D:\B.jpg D:\A.jpg" -dc 删除jpeg信息中的备注。注意,jpeg文件有两个备注,一是和其他文件一样的备注,另一个是exif信息中的备注。jhead仅对exif信息有效。 -de 完全删除exif信息。 -du 删除非原始exif信息,例如Photoshop、Turbophoto之类编辑后修改exif留下的信息。 -purejpg 删除所有jpeg文件非必须的信息。相当于-de、-dc和-du的集合,可以将文件减小数k。 -ce 修改文件的jpeg文件头部分备注(此备注并非exif信息)。该指令会打开文本编辑器,并在编辑器关闭时将备注信息存入文件。 -cs 导出备注。例如"jhead –cs D:\988.txt D:\A.jpg" -ci 导入备注。例如"jhead –ci D:\988.txt D:\A.jpg" -cl 直接输入备注。。例如"jhead –cl 我的备注 D:\A.jpg" 三、其他指令 时间日期 -ft 将jpeg文件的“修改时间”修改为exif信息中记录的时间。 -n[] 该指令会将文件名修改为exif信息中记录的“创建时间”;如果jpeg文件没有exif或者exif中的创建时间不可用,则将文件名修改为文件的“修改时间”。 默认的格式-顺序为MMDD-HHMMSS 格式-顺序参数如下: %d-日(01-31) %H-小时(00-23) %j-一年中的第几天(001-366) %m-月(01-12) %M-分钟(00-59) %S-秒(00-59) %U-一年中的第几周(00-53) %w-星期几(0-6,周日为0) %y-两位数纪年(00-99) %Y-四位数几年 %i-添加数字序号 例如: jhead -n%Y%m%d-%H%M%S d:\*.jpg 将所有jpg文件修改为YYYYMMDD-HHMMSS.jpg格式。 -nf 与“-n”相同功能相同,不保留原文件名。 -a 修改不同扩展名的同名文件名,相机拍摄的avi短片exif信息存储在与其同名的thm文件中,可用此指令给avi文件更名。一般与“-n”指令共同使用。 -ta 修正时差,例如时差根据时区确定,例如+1:00或者-1:00 -da- 修正日期。日期格式是yyyy:mm:dd、yyyy:nn:dd+hh:mm或者 yyyy:mm:dd+hh:mm:ss。根据前后参数时间差调整exif的时间。 -ts 直接修改exif中的拍摄时间,日期-时间格式为yyyy:mm:dd-hh:mm:ss 缩略图 -dt 删除exif中的缩略图。这个缩略图一般为240x160像素,10k大小,用于数码相机、Windows XP查看照片,删除它不会影响工作。 -st 将exif中的缩略图复制为另一个jpeg文件 -rt 用另一个jpeg文件替换exif中的缩略图 -rgt[大小] 刷新exif缩略图,其中大小为缩略图的最大边长。 旋转 -autorot 根据exif中记录的水平方向信息转动jpeg照片。 -norot 清除exif中的水平方向信息。 四、使用技巧 1)用开始菜单的"运行"指令并不直观,可以通过运行cmd命令进入DOS命令提示符界面操作。在DOS界面进入操作照片文件夹(不懂DOS操作的朋友建议稍稍学习DOS指令,今后也会受用无穷),在文件夹中运行jhead命令,用“*.jpg”表示文件夹中所有的jpeg文件,可以进行批处理。 2)-te(复制exif信息)作用在于可以恢复被其他编辑软件删除的exif信息。编辑照片之前,先在照片文件夹中建立一个名为“backup”的备份文件夹,将原是照片复制到backup文件夹中,然后再编辑照片,编辑软件可能会删除或修改exif。编辑结束后进入DOS界面照片文件夹输入: jhead –te “backup\&i” *.jpg 照片的exif信息就会从backup文件夹的原始文件中复制回来。其中“&i”表示与目标文件同名的文件,前面的“backup\”表示原始文件位置。 3)-purejpg指令可以删除所有exif信息,让照片减小若干k字节
一、安装和使用 Jhead 2.82_绿色英文版 使用时,点击开始菜单-运行命令,在对话框输入: "jhead –命令参数 jpeg文件" 例如: “jhead -de D:\My Pictures\A.jpg” 删除D盘My Pictures文件夹A.jpg文件的exif信息。 “jhead -de D:\My Pictures\*.jpg” 删除D盘My Pictures文件夹所有jpg文件的exif信息。其中星号是通配符。 二、通用指令参数 -te 将其他jpeg文件的eixf导入目标jpeg。例如"jhead –te D:\My Pictures\B.jpg D:\My Pictures\A.jpg" -dc 删除jpeg信息中的备注。注意,jpeg文件有两个备注,一是和其他文件一样的备注,另一个是exif信息中的备注。jhead仅对exif信息有效。 -de 完全删除exif信息。 -du 删除非原始exif信息,例如Photoshop、Turbophoto之类编辑后修改exif留下的信息。 -purejpg 删除所有jpeg文件非必须的信息。相当于-de、-dc和-du的集合,可以将文件减小数k。 -ce 修改文件的jpeg文件头部分备注(此备注并非exif信息)。该指令会打开文本编辑器,并在编辑器关闭时将备注信息存入文件。 -cs 导出备注。例如"jhead –cs D:\1.txt D:\My Pictures\A.jpg" -ci 导入备注。例如"jhead –ci D:\1.txt D:\My Pictures\A.jpg" -cl 直接输入备注。。例如"jhead –cl 我的备注 D:\My Pictures\A.jpg" 三、其他指令 时间日期 -ft 将jpeg文件的“修改时间”修改为exif信息中记录的时间。 -n[] 该指令会将文件名修改为exif信息中记录的“创建时间”;如果jpeg文件没有exif或者exif中的创建时间不可用,则将文件名修改为文件的“修改时间”。 默认的格式-顺序为MMDD-HHMMSS 格式-顺序参数如下: %d-日(01-31) %H-小时(00-23) %j-一年中的第几天(001-366) %m-月(01-12) %M-分钟(00-59) %S-秒(00-59) %U-一年中的第几周(00-53) %w-星期几(0-6,周日为0) %y-两位数纪年(00-99) %Y-四位数几年 %i-添加数字序号 例如: jhead -n%Y%m%d-%H%M%S d:\*.jpg 将所有jpg文件修改为YYYYMMDD-HHMMSS.jpg格式。 -nf 与“-n”相同功能相同,不保留原文件名。 -a 修改不同扩展名的同名文件名,相机拍摄的avi短片exif信息存储在与其同名的thm文件中,可用此指令给avi文件更名。一般与“-n”指令共同使用。 -ta 修正时差,例如时差根据时区确定,例如+1:00或者-1:00 -da- 修正日期。日期格式是yyyy:mm:dd、yyyy:nn:dd+hh:mm或者 yyyy:mm:dd+hh:mm:ss。根据前后参数时间差调整exif的时间。 -ts 直接修改exif中的拍摄时间,日期-时间格式为yyyy:mm:dd-hh:mm:ss

2,496

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 数据库相关
社区管理员
  • 数据库相关社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧