右边很不齐,于是回到水晶报表10程序中调rpt,很快,把文本的对齐方式设为两端对齐就好了,效果非常的棒,跟word一样。再保存,重编译,显示,结果有所变化,但变化不大,还是不齐。
接着,试着直接导入rpt,结果发现居然不能设置两端对齐,——根本就没有两端对齐,在vs .net环境里面,即使强制把两端对齐按钮添上工具栏,也是灰的。
于是,我便打算在动态加载时,即在将ReportDocument对象赋给报表对象前,对该文本字段用程序方式控制对齐方式。结果发现:还真不是一般的难,瞎试没结果,手上的章立民的《用实例学Crystal Report》仍然没用。很难得到字段的引用,最后终于搞定,我对cr的对象结构也有了一点点的进一步了解:
水晶报表在.Net中,主要的命名空间,一个是CrystalDecisions.CrystalReports.Engine,一个是CrystalDecisions.Shared。
ReportDocument的主要成员,一个是Tables集合,就是这个报表相关的表的集合,顺着它可以找到字段,以及每个字段被引用的次数。这个对我来说没有用,我只想控制已经加入到报表中的字段。
ReportDocument的另一个成员DataDefinition看起来很像,不过它的成员什么都有,就是没有Field对象,也不行。
最后,还是在命名空间CrystalDecisions.CrystalReports.Engine中乱看,看到FieldObject,顺藤摸瓜,才算找到,原来是这样的:报表由很多的ReportObject组成,而FieldObject派生自它,要获得ReportObject,需要用ReportDocument.ReportDefinition.ReportObjects[FieldName]来获得引用,再强制转换成FieldObject即可。
不过问题在于,FieldName并非形如“t1.a1”这样的表达方式,而是“a11”,可以是为了应付多次引用吧。下面是调试时看到的一些东西。
终于可以控制字段了,试试
ReportDocument rd=new ReportDocument();
rd.Load (this.Server.MapPath("\\rpt")+"\\公文.rpt");
rd.SetDataSource(XmlPage.GetDataSet( Session["Gw_GwXml"].ToString(),"FlowData"));
FieldObject field=(FieldObject)rd.ReportDefinition.ReportObjects["a51"];
field.ObjectFormat.HorizontalAlignment=CrystalDecisions.Shared.Alignment.LeftAlign ;
Session["Gw_rd"]=rd;
cr1.ReportSource=rd;
rd.Load (this.Server.MapPath("\\rpt")+"\\公文.rpt");
rd.SetDataSource(XmlPage.GetDataSet( Session["Gw_GwXml"].ToString(),"FlowData"));
FieldObject field=(FieldObject)rd.ReportDefinition.ReportObjects["a51"];
field.ObjectFormat.HorizontalAlignment=CrystalDecisions.Shared.Alignment.LeftAlign ;
Session["Gw_rd"]=rd;
cr1.ReportSource=rd;
结果发现,设置左对齐,右对齐都好的,但两端对齐Justify却跟原来一样。才觉悟过来:问题并不出在报表上,而是在于网页的显示方式的限制,在两端对齐的方式下,查看显示的网页,可以看到:
原来它也只是利用CSS来进行两端对齐的。这种对齐方式,不能得到很完美的效果,——至少不可能达到想word或者报表系统本身这样的本地应用程序达到的效果。网上找了找,有些相应的解决办法,如
http://blog.netbei.com/1/722/archives/2005/2178.shtml提到加一个text-justify=distribute;的方法,不过也就那样吧。
罗罗嗦嗦,实在是这个东西费了我半天功夫,直接过去未免可惜,是为记。