線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1845
推到 Plurk!
推到 Facebook!

請教圖形欄位(OLE物件的顯示和列印問題

答題得分者是:hagar
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-08-14 15:12:19 IP:63.84.xxx.xxx 未訂閱
請教各位前輩    小弟使用ADOConnection連接Access資料庫﹐并以ADOQuery取得資料﹐并使其顯示出來﹐但在使用DBImage元件顯示資料表中的圖形欄位(OLE物件)時﹐出現﹕[Bitmap image is not valid]錯誤﹐請問是何原因﹐該如何解決﹖ 在使用QuickRep元件來做報表時﹐使用相同的元件取得資料表﹐但在使用QRDBImage顯示圖形欄位﹐也出現同樣的錯誤﹒ 謝謝﹗ ===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-08-15 13:05:37 IP:202.39.xxx.xxx 未訂閱
http://sun.cis.scu.edu.tw/~nms9115/articles/delphi/AdoAccessImg/AdoAccessImage.htm --- --<-<-<@
sos_admin
版主


發表:121
回覆:697
積分:768
註冊:2003-07-23

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-08-15 13:25:15 IP:61.155.xxx.xxx 未訂閱
TDBimage組件是不是不能顯示非bmp格式的圖像 系統說‘bitmap image is not valid’,請教這種問題怎樣解決? 如下: http://delphi.ktop.com.tw/topic.php?topic_id=30976
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-08-15 14:27:58 IP:63.84.xxx.xxx 未訂閱
感謝兩位﹒    但小弟的圖形檔是BMP類型﹐為何也是不能使用DBImage顯示呢﹖    感謝﹗    ===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
sos_admin
版主


發表:121
回覆:697
積分:768
註冊:2003-07-23

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-08-15 14:54:06 IP:61.155.xxx.xxx 未訂閱
cashxin2002 兄: 可将你的原码部分post上来吗?大家再帮你看看是不是有什么遗漏了
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-08-15 17:29:10 IP:63.84.xxx.xxx 未訂閱
感謝各位前輩﹒    原來DBImage是不能讀取OLE圖檔的 看了><>===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
sos_admin
版主


發表:121
回覆:697
積分:768
註冊:2003-07-23

發送簡訊給我
#7 引用回覆 回覆 發表時間:2003-08-15 17:34:54 IP:61.155.xxx.xxx 未訂閱
感謝各位前輩﹒ 原來DBImage是不能讀取OLE圖檔的 看了hagar版主的文章才明白是這樣一回事﹐再試了一下前輩的方法﹐也是可行的﹒ 現在小弟用了一個變相的方法來做這個工作﹐將Access資料表欄位中的PHOTO欄位形態改為文字﹐而后在Form中使用一個DBEdit來對應這個欄位﹐而后再用一個OpenPictureDialog加上Image元件的顯示方法﹐就可以了﹒ 感謝各位前輩的指點﹗ ------------------------------------- oh,dear! [ree]谁说不能使用ole图档,我在intraweb、一般的软件中将图像存在access的ole字段或sql server 的blob字段都可顺利取出,不论是bmp还是jpg类型的图档 [/red]
sos_admin
版主


發表:121
回覆:697
積分:768
註冊:2003-07-23

發送簡訊給我
#8 引用回覆 回覆 發表時間:2003-08-15 17:35:19 IP:61.155.xxx.xxx 未訂閱
感謝各位前輩﹒    原來DBImage是不能讀取OLE圖檔的 看了hagar版主的文章才明白是這樣一回事﹐再試了一下前輩的方法﹐也是可行的﹒ 現在小弟用了一個變相的方法來做這個工作﹐將Access資料表欄位中的PHOTO欄位形態改為文字﹐而后在Form中使用一個DBEdit來對應這個欄位﹐而后再用一個OpenPictureDialog加上Image元件的顯示方法﹐就可以了﹒    感謝各位前輩的指點﹗ ------------------------------------- oh,dear! 谁说不能使用ole图档,我在intraweb、一般的软件中将图像存在access的ole字段或sql server 的blob字段都可顺利取出,不论是bmp还是jpg类型的图档
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#9 引用回覆 回覆 發表時間:2003-08-15 17:57:04 IP:63.84.xxx.xxx 未訂閱
引言: 感謝各位前輩﹒ 原來DBImage是不能讀取OLE圖檔的 看了hagar版主的文章才明白是這樣一回事﹐再試了一下前輩的方法﹐也是可行的﹒ 現在小弟用了一個變相的方法來做這個工作﹐將Access資料表欄位中的PHOTO欄位形態改為文字﹐而后在Form中使用一個DBEdit來對應這個欄位﹐而后再用一個OpenPictureDialog加上Image元件的顯示方法﹐就可以了﹒ 感謝各位前輩的指點﹗ ------------------------------------- oh,dear! 谁说不能使用ole图档,我在intraweb、一般的软件中将图像存在access的ole字段或sql server 的blob字段都可顺利取出,不论是bmp还是jpg类型的图档
小弟之所以有這樣的講法是因為自己遇到的問題﹐和參考hagar版主轉貼的這個文章﹕ =========================================================================== 讀取 Access 資料庫的圖形欄位 (使用 Delphi 5 ADOExpress) 資料提供、整理:陳國生,蔡煥麟,朱子 摘要 「如何讀取並顯示 Access 資料庫的圖形欄位資料?」已是個 FAQ,本文主旨即在說明解決此問題的方法。此方法最初是在 efg's Computer Lab 網站的一篇文章中得來,但目前該文已經在網站上消失了。如果你搜尋 Borland 新聞群組,也可以找到類似的解答,整理這篇文章只是方便大家參考。 請先確定你的電腦有安裝 Microsoft© Access 中文版,在本文中我們將使用其隨附的北風資料庫來做示範。 問題重現 建立一個新的專案,然後在 Form1 上面各放置一個 ADODataSet,DataSource,DBImage,DBGrid。 設定 ADODataSet1 的 ConnectionString 屬性: Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Program Files\Microsoft Office\Office\Samples\Northwind.mdb;Persist Security Info=False 以及 CommandText 屬性: select * from 產品類別 把連接各元件的屬性設定好之後,將 ADODataSet1 的 Active 屬性設為 True,此時便會出現錯誤訊息 "Bitmap image is not valid."。由於該圖形是以 OLE 物件的形式存在資料庫中,而 DBImage 並未支援這種格式的圖形資料,因而發生錯誤。你可以在程式中加入下面這行程式碼,它會將圖形資料存到 Blob.dat 檔案裡面: TBlobField(ADODataSet1.FieldByName('圖片')).SaveToFile('Blob.dat'); 如果用 UltraEdit 之類的工具檢視該檔案的內容,可以看到它大概是長成這樣: 1 151C2F00020000000D000E0014002100 ../...........!. 2 FFFFFFFF4269746D617020496D616765 ....Bitmap Image 3 005061696E742E506963747572650001 .Paint.Picture.. 4 05000002000000070000005042727573 ...........PBrus 5 6800000000000000000020540000424D h......... T..BM 6 16540000000000007600000028000000 .T......v...(... 7 C0000000DF0000000100040000000000 ................ 8 A0530000CE0E0000D80E000000000000 .S.............. 9 00000000000000000000800000800000 ................ 10 00808000800000008000800080800000 ................ 11 C0C0C000808080000000FF0000FF0000 ................ 12 00FFFF00FF000000FF00FF00FFFF0000 ................ 13 FFFFFF00FF0CB0C9000B090900000A00 ................ 14 9009000000000909A09A900B09000A90 ................ 15 A00000000FFFEFFFFFFFFFFFFFFFFFCB ................ 16 9CFCFEFAFFFFFFFFEDFFFEDEFFDEFEFC ................ 17 FFFFDADA00D900009009009000000000 ................ 18 090A00090BC0000900900000000A00AC ................ 19 A0E0E0E0F0E9CA9000A9CB0C00009090 ................ 20 E0000009090B0000D009009000000900 ................ 21 009A000FFFFFFFFFFFFEFFFFFFFFFCAD ................ 22 EBDBDFDFDFFFFFFFFFEFEDFFFEFFFFFF ................ 23 FEFCAF0C9A0A0D00009A000000000000 ................ 24 0009090A000B009A9000090000900C09 ................ 25 00900900FA90ADA00090B00B00000000 ................ ... 解決方法 前面說過,DBImage 之所以無法正常顯示圖形,是因為當初該欄位的圖形資料是以 OLE 物件的格式存進去的(跟是不是 Access 資料庫沒關係),所以解決方法就是將 OLE 格式的圖形資料轉換成 DBImage 支援的 bitmap 格式 =========================================================================== 以上是摘錄的一部分﹐問題是需要將OLE物件轉成支援的Bitmap格式才可以﹒ 敬請揣摩﹗ 小弟認真拜讀過您有關這方面的大作﹐或者小弟就是認為比較麻煩﹐所以才改用另外一個變通的方法﹐請您多多指正﹗ ===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
系統時間:2024-07-01 19:53:27
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!