庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>程序设计>Delphi语言>编程技巧>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

Delphi8 for .net 的 VCL 类库

 作者:本站收集   日期:2005-3-14
字号选择〖 〗/ 双击滚屏 单击停止   
    前两天,看了一篇Delphi8的介绍,于是下来一个装上看看(可能是盗版的,不过我不会用于商业用途!),我使了5年的Delphi,从3到6,6以后就开始用.Net了。前段时间出了个C#Builder,兴奋的装上看了看,而已!
前段时间听说Borland要推出"超级"的VCL Framework,着有兴趣,因为总觉得microsoft不会真的推出For Linux的Framework,那么Mono更是遥遥无期(估计万不得已,ms会花一些money收掉他)。
装好Delphi8后,一启动以为和C#Builder差不多(一样启动界面风格,现在我还不解那个黑灰的设计,预示着什么?),根据前面看到的Delphi8的介绍,一直对Vcl控件不能兼容.Net控件不解,探个究竟!见了一个Vcl Forms的工程一看,还傻不啦叽相硬拖.Net控件,门都没有!
还好,Vcl类库是开放源码的(跟了ms一段时间,这样的习惯已经没了),一看才知道怎么回事事儿!Vcl的控件都是从System.ComponentModel.Component写下来的,怪不得与.Net控件不相容了。就拿TForm举例,其是从:System.ComponentModel.Component —〉TComponent —〉TControl —〉TWinControl —〉TScrollingWinControl —〉TCustomForm一路过来的,当然和System.Windows.Forms.Control下的.Net控件不是一路货了,TControl和Control分道扬镳。不过还好从类库的结构看上去,他们的组件还是可以兼容的,具体的就不一定了!
再看看Borland工程师写的Vcl源码,就好像开始说的那句话,好辛苦啊!既要完全兼容以前Delphi源码,又要支持.Net,不能再像以前那样无所忌惮的用API,用汇编,把System.Runtime.InteropServices.Marshal类用的个透熟!不知道还能不能跨平台,估计在什么Linux上,这帮Borland工程师们又要“好辛苦”了。再写一遍,反正我们比ms的men强,怕什么!
说了半天,两边的控件能不能互调,怎么互调啊?怎么让TControl包含Control,让Control包含TControl?
Delphi8安装后,发现程序菜单中有一个WinForms Controls的导入工具,哇,赶紧试一下!转了一个简单的控件,自己写的一个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中调用过ActiveX控件的朋友一定知道,在.Net调用ActiveX控件时,DotNet会自动生成一个包装类,就像上面TImpRulerPanel一样,只不过Com对象的包装类是从AxHost继承的,这里的包装是从TNetControlWrapper继承的,手法很相像。AxHose通过GetOcx或得Com控件,这里直接可以获得,都是“一家”,自然要方便一些。我想将来,将Vcl控件包装到.Net中使用也不是什么难事。

但是在转换其他一些复杂一点的控件,比如包含自定义事件时,就会有一些问题,甚至产生莫名奇妙的错误,我会加强研究,在后来文章中的给大家介绍及其解决的方法。

现在用.Net IDE开发的同志我不推荐使用Delphi for .net,但现在使用老版本Delphi的同志,我强烈推荐。既可以保留Delphi的一些工程、编程习惯,又可以逐步过渡到.Net,使用.Net类库的强大功能,真是鱼和熊掌可以兼得阿,只是目前的界面控件的兼容上稍差一点。

另外Delphi8也比老版本的Delphi有一些其他方面的小进步,比如以前在编译时无法检验含有虚方法的类,现在则可以等。

总的来说,Delphi8还是非常值得使用.Net开发工具。只看了一小会儿,有什么谬论,希望大家指出和原谅,我也会不断地学习进步!

acai 评论:
不用再指望VCL还能在.Net上再现辉煌了,Borland清楚,你我也应该清楚,就象李维说的,“把Delphi7好好保存起来吧,这是最后一个Win32版本了”(好像据说还会有更新,如7.1等等,但是大版本更新不会有了,仅仅处于维护阶段了),还在开发win32程序的兄弟,就买本老李的《Inside VCL》,没事研究下VCL做做纪念吧。而想快速地进入.Net的天地,那就轻装上阵,暂时忘记Delphi吧。千万要记住:只要ms不倒,.Net的FCL就是.Net下最大最流行最根本的类库,你不要再指望borland把什么都包起来象个婴儿似地喂着delphi的程序员——如果你还是认为学了VCL就可以不理会Win32的api,学了VCL.Net就可以不理会FCL的话,那就当我没说吧。

完全没有必要用所谓的“vcl Form”程序来过渡到.Net的上,“winform application”是标准的.Net类库程序,而所谓的“VCL Form Application”仅仅是borland用来进行所谓“升级维护”的幌子而已,李维都认为现在的vcl.net仅仅是个过渡方案,而Danny Thrope也直言不讳说.Net类库由MS来开发那Borland可以把以前分散在类库设计上的力量集中起来设计“真正威力的Delphi”(不知道IDE重要了还是类库重要了),大家都知道这个版本的delphi开发时间仅仅只有6个月,所以现在的“VCL Form Application”的控件少的可怜,那是因为开发组来不及做,以后也很难说,再说,学习.Net,首要的是学习.Net FrameWork,而不是VCL.Net!!
即使从工具的角度来讲,现在的Delphi.Net也是个鸡肋,就这种bug不断的半成品,真的能来做项目吗??从学习的角度来讲,那更不应该来用,.Net FrameWork已经不象以前的Win32api,学习的难度已经大大降低了,更不可想像从事.Net的开发而不熟悉.Net的FCL,因此,还是学习C#吧!VS.Net要稳定的多,足以用来做真实的项目开发了,反观现在的C# Builder和Delphi.Net,有几个人真的敢来做项目??
所以,如果你真的还是所谓的“Delphi”扇子,那尽量还是选择“Windows Form”程序学习吧,否则,还是老老实实地去学习Framework去吧。

上一篇:Delphi+Word解决方案参考    下一篇:用Delphi编写VxD设备驱动程序  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-3-14
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿