模仿PowerBuilder的一个报表工具

来源:互联网 发布:淘宝商城药店 编辑:程序博客网 时间:2024/06/10 01:33

模仿PowerBuild的一个报表工具

模仿PowerBuild的一个报表工具
因为在网上找到的例程依然使用DrawText()去一句一句写,
实在是不方便,其它又说要钱,一说到钱就没兴趣用了;
所以我模仿PB的dataWindow写成了这个报表工具。
程序主要包括4个类
1、ADOxxxx是别人写的一个数据库类,具体怎么用去问作者吧。
2、CPreGraphic是实现绘制的类,DrawText()等
3、CPrePrint是控制打印机的类,CPrintDialog等
4、CDataWin是实现功能的主要类,它把VC在IDE介面中设计
   的窗口转换成报表,见下图。
使用方法:
1、在工程中加入ADO、DataWin目录中的所有文件
2、在App中加入对COM的支持
   App::InitInstance()加入
        CoInitialize(NULL);
   App::ExitInstance()加入
        CoUninitialize();
3、生成一个CDataWin类
   CDataWin m_dlg;
   m_dlg.Create(IDD_DIALOG1, this); //创建
   m_dlg.Init();
// m_dlg.SetDoubleRam(TRUE);  //双缓存,提高显示速度
// m_dlg.SetPrintView(FALSE); //是否模拟显示
   CRect rect;                   //定位
   GetClientRect(&rect);
   rect.DeflateRect(10, 50, 10, 50);
   m_dlg.MoveWindow(rect,FALSE);
   m_dlg.ShowWindow(SW_SHOW);
4、执行打印
   m_dlg.OnPrint("Title1"); //打印项目名称,什么都没关系
技术细节
   在IDE窗口中加入三条PROGRESS,把窗口分成4个区域
(页头、表体、表尾、页尾)。在生成窗口后CDataWin会取出窗
口中所有控件的位置、类型等,然后隐藏控件。CDataWin
根据这些信息去连结数据库,取出数据并显示或打印出来。
a)标题是SQL命令
b)=Name 等号+数据库表项的名称
c)其它为一般显示。
主要初始化函数Init()包括以下功能:
   InitGraphic();                //创建绘图类
   ResetAll();                   //复位所有变量
   InitBase();                   //修改窗口风格、初始化纸张
   fnEnumControl();              //枚举所有子窗口
   if(!Init4Control()) return FALSE;    //初始化窗口结构
   InitConnect();                //连结数据库
   Open(m_strDefSQL);            //打开表格
   UpdateRecord();          //载入数据库数据
   ShowWindow(SW_SHOW);          //显示
窗口中的控件被转换成统一的CDataCell结构,就象Grid中的项目。
刷新窗口时会执行
OnPaint()
OnPageStart()
OnCellStart(CDataCell *p)  //N次
OnCellEnd(CDataCell *p)    //你可以继承这些函数,从而改变显示内容
OnPageEnd()                //格式、或禁止它。
补充: 程序存在大量坐标转换的运算,其实不用去理解,只要在OnCellStart()中
对CDataCell进行修改就可以达到不同的效果。简单扩展类CDlg1就是让ID显
示红色。 

效果图1

下载地址:ebug.ys168.com

原创粉丝点击