在打印报表的时候经常会用到分页,本文的报表是连续的多个报表按顺序排列的,其中每个报表由三部分组成,第一部分是一个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 ......");