silverlight分页打印报表

在打印报表的时候经常会用到分页,本文的报表是连续的多个报表按顺序排列的,其中每个报表由三部分组成,第一部分是一个label,用于显示报表标题,第二部分是一个label,用于显示报表单位,第三部分是一个datagrid,用于显示数据,

报表截图如下图所示:




现在想实现的功能是每个报表占一页,一次性打印所有的报表。

实现此分页打印的代码如下:

PrintDocument _print = new PrintDocument();
            List<UIElement> uis = new List<UIElement>();
                      
            _print.PrintPage += (s, args) =>
            {
                StackPanel sp = new StackPanel();

                while ( SP_ReportManagement.Children.Count > 0)
                {
                    var ui = SP_ReportManagement.Children[0];
                    SP_ReportManagement.Children.RemoveAt(0);
                    
                    sp.Children.Add(ui);
                    uis.Add(ui);
                    sp.Measure(new Size(double.PositiveInfinity, double.PositiveInfinity));
                                        
                    //当sp中已经包含一个报表或者包含的报表高度大于纸张高度就换页
                    if (sp.Children.Count > 3 || (sp.DesiredSize.Height > args.PrintableArea.Height && sp.Children.Count > 1))
                    {                        
                        sp.Children.Remove(ui);
                        uis.Remove(ui);
                        SP_ReportManagement.Children.Insert(0, ui);
                       
                        args.HasMorePages = true;
                        
                        break;
                    }                  
                }
                args.PageVisual = sp;
            };

            //把删除的报表数据重新加入到SP_ReportManagement
            _print.EndPrint += (s, args) =>
            {
                if (SP_ReportManagement.Children.Count > 0)
                {
                    for (int i = uis.Count() - 1; i >= 0; i--)
                    {
                        //把标题和单位加入
                        if (i % 3 == 0 || i % 3 == 1)
                        {
                            Label ui = (Label)uis.ElementAt(i);
                            ((StackPanel)ui.Parent).Children.Remove(ui);

                            SP_ReportManagement.Children.Insert(0,ui);
                        }
                        //加入dagagrid表格数据
                        else
                        {
                            DataGrid ui = (DataGrid)uis.ElementAt(i);
                            ((StackPanel)ui.Parent).Children.Remove(ui);

                            SP_ReportManagement.Children.Insert(0,ui);
                        }
                    }
                }
                else
                {
                    for (int i = 0;i < uis.Count;i++)
                    {
                        //把标题和单位加入
                        if (i%3==0 || i %3 ==1)
                        {
                            Label ui = (Label)uis.ElementAt(i);
                            ((StackPanel)ui.Parent).Children.Remove(ui);

                            SP_ReportManagement.Children.Add(ui);
                        }
                        //加入dagagrid表格数据
                        else
                        {
                            DataGrid ui = (DataGrid)uis.ElementAt(i);
                            ((StackPanel)ui.Parent).Children.Remove(ui);

                            SP_ReportManagement.Children.Add(ui);
                        }
                        
                    }
                }
               
                uis.Clear();
                
            };


            _print.Print("Report Generating ......");



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值