最近需要做打印发货单的功能,以前用delphi的reportmachine控件做报表,功能很强大,可以设计报表并且报表文件和程序分离,优点就不多说了,这次需要连纸打印,于是想到用activex组件开发打印组件。
这样这个教程就分为两部分,一部分说Delphi的activex组件开发,另一部说ASP.NET MVC如何调用activex组件进行打印。
1.Delphi开发Activex组件
- 创建一个ActiveXform项目,如图所示:
- 设置项目发布选项,需要提醒的是由于Delphi7的bug,只在第一次创建项目后能够设置Web Deploy选择,等关闭项目再打开就不能设置了,这个需要注意!
- 拖拽RMRport控件到窗体中,拖拽RMUserDataset组件到窗体,这个适用于传递数据给RMReport报表打印用的,
- 设置RMReport1的DataSet属性为RMUserDataset1


到此已经成功创建了一个带打印功能的ActiveX组件,具体如何使用ReportMachine 报表组件的教程,稍后我会写个详细的教程
下面就是.Net如何调用Activex组件了。
2.ASP.NET MVC 调用Activex组件打印
4.在About.aspx.cs的onload时间中调用Delphi的Activex组件声明的print方法进行打印,需要赋予服务器上report.rmf也就是报表文件的绝对地址给print方法,这样报表组件才能正确加载报表文件,具体代码如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using ActiveFormProj1;
namespace TangCMS.Views.Home
{
public partial class About : ViewPage
{
protected override void OnLoad(EventArgs e)
{
//声明Activex组件的ActivexForm对象
ActiveFormX report = new ActiveFormX();
//调用Activex组件声明的print方法
string file = Server.MapPath("~/content/report.rmf");
report.Print(file);
}
}
}
5.发布站点,点击About Us链接会弹出报表预览打印窗口,最终效果如下:
Mikel





选择 View ->Type Library







