RDLC报表WEB页面中斜线消失之解决方法

版本:VS2005

使用水晶报表的人经常会感慨,这么强的报表工具,连个斜线也没有,太不可理解了。
就这么个小效果,折腾坏不少人。
而VS2005里的RDLC工具,是有斜线的,但是当放到WEB应用时,模板上画得好好的,运行起来后,斜线消失了?


简单分析一下HTML代码 (框架内的报表部分)

 

  1 
  2  < DIV  style ="overflow:auto;HEIGHT:100%;WIDTH:100%"  ID ="oReportDiv"  onscroll ="ShowFixedHeaders()"
  3  onresize ="ShowFixedHeaders()" >
  4       < TABLE  CELLSPACING ="0"  CELLPADDING ="0" >
  5           < TR >
  6               < TD  ID ="oReportCell"  onpropertychange ="ShowFixedHeaders()" >
  7                   < DIV  class ="a1" >
  8                       < TABLE  CELLSPACING ="0"  CELLPADDING ="0"  BORDER ="0"  COLS ="12"  LANG ="zh-CN"
  9                      class ="r10" >
 10                           < TR >
 11                               < TD  style ="HEIGHT:10.00mm;WIDTH:25.00mm" >
 12                               </ TD >
 13                               < TD  style ="WIDTH:5.00mm" >
 14                               </ TD >
 15                               < TD  style ="WIDTH:7.50mm" >
 16                               </ TD >
 17                               < TD  style ="WIDTH:2.50mm" >
 18                               </ TD >
 19                               < TD  style ="WIDTH:5.00mm" >
 20                               </ TD >
 21                               < TD  style ="WIDTH:37.69mm" >
 22                               </ TD >
 23                               < TD  style ="WIDTH:9.93mm" >
 24                               </ TD >
 25                               < TD  style ="WIDTH:4.88mm" >
 26                               </ TD >
 27                               < TD  style ="WIDTH:2.55mm" >
 28                               </ TD >
 29                               < TD  style ="WIDTH:12.45mm" >
 30                               </ TD >
 31                               < TD  style ="WIDTH:22.51mm" >
 32                               </ TD >
 33                               < TD  style ="WIDTH:24.95mm" >
 34                               </ TD >
 35                           </ TR >
 36                           < TR  VALIGN ="top" >
 37                               < TD  COLSPAN ="5"  style ="HEIGHT:2.50mm" >
 38                               </ TD >
 39                               < TD  ROWSPAN ="3"  COLSPAN ="2" >
 40                                   < v:group  coordsize ="100,100"  coordorigin ="0,0"  style ="WIDTH:47.62mm;HEIGHT:19.84mm" >
 41                                       < v:line  from ="0,0"  to ="100,100"  strokecolor ="#0"  strokeWeight ="1pt" >
 42                                           < v:stroke  dashstyle ="solid"   />
 43                                       </ v:line >
 44                                   </ v:group >
 45                               </ TD >
 46                               < TD  ROWSPAN ="3"  COLSPAN ="5" >
 47                               </ TD >
 48                           </ TR >
 49                           < TR >
 50                               < TD  COLSPAN ="5"  style ="HEIGHT:12.50mm" >
 51                               </ TD >
 52                           </ TR >
 53                           < TR >
 54                               < TD  COLSPAN ="5"  style ="HEIGHT:4.84mm" >
 55                               </ TD >
 56                           </ TR >
 57                           < TR >
 58                               < TD  COLSPAN ="12"  style ="HEIGHT:5.16mm" >
 59                               </ TD >
 60                           </ TR >
 61                           < TR  VALIGN ="top" >
 62                               < TD  COLSPAN ="2"  style ="HEIGHT:10.00mm" >
 63                               </ TD >
 64                               < TD  COLSPAN ="8" >
 65                                   < TABLE  CELLSPACING ="0"  CELLPADDING ="0"  LANG ="zh-CN" >
 66                                       < TR >
 67                                           < TD  style ="WIDTH:82.54mm;word-wrap:break-word;HEIGHT:10.00mm;"  class ="a8" >
 68                                              xxxx
 69                                           </ TD >
 70                                       </ TR >
 71                                   </ TABLE >
 72                               </ TD >
 73                               < TD  COLSPAN ="2" >
 74                               </ TD >
 75                           </ TR >
 76                           < TR >
 77                               < TD  COLSPAN ="12"  style ="HEIGHT:5.00mm" >
 78                               </ TD >
 79                           </ TR >
 80                           < TR >
 81                               < TD  style ="HEIGHT:12.54mm" >
 82                               </ TD >
 83                               < TD  COLSPAN ="10"  style ="border-width:0px;border-top:1pt Solid Black" >
 84                               </ TD >
 85                               < TD >
 86                               </ TD >
 87                           </ TR >
 88                           < TR  VALIGN ="top" >
 89                               < TD  COLSPAN ="4"  style ="HEIGHT:9.88mm" >
 90                               </ TD >
 91                               < TD  ROWSPAN ="2"  COLSPAN ="5" >
 92                                   < v:group  coordsize ="100,100"  coordorigin ="0,0"  style ="WIDTH:60.05mm;HEIGHT:17.46mm" >
 93                                       < v:line  from ="0,100"  to ="100,0"  strokecolor ="#0"  strokeWeight ="1pt" >
 94                                           < v:stroke  dashstyle ="solid"   />
 95                                       </ v:line >
 96                                   </ v:group >
 97                               </ TD >
 98                               < TD  ROWSPAN ="2"  COLSPAN ="3" >
 99                               </ TD >
100                           </ TR >
101                           < TR >
102                               < TD  COLSPAN ="4"  style ="HEIGHT:7.58mm" >
103                               </ TD >
104                           </ TR >
105                           < TR >
106                               < TD  COLSPAN ="12"  style ="HEIGHT:7.50mm" >
107                               </ TD >
108                           </ TR >
109                           < TR >
110                               < TD  COLSPAN ="12"  style ="HEIGHT:30.00mm" >
111                               </ TD >
112                           </ TR >
113                       </ TABLE >
114                   </ DIV >
115               </ TD >
116               < TD  WIDTH ="100%"  HEIGHT ="0" >
117               </ TD >
118           </ TR >
119           < TR >
120               < TD  WIDTH ="0"  HEIGHT ="100%" >
121               </ TD >
122           </ TR >
123       </ TABLE >
124  </ DIV >
125 

 

我们看到线是用VML来绘制的

 

  < v:group  coordsize ="100,100"  coordorigin ="0,0"  style ="WIDTH:47.62mm;HEIGHT:19.84mm" >
                                    
< v:line  from ="0,0"  to ="100,100"  strokecolor ="#0"  strokeWeight ="1pt" >
                                        
< v:stroke  dashstyle ="solid"   />
                                    
</ v:line >
                                
</ v:group >

但是,页面上却少了让页面解析VML标签的声明
v/:* {behavior:url(#default#VML);}

于是解决思路就有了,主动在页面上附加上这个声明。
实际做起来就比较复杂,因为表面上RDLC页面是内嵌了一个iframe,实际上套了frame后又嵌了个iframe.
反正挺折腾人,解决方法如下

1:新建一个x.css,放在同目录下
内容为:v/:* {behavior:url(#default#VML);}

2:在aspx的html模式下,加上如下代码即可。

< script language = " javascript "  type = " text/javascript " >
try {
var  oWindow  =  document.getElementById( ' ReportFrameReportViewer1 ' ).contentWindow ;
var  oHead = oWindow.document.getElementsByTagName( ' frame ' )[ 1 ].contentWindow.document.getElementsByTagName( ' head ' ).item( 0 );
var  cssRef = oWindow.document.getElementsByTagName( ' frame ' )[ 1 ].contentWindow.document.createElement( " link " ); 
cssRef.setAttribute(
" rel " " stylesheet " ) ;
cssRef.setAttribute(
" type " " text/css " );
cssRef.setAttribute(
" href " " x.css " );
oHead.appendChild(cssRef);
oWindow.document.getElementsByTagName(
' frame ' )[ 1 ].contentWindow.document.body.innerHTML = oWindow.document.getElementsByTagName( ' frame ' )[ 1 ].contentWindow.document.body.innerHTML;
}
catch  (err)
{
}
< / script>

 

 

加上这个后,发现了另外一个问题,就是如果线有交叉,那么就只显示一条。
比如我们的模板是这样的(图比较丑,只是做个示例)

显示出来的效果是这样的


模板有4条斜线,实际上只显示了两条。
而他的HTML 代码就是本文最开始的那段。
明显是少了两条,经过试验,如果两条线有交叉
(不一定是视觉上的交叉,
交叉应该是以一条线为对角线,所在的矩形,与另一矩形有任何的交叉,都将会只显示一个矩形)


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
本DataGridView打印控件和.NET打印控件5.5版(含报表模板设计组件)2014年2月8日修改完成,完全免费,在.NET2.0及以上环境下都可以使用(VB打印、C#打印都是可以的),有帮助文档与使用实例。 与上一版本的5.4版相比,新控件5.5版的主要更改如下: 1、对控件进行了完善,DGVPrint、VB2008Print、EasyReport组件的打印预览速度有较大的提升; 2、VB2008Print与EasyReport添加了二维码打印的功能,该功能使用开源的Zxing.NET实现; 3、添加了DrawDGVEx函数,一方面可以以DGVprint对象的参数在VB2008Print组件打印,另一方面提供了并排打印多个表格的重载函数; 4、DGVPrint组件添加了报表头与报表尾内容的设置属性和参数; 5、DGVPrint与VB2008Print组件在以工资条方式打印表格时,添加了是否自动换行续打的功能(即,如果工资条列太多在一行打印不下时,可以指定自动换行续打); 6、修改了EasyReport组件的设计界面,每个区域的属性放在属性窗口显示; 7、EasyReport组件添加了简单的多栏打印支持功能; 8、VB2008Print组件添加了PrintDGVFixedWidth函数,方便将DataGridView按指定宽度进行打印; 9、去掉了网页打印功能(因为在IE11下没法使用,所以干脆去掉),去掉了打印RDLC报表的功能; 10、其他一些完善,比如在导出Excel时,如果Columheader不可见,则不导出;解决了快速导出Excel时部分特殊列没有表格线问题(比如是数值列,但使用了%等格式);VB2008Print组件添加了PageScale可以指定打印时的缩放比例等等。 本控件特色: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印)打印DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,基本上做到了所见即所得的打印。 2、报表设计功能。报表模板设计组件EasyReport与WebEasyReport组件可以设计普通报表、分组报表、套打模板等,分别以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、强大的图表打印功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在打印控件打印出来,也可以在Graphics对象显示。 4、分组汇总打印DataGridVeiw功能,每组还可以自动换新页打印,还可以自动增加行号。 5、强大的文本打印输出功能,控件提供多个文本打印重载函数,打印文本时,如果需要,控件会自动换行和换页打印输出。还增加了以指定行间距及字符间距打印文本的功能,可以用固定行距,也可以用单倍或多倍行距打印文本。 6、强大的绘图功能,基本上.NET的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 7、支持同一文档多种版面格式打印(类似于Word的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边 距),只需要在新增一页时在NewPage方法指定要使用的页面格式即可,使用非常简单。 8、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 9、Excel导出功能,可以将DataGridView和GridView导出为Excel文件,5.2版控件还增加了不依赖Office的导出Excel功能,而且速度非常快,5.4版还增加了合并单元格的导出功能。 10、打印DataGridView时的打印方案保存与读取功能。可以将当前打印参数保存为打印方案文件,或者从保存的打印方案文件读取打印参数。 11、水印打印功能。根据需要,可以在页面打印或不打印以半透明空心文字打印水印。 12、强大的容器控件打印功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件设计好要打印的内容及打印内容的相对位置,控件轻松帮你打印出来(如果超过一页,控件会自动换页续打)。 13、特殊文字效果打印功能。控件具有打印浮雕文字、阴影文字、空心文字、块文字的功能。 14、页眉页脚既可打印文字,也可打印图像,或者即打印图像又打印输出文字。 15、图像与图标打印输出功能。 16、多表头(跨行跨列的复杂表头)打印功能,多表头组件支持多表头显示与打印、单元格内容的合并显示、打印与导出。 17、自定义纸张支持功能。 18、纸张背景图片设置打印功能。 19、.NET4.0支持功能(是单独的一个文件) 20、直接打印窗口的TreeView控件功能 21、打印窗口的ListView功能。 22、RichTextBox控件的RTF文本打印功能。 23、斜线表头打印功能(5.4版新增)。 24、二维码打印功能(5.5版本增加)。 我将持续改进该控件,并将不断推出控件的新版本,要查看或下载控件的升级版本,请登陆网站:http://myyouping.download.csdn.net/ 。具体使用方法请参见帮助文件与实例文件,如有疑问或好的建议,请与我联系: 邮箱:[email protected] Q Q:479781502
在WinForms使用RDLC报表的教程如下: 1. 添加RDLC报表控件:在Visual Studio打开你的WinForms项目,找到“工具箱”窗口,在其找到“Reporting”部分,右键点击并选择“选择项”。在弹出的对话框,勾选“Microsoft.ReportViewer.WinForms”并点击确定。然后将“ReportViewer”控件拖放到你的窗体上。 2. 创建RDLC报表:在解决方案资源管理器右键点击你的项目,选择“添加”->“新建项”,然后选择“报表”模板。在弹出的对话框选择“报表向导”,按照向导的指引来创建你的RDLC报表。 3. 设计RDLC报表:在报表设计器,你可以定义报表的布局、数据源和数据绑定。你可以使用表格、图表、文本框等控件来展示数据。在设计完报表后,保存并关闭报表设计器。 4. 加载数据到RDLC报表:在你的WinForms窗体,你可以通过代码来加载数据到RDLC报表。首先,创建一个数据源,可以是DataTable或者其他集合类型。然后,创建一个ReportDataSource对象,并将数据源赋值给它的Value属性。最后,将ReportDataSource对象添加到ReportViewer控件的LocalReport对象的DataSources集合。 5. 显示RDLC报表:在代码,使用ReportViewer控件的Refresh方法来刷新报表数据,并调用RefreshReport方法来显示报表。 这些是使用RDLC报表的基本步骤,你可以根据具体需求进一步定制和扩展报表功能。希望对你有帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值