delphi使用流实现jpg文件的处理(转).docVIP

  • 10
  • 0
  • 约5.01千字
  • 约 6页
  • 2016-12-21 发布于北京
  • 举报
一、 原理介绍--流式数据的类型及其应用 在Dephi中提供了TStream来支持对流式数据的操作。TStream是万流之源。 但由于它是一个抽象类,故不能被直接使用;而要使用其相应的子类, 如:TFileStream 、TStringStream、TMemoryStream、TBlobStream、 TWinSocketStream和TOleStream。TStream提供了统一、简洁的方法来进行数据的读写。 1.)SaveToStream(Stream: TStream ); 作用:将类中的数据写到Stream的当前位置中 2.)LoadFromStream(Stream: TStream); 作用:从当前位置读入Stream里的数据 实际使用时我们基本上只要使用上面两个函数就可以了。 二、所遇到的问题及相应的解决方法 为了节省图像的存储空间和使用更加方便,决定采用JPEG这种图像格式。 (一)所遇到的问题 第一、在Delphi 5中进行画图所用到的组件是TImage,所生成的图像的格式为BMP格式, 而为了节省图像的存储空间,图像在数据库里存储的格式须为JPEG格式,这样就产生了 图像格式转化的需求;而TImage本身并不直接提供这两种图像格式之间的转化。 第二、怎样将存储在Microsoft Access数据库中的图像取出并且显示出来:在Delphi 5 中,能提供这种功能的组件是TDBImage,但该组件却存在着一个很大的缺陷:它所能显 示的图像类型只能是一些图标文件,元文件和BMP文件,而不能支持JPEG格式的图像在 该组件中的显示;但根据实际需要,在Microsoft Access数据库中所存储的图像数据却 是以JPEG格式保存的。 (二)相应的解决方法 为了解决上述两个问题,可以采用目前数据库中一种名为大二分对象(BLOB--Bina ry Large Object),它是用来处理某些特殊格式的数据的。BLOB在数据库的表中实际上 是以二进制数据的形式存放的。为了处理BLOB字段,可以借鉴一些可视的桌面数据库的 方法。在这里,我们选择了通过内存流的方式来完成;使用内存流,可减少磁盘操作, 大大提高运行效率。 具体的过程和相关的程序代码如下: 1、如何实现在Microsoft Access数据库中的图像存储: 这里是利用TStream的子类TMemoryStream向Microsoft Access数据库中存储图像的。 下面的这段代码是在按了“保存”按钮之后所触发的事件处理程序: procedure TForm1.Button1Click(Sender: TObject); var MyJPEG : TJPEGImage; MS: TMemoryStream; begin MyJPEG := TJPEGImage.Create; try with MyJPEG do begin Assign(Image.Picture.Graphic); MS:=TMemoryStream.create; SaveToStream(MS); MS.Position:=0; Table1.Edit; TBlobField(Table1.FieldbyName(Image)).LoadFromStream(MS); Table1.Post; messagebox(getactivewindow(),图像保存完毕!,保存,mb_ok); end; finally MyJPEG.Free; end; end; 在这段代码里TStream的子类TMemoryStream利用内存流起到了将BMP格式转化为JPEG格式 的中间桥梁的作用。 2、如何将图像从Microsoft Access数据库中取出并显示出来: 下面的这段代码是在按了“查看图像”按钮之后所触发的事件处理程序: procedure TForm1.Button1Click(Sender: TObject); var tempstream:TStringStream; tempjpeg:TJPEGImage; begin try tempstream:=TStringStream.Create(); TBlobField(Query1.FieldByName(Image)).SaveToStream(tempstream); tempstream.Position:=0; tempjpeg:=TJPEGImage.Create; tempjpeg.LoadFromStream(tempstream);

文档评论(0)

1亿VIP精品文档

相关文档