因为考虑各个电脑的安全配置问题,有些电脑不一定允许安装ActiveX控件,
另外刚开始用户使用时,点了打印没有反应,搞得我很郁闷,后来在我电脑上测试时发现需要弹出一个窗口确认打印的页数,就在想是不是被浏览器拦截了,看了一下,果然是这样,去掉拦截就好了。
所以使用ActiveX模式一开始就被排除了。
因为公司电脑都装了PDF(因为国外客人给的订单,有很大一部分用的PDF,老外的习惯就是不一样),所以后来用pdf模式,发现也会有窗口弹出,没办法,只好一台电脑一台电脑设置了!
再后来发现,纯粹打印时有些多余步骤, 先是预览,然后点打印,然后选择页数(这个页面完全是多余的,因为在pdf中打印的时候,也可以选择页数,难道是水晶报表怕页数较多,导出pdf时耗用较多的资源?),然后预览到了PDF,然后再点打印,再选择打印机,SHIT,最后才能打印出来。
于是想了个办法,用报表直接导出PDF,然后重定向到这个PDF,这样省去了就可以那个选择页数的页面,这里还有个更好的地方,就是不用担心有弹出窗口而造成拦截了。
但这样也有一个缺点,就是如果要导出成excel,就没法了。。所以要看情况而定用哪种方式了。
相关代码如下:
PickGoodsInfo cr = new PickGoodsInfo();
DataSet ds = 查询过程省略
cr.SetDataSource(ds);
//目的路径
string DownloadFilePath = xxxxxxxxxxx
cr.ExportToDisk(CrystalDecisions.Shared.ExportFormatType.PortableDocFormat, DownloadFilePath);
string[] webnet=new string[Context.Request.Url.Segments.Length-1];
Array.Copy (Context.Request.Url.Segments,webnet ,Context.Request.Url.Segments.Length-1);
string path = Context.Request.Url.Scheme + "://" + Context.Request.Url.Authority + string.Join("", webnet) + "rpt/" + "xxxx.PDF";
Response.Redirect(path);