首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > .NET >

【水晶报表内功心法】-信手拈来,掌控对象,该如何解决

2012-04-07 
【水晶报表内功心法】--信手拈来,掌控对象索引 .【水晶报表内功心法】--序言 .【水晶报表内功心法】--推拉之间.【

【水晶报表内功心法】--信手拈来,掌控对象
索引

.【水晶报表内功心法】--序言

.【水晶报表内功心法】--推拉之间

.【水晶报表内功心法】--PULL模式样板招式

.【水晶报表内功心法】--PUSH模式样板招式
============================================================ 

月初一如既往地忙碌,竟然一点时间也没抽出来。
周末也是一如既往地加班了,好在事情进展地还算顺利,终于有时间写这一篇。

本来的计划是《掌控于股掌之间-代码中传参数、传公式、操作水晶报表里的所有对象》
考虑到公式的重要性,会单独写一篇,于是本篇的内容就是参数与对象的控制
而参数的部分,在本篇也是基本操作,后续的进阶操作会结合其他环节进一步说明

1.对象的操作


开始之前

先说一下,操作对象,是依靠ReportDocument,
基础代码如下:

C# code
ReportDocument myReport = new ReportDocument();string reportPath = Server.MapPath("crystalreport1.rpt");myReport.Load(reportPath);//PULL或PUSH方式的数据处理//... CrystalReportViewer1.ReportSource = myReport;//然后,才是下文中的代码


关于水晶报表里的对象,我们直观的来看一下。
在模板空白处点邮件,选“插入”,鼠标放到“特殊字段”上,不要点,会出现如下菜单。

上面这些,都是报表对象或说是报表部件。恩,这些我们都可以进行控制。

操作的基本语法是:
C# code
myReport.ReportDefinition.ReportObjects[对象序号].方法或属性;//或myReport.ReportDefinition.ReportObjects[对象名称].方法或属性;


对象序号在 .Net的水晶报表版本里很难直观的看出来,一般他是按加入报表的顺序来排的
这个很难去记住。有时候为了一些需要,在遍历的时候会用的到。
一般我们会用名称。
在对象上点右键,设置对象格式,

在出来的界面上就可以看到对象的名称

ReportObjects就是我们前面所指的报表对象集合,单一对象就是一个ReportObject
对于ReportObject来说,通用的属性有这样一些

一般我们可以控制对象的位置,通过控制左上角的坐标,也就是top和left属性。
这里说一下水晶报表的坐标系和计量单位。

水晶报表的坐标系,以每个节的左上角为原点,往下往右两个方向递增延展。
计量单位是缇,与厘米的换算关系是:1厘米=567缇
所以在后面的代码中,你会看到我有这样的写法: 567*N 其实也就是N厘米。

另外还有ObjectFormat下面的属性,可以控制对象的隐藏与显示,这个很实用吧,呵呵。


如抑制显示可以这样操作:
C# code
myReport.ReportDefinition.ReportObjects("text4").ObjectFormat.EnableSuppress = true;


ReportObject是个通用对象,而其实际上又是一个具体的对象。他有各自的特殊属性。
以文本框为例,他就会多出一些特性,比如Text属性,这样我们可以修改到文本框的内容。

具体操作如下:
C# code
//更改一个文本框的内容TextObject x;x = (TextObject)myReport.ReportDefinition.ReportObjects["text4"];x.Text = "我们的世界";


另外说一下,前面没提到的数据字段,也可以这样操作。

C# code
//调整字段的位置FieldObject fo;fo = (FieldObject)myReport.ReportDefinition.ReportObjects["NAME1"];fo.Height = 567 * 3;fo.Width = 567 * 4;fo.Left = 567 * 1;


每个对象都有各自不同的属性,至于具体有多少对象,你可以按一下F2,
在CrystalDecisions.CrystalReports.Engine这个命名空间下,以 Object结尾的,基本都是。


2:子报表里对象的操作
子报表里的对象操作跟主报表是一样的,主要是要先找到这个子报表对象。

下面这个方法是不对的
C# code
SubreportObject subObj;subObj = (SubreportObject)myReport.ReportDefinition.ReportObjects["subreport1"];
这个只会定义子报表在主报表内的特性,不能设置到子报表内的部件

要这样
C# code
myReport.Subreports[子报表序号].ReportDefinition.ReportObjects["xx"];//序号从0开始计数,单纯子报表的一个序号//或myReport.Subreports[子报表名称].ReportDefinition.ReportObjects["xx"];

注意这个名称不是我们在子报表上点右键看到的名称,而是我们在设计子报表时指定的子报表名称



C# code
TextObject subtext;subtext = (TextObject)myReport.Subreports["xyz"].ReportDefinition.ReportObjects["text3"];subtext.Text = "我是子报表里的内容哦"; 


   
3:参数的基本操作
参数是程序与报表交互的一个重要媒介,本节只做一个基础说明,后续的章节中会进一步介绍。
新建一个参数p1



拖到模板上,会自动显示为 ?pa1


代码中传递参数给报表的代码为:
SetParameterValue 后面的几个参数依次为:参数名称,参数值,子报表名称(如果是子报表参数的话)。
C# code
myReport.SetParameterValue("pa1", "我是一个参数");


在子报表中建立一个新的参数spa1,注意xyz是子报表名称
C# code
myReport.SetParameterValue("spa1", "我是一个参数","xyz");


当然,参数也可以传递给CrystalreportViewer,这里就不展开说了,用到的时候再说。

单纯从这个代码上来看,textbox和参数似乎可以等价
但是textbox一般只能用于显示一个字符串,但是参数则可以参与公式,过滤数据,控制对象的一些特性等等,用途更广泛一些。


好了,就到这里。这个基本上没有什么需要特别注意的。

修正记录:
20090707:
坐标系原点应该是每个节的左上角,而不是整个模板的左上角

下一篇:如何过滤数据




[解决办法]
这下抢到了!……
[解决办法]
正在学习这个东东,看看。帮顶起
[解决办法]
泰哥,顶
[解决办法]
非常感谢将你的知识和大家分享。。
[解决办法]
强大。。。
[解决办法]
不错,学习一下
[解决办法]
精彩,我自己除了参数对象和导出方法在程序中有用到外,其它的我都是在报表文件中设置好的,没有用程序去控制。
要做出灵活的报表,这些事必须要掌握的
[解决办法]
認真學習!
[解决办法]
探讨
考虑到公式的重要性,会单独写一篇

[解决办法]
好东西
[解决办法]
up
[解决办法]
又来晚了,,,
[解决办法]
占楼学习,谢谢阿泰上次帮我解决了问题.上一篇Push的有点点让我误解了,向Dataset加表应该没有必要去加个table再加列吧,直接从数据库里头一拖就搞定了.
[解决办法]
很好很强大,趁没有结贴赶紧蹭一下分
[解决办法]
探讨
引用:
占楼学习,谢谢阿泰上次帮我解决了问题.上一篇Push的有点点让我误解了,向Dataset加表应该没有必要去加个table再加列吧,直接从数据库里头一拖就搞定了.


我是一步跨进共产主义,呵呵。

如果数据是从单表里出来的,那么自然可以直接拖过来的。不过如果是单表,那么更适合用PULL会更好些。

我这里用手工建的目的,是用这个结构,可以承接任何数据。
比如:

Select a.f1 as f1,b.f2 as f2,a.f7 as f3,a.f4 as f4 from a,b where a.x=b.x

这样一个SQL出来,可以直接对应到一个f1,f2,f3,f4的单表里。

这个做法,也是下面几篇文章的操作基础。
【原创】动态(万能)水晶报表:任意表,任意列,动态格线调整
【原创】水晶报表动态表扩展  之  任意无关联表,任意列,任意数据源 
【原创】水晶报表动态表扩展  之  任意SQL及任意有关联表,任意列  及其他


[解决办法]
探讨
引用:
占楼学习,谢谢阿泰上次帮我解决了问题.上一篇Push的有点点让我误解了,向Dataset加表应该没有必要去加个table再加列吧,直接从数据库里头一拖就搞定了.


我是一步跨进共产主义,呵呵。

如果数据是从单表里出来的,那么自然可以直接拖过来的。不过如果是单表,那么更适合用PULL会更好些。

我这里用手工建的目的,是用这个结构,可以承接任何数据。
比如:

Select a.f1 as f1,b.f2 as f2,a.f7 as f3,a.f4 as f4 from a,b where a.x=b.x

这样一个SQL出来,可以直接对应到一个f1,f2,f3,f4的单表里。



这个做法,也是下面几篇文章的操作基础。
【原创】动态(万能)水晶报表:任意表,任意列,动态格线调整
【原创】水晶报表动态表扩展  之  任意无关联表,任意列,任意数据源 
【原创】水晶报表动态表扩展  之  任意SQL及任意有关联表,任意列  及其他


[解决办法]
学习 多谢阿泰
[解决办法]
学习
[解决办法]
顶,楼主写一本书吧。或者电子书,相信很多人需要的。
[解决办法]
探讨
顶,楼主写一本书吧。或者电子书,相信很多人需要的。

[解决办法]
《掌控于股掌之间-代码中传参数、传公式、操作水晶报表里的所有对象》
期待中。。。。
[解决办法]
探讨
顶,楼主写一本书吧。或者电子书,相信很多人需要的。

[解决办法]
恩 不错 先收藏下
[解决办法]
还有没有,等待中。。。

热点排行