报表输出轻松搞定

王朝vc·作者佚名  2006-01-17
窄屏简体版  字體: |||超大  

报表输出轻松搞定

作者:一行代码

下载源代码

一、刚刚开发了一个报表输出的 COM,可以动态的添加数据。代码没有限制,可随意使用。现在还在修改一些细节的地方,修改后会再次上传。

二、代码说明

1、首先注册COM控件 使用regsvr32命令

2、在stdafx中加入#import ".\YTReport.tlb"rename_namespace("TestYTReportDriver")

using namespace TestYTReportDriver;

3、在APP文件中加入CoInitialize(NULL);和CoUninitialize();用于初始化COM环境和释放环境

4、建立变量IYTReportAPtr m_YTPrint;

初始化:

m_YTPrint = NULL;

if (FAILED(m_YTPrint.CreateInstance(__uuidof(YTReportA))))

{

MessageBox("清先注册COM","提示");

}

5、程序可以输出双联表和普通模式

普通模式分为正表和反表两种

6、当然程序推出时别忘了释放对象

m_YTPrint.Release();

三、图像

第一个表格使用SetReportHeadA实现

第二个表格使用SetReportHeadB实现

第三个表格使用SetReportHeadC实现

-----------------------------COM接口标示------------------------------------------------

//准备打印

HRESULT PrePrint([out,retval]long *pRet);

----------------------------------------------------------------------------------------

//设置主标题

HRESULT SetTitleA([in]BSTR MyTitle,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//设置副标题

HRESULT SetTitleB([in]BSTR MyTitle,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//strReportHead"列名|对齐方式(m,l,r)|该列宽度(以一个数字的宽度为单位)|..."

//注:该字串最后不以"|"结尾。

HRESULT SetReportHeadA([in]BSTR strReportHead,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//strReportHead:"项目名|项目名|..." (各统计项名称)

// ColWide:统计项对应列的宽度

// ColNum:表格所含列数

//注:字串SubItemName最后不以"|"结尾。

// 采取自动与第一个表宽度对齐的机制。

HRESULT SetReportHeadB([in]BSTR strReportHead,[in]int ColWide,[in]int ColNum,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//相当于反表,数据为一列一列的填

//strReportHead:"行名|行名|..."

// otherColWide:第一列的宽度(写行名的那列)

// ColWide:其它列的宽度

//注:字串strReportHead最后不以"|"结尾。

HRESULT SetReportHeadC([in]BSTR strReportHead,[in]int ColWide,[in]int otherColWide,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//相当于反表,数据为一列一列的填

//strReportHead:"行名|行名|..."

// otherColWide:第一列的宽度(写行名的那列)

// ColWide:其它列的宽度

//注:字串strReportHead最后不以"|"结尾。

HRESULT SetReportHeadD([in]BSTR strReportHead,[in]int ColWide,[in]int otherColWide,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//加入记录

HRESULT AddDetail([in]BSTR strItem,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//写文本,数字,注释等东东

HRESULT WriteText(BSTR strText, long *pRet);

----------------------------------------------------------------------------------------

HRESULT Print([out,retval]long *pRet);

----------------------------------------------------------------------------------------

//设置表的序号

HRESULT SetTableNo([in]BSTR strTableNo,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//强行分页

HRESULT NewPage([out,retval]long *pRet);

----------------------------------------------------------------------------------------

//双联表

HRESULT DrawDoubleTable([in]BSTR strTableOName,[in]BSTR strTableTName,[out,retval]long *pRet);

----------------------------------------------------------------------------------------

//添加制表人

HRESULT SetTableMaker([in] BSTR strTableMaker,[out,retval]long *pRet);

具体的用法请参见程序。希望可以节约大家的一些时间。代码没有限制,可随意使用。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航