轉載delphi6、delphi7下無法調用activex控件的解決方法_第1頁
轉載delphi6、delphi7下無法調用activex控件的解決方法_第2頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、轉載:關于在delphi6、delphi7下無法調用activeX 控件的解決方法Delphi使用VB控件全攻略原創:環創工作室 前言 在最近幾周的工作里,始終被一個頭疼的問題所困擾,那就是VB6編寫的ActiveX控件在Delphi環境下存在著諸多稀奇古怪的問題,幾經周折,終于在搜索了幾乎全部的論壇、資料后,找到了針對不同Delphi版本發生的問題的解決辦法。 Delphi 5 莫名其妙的致命異常之一 首先,我們來看看VB寫的ActiveX控件在Delphi 5下面的奇怪表現。 例如:我們用VB編寫了一個控件UserTest(為簡單起見,我們只導出一個類即用戶控件),一個屬性TestName

2、,一個方法TestMethod。然后將其編譯成一個ActiveX控件,注冊并導入Delphi5的開發環境(以上步驟如有未清楚之處,請查閱各類參考資料,肯定有標準答案),到目前為止,看來一切正常。 然后,我們習慣的把控件拖放到窗體上,調整大小,在屬性窗口中為屬性賦值,或者在代碼中也是一樣,非常正常,好用的很。但是,下面問題來了,如果您興致勃勃的去調用了那個TestMethod,那么您將得到一個古怪的異常 “Ole Error 800a01a9”,然后程序退出,而且非常不幸的是,您將無法跟蹤到這個異常,在Delphi中或是VB中都是,當然如果您對匯編很在行的話,您可以跟著Delphi的調試窗口一步

3、一步往下 當我第一次碰到這個問題的時候,我幾乎是憤怒的,因為無論是MicroSoft或是Borland,對該錯誤都沒有任何解釋,也沒有任何可以查找的資料。我只好跑到常去的幾個論壇,當然最主要的還是CSDN,在VB版和Delphi版中四處搜索類似的問題,然后非常遺憾的是,只有類似的問題,而沒有答案,一個大客戶就用的這個開發工具,我在測試了幾乎所有Windows上的開發工具和開發環境(包括桌面和WEB)后,惟獨將Delphi忘記了。 剩下的兩天里,我幾乎是滿世界亂跑,給所有的朋友打電話,詢問Delphi方面的高手是否知道這個情況,最后,我從Google上搜到了一個鏈接,可惜的是現在我忘記了那個鏈接

4、的具體位置,但是我得到了一個近乎Magic的方法(發現者是這么稱呼它的): 一個手工修改Delphi導入VB ActiveX控件后產生的代理類型庫XXX_TLB.PAS(這里XXX指的是控件的類名)文件的方法可以解決這一問題。舉例說明: 有一個VB 寫的控件 UserControl1 ,在Delphi中導入后產生兩個文件,其中一個UserControl1_TLB.PAS 就是我們所要修改的文件。 在文件中查找 類似 FintF: _UserControl1; Function GetControlInterface:_UserControl1; 和 property ControlInterf

5、ace: _UserControl1 read GetControlInterface; GetControlInterface; 以及 procedure TUserControl1.CreateControl; procedure DoCreate; begin Finf:=IUnknown(OleObject) as _UserControl1; End; Begin If Finf=nil then DoCreate; End; Function TUserControl1.GetControl1Interface: _UserControl1; Begin CreateControl

6、; Result:=Finfl; End; 請注意:這里紅色標出的 _UserControl1 要 全部換成 _ UserControl1Disp,如果編譯不成功的話,請將編譯警告中報出的_UserControl1 全部換成 _UserControl1Disp,編譯即可,這樣在調用控件的方法時便不會出現上述的致命錯誤。 感謝這個偉大的發現,我只能這么形容它,否則可能到現在我還要在這個圈子里套不出來,或者就是使用另外的工具重新開發這個控件(我難以想象這個工作量會有多大,又或者它可能還會存在其他的兼容性問題)。 Delphi 5 莫名其妙的致命異常之二 但是,Delphi并沒有在我繞開這個限制之后

7、而放過我,很快,客戶那邊發現另一個麻煩的問題,在開發環境下,每次運行時關閉載有控件的窗體都會跳出一個異常錯誤,但是在編譯后的應用程序中則不會,雖然不會影響最終用戶的使用,但是這對開發人員來說是個不小的困擾,然后我用了上述例子去試,發現并不會發生這個問題。(我當時就瘋了,這很可能是代碼中一些不兼容的用法所致,在一天時間里查找上萬行代碼是不是很正規是件極其恐怖的事情)我一氣之下,屏蔽了我的控件中所有的代碼,只留下用戶界面本身,然后奇怪的事情發生了,我什么代碼都沒寫,但是加載我的控件還是會發生這個錯誤,這使我又喜又驚,喜的是這個問題和我的代碼無關,這樣查找起來會方便的多;驚的是只是拖放幾個VB中的標

8、準控件居然也會造成這種恐怖的錯誤,Delphi5和VB6之間的矛盾還真不是一般的深。接下來的2個小時里,我不斷地刪除界面上的控件來測試到底是誰造成了這個致命的異常。 2個小時后,我舒了一口氣,問題找到了, 其根本問題是: 如果你在VB的用戶控件中使用類似Frame和PictureBox這樣的容器控件(其內部可以包含其他控件)時,那么您將不可以在這些控件中添加Label、Line、Image這樣的windowLess控件(也就是無窗口控件,它們在運行時是VB實時畫出來的),否則您就會得到上面這樣的錯誤報告。 Delphi 6、7 隱蔽的ActiveX控件 正是因為有了Delphi5下面的恐怖經歷

9、,我發現還是很有必要在Delphi6和7下面測試是不是也存在同樣的問題(之前的版本因為用戶極少已無必要,Delphi8還沒正式出,也暫不在考慮之列)。結果是:無論我加載多少次,我在ActiveX欄上始終沒有發現那個期待已久的小圖標。這樣的結果當然很滑稽,我連加載都做不到,更不要談什么測試正常不正常了。 同樣的,我搜索各類論壇和網站,CSDN里我也發現了更多的類似問題的提出者,但答案還是零,無奈之下,我只好對每個Delphi6、7中的選項進行調整 歷時3小時15分54秒后,我找到了這個該死的問題(請原諒我這么稱呼它,我實在是忍無可忍)的原因,或者說是解決辦法,說起來其實很簡單。 現在請跟著我做:點擊Tools菜單-Environment Options-Type Library頁,我們應該發現一項:Ignore special CoClass Flags When Importing,選中它,然后再選中Can Create那一項,那么現在,我們再嘗試去導入那個可憐的ActiveX控件吧(這里要注意,如果你已經導入過一次,那么請把產生的那兩個文件 .dcr 和 .pas文件刪除,否則將不會刷新)。這次如果還是不能在ActiveX欄中發現那個控件的話,

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論