小探 Delphi8 for .net 的 VCL 類庫
發(fā)表時間:2023-08-04 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]Borland工程師好辛苦啊!首先得感嘆這么一句! 前兩天,看了一篇Delphi8的介紹,于是下來一個裝上看看(可能是盜版的,不過我不會用于商業(yè)用途。沂沽5年的Delphi,從3到...
Borland工程師好辛苦啊!首先得感嘆這么一句!
前兩天,看了一篇Delphi8的介紹,于是下來一個裝上看看(可能是盜版的,不過我不會用于商業(yè)用途。沂沽5年的Delphi,從3到6,6以后就開始用.Net了。前段時間出了個C#Builder,興奮的裝上看了看,而已!
前段時間聽說Borland要推出"超級"的VCL Framework,著有興趣,因為總覺得microsoft不會真的推出For Linux的Framework,那么Mono更是遙遙無期(估計萬不得已,ms會花一些money收掉他)。
裝好Delphi8后,一啟動以為和C#Builder差不多(一樣啟動界面風(fēng)格,現(xiàn)在我還不解那個黑灰的設(shè)計,預(yù)示著什么?),根據(jù)前面看到的Delphi8的介紹,一直對Vcl控件不能兼容.Net控件不解,探個究竟!見了一個Vcl Forms的工程一看,還傻不啦嘰相硬拖.Net控件,門都沒有!
還好,Vcl類庫是開放源碼的(跟了ms一段時間,這樣的習(xí)慣已經(jīng)沒了),一看才知道怎么回事事兒!Vcl的控件都是從System.ComponentModel.Component寫下來的,怪不得與.Net控件不相容了。就拿TForm舉例,其是從:System.ComponentModel.Component —〉TComponent —〉TControl —〉TWinControl —〉TScrollingWinControl —〉TCustomForm一路過來的,當(dāng)然和System.Windows.Forms.Control下的.Net控件不是一路貨了,TControl和Control分道揚鑣。不過還好從類庫的結(jié)構(gòu)看上去,他們的組件還是可以兼容的,具體的就不一定了!
再看看Borland工程師寫的Vcl源碼,就好像開始說的那句話,好辛苦!既要完全兼容以前Delphi源碼,又要支持.Net,不能再像以前那樣無所忌憚的用API,用匯編,把System.Runtime.InteropServices.Marshal類用的個透熟!不知道還能不能跨平臺,估計在什么Linux上,這幫Borland工程師們又要“好辛苦”了。再寫一遍,反正我們比ms的men強,怕什么!
說了半天,兩邊的控件能不能互調(diào),怎么互調(diào)。吭趺醋孴Control包含Control,讓Control包含TControl?
Delphi8安裝后,發(fā)現(xiàn)程序菜單中有一個WinForms Controls的導(dǎo)入工具,哇,趕緊試一下!轉(zhuǎn)了一個簡單的控件,自己寫的一個Button,沒問題,工作的很好!先來看看怎么完成的:
TImpRulerPanel = class(TNetControlWrapper)
private
function GetRulerPanel: Hose.WinForm.RulerPanel;
protected
procedure InitControlData; override;
procedure HookNetEvents(AControl: System.Windows.Forms.Control); override;
procedure UnhookNetEvents(AControl: System.Windows.Forms.Control); override;
public
property RulerPanel: Hose.WinForm.RulerPanel read GetRulerPanel;
(我刪除了不必要的部分)
在.net中調(diào)用過ActiveX控件的朋友一定知道,在.Net調(diào)用ActiveX控件時,DotNet會自動生成一個包裝類,就像上面TImpRulerPanel一樣,只不過Com對象的包裝類是從AxHost繼承的,這里的包裝是從TNetControlWrapper繼承的,手法很相像。AxHose通過GetOcx或得Com控件,這里直接可以獲得,都是“一家”,自然要方便一些。我想將來,將Vcl控件包裝到.Net中使用也不是什么難事。
但是在轉(zhuǎn)換其他一些復(fù)雜一點的控件,比如包含自定義事件時,就會有一些問題,甚至產(chǎn)生莫名奇妙的錯誤,我會加強研究,在后來文章中的給大家介紹及其解決的方法。
現(xiàn)在用.Net IDE開發(fā)的同志我不推薦使用Delphi for .net,但現(xiàn)在使用老版本Delphi的同志,我強烈推薦。既可以保留Delphi的一些工程、編程習(xí)慣,又可以逐步過渡到.Net,使用.Net類庫的強大功能,真是魚和熊掌可以兼得阿,只是目前的界面控件的兼容上稍差一點。
另外Delphi8也比老版本的Delphi有一些其他方面的小進步,比如以前在編譯時無法檢驗含有虛方法的類,現(xiàn)在則可以等。
總的來說,Delphi8還是非常值得使用.Net開發(fā)工具。只看了一小會兒,有什么謬論,希望大家指出和原諒,我也會不斷地學(xué)習(xí)進步!