c# Winform 用到的一个打印控件(VBprinter.DGVprint)。

给大家分享一个挺好用的打印控件。dll等下上传到资源里边。

新手可以看看

12-13补充

这个dll里边有好几个打印控件,刚知道。

有一个比这更更好用的,我把代码放到最后



  1. private void tabControl1_Click(object sender, EventArgs e)  
  2.        {  
  3.            if (tab.SelectedTab.Text == "打印预览")  
  4.            {  
  5.                myp.PageUnits = VBprinter.VB2008Print.PageExportUnit.CentiMeter;  
  6.                myp.IsImmediatePrintNotPreview = false;  
  7.                myp.IsUseDGVPadding = false;  
  8.                myp.CellMargin = new System.Drawing.Printing.Margins(10, 20, 10, 10);  
  9.   
  10.                myp.InvalidatePreview();  
  11.                tab.SelectedIndex = 1;  
  12.            }  
  13.        }  
  1. //打印预览  
  2. private void myp_PrintDocument()  
  3. {  
  4.     DataGridView newdgv = new DataGridView();  
  5.     myp.CopyDataGridView(dgvsource, newdgv, false);  
  6.     newdgv.GridColor = Color.Black;  
  7.     //打印处理过程  
  8.     myp.IsNeedCheckNewPage = false;  
  9.     System.Drawing.Printing.Margins mymargin;  
  10.     mymargin = new System.Drawing.Printing.Margins();  
  11.     mymargin.Left = Convert.ToInt32(myp.ConvertInchToCm(45));  
  12.     mymargin.Right = Convert.ToInt32(myp.ConvertInchToCm(45));  
  13.     mymargin.Top = Convert.ToInt32(myp.ConvertInchToCm(80));  
  14.     mymargin.Bottom = Convert.ToInt32(myp.ConvertInchToCm(45));  
  15.     myp.NewPage(System.Drawing.Printing.PaperKind.A4, mymargin, false);  
  16.     mymargin.Top = 20;  
  17.     //先打印表头内容  
  18.     Font f1 = new Font("黑体", 18, FontStyle.Bold);  
  19.     Font f2 = new Font("黑体", 14, FontStyle.Bold);  
  20.     Font f3 = new Font("宋体", 12);  
  21.     Font f4 = new Font("华文行楷", 12);  
  22.     string ss;  
  23.     ss = "自来水公司\n欠费查询表";  
  24.     myp.DrawTitle(ss, f1, Color.Black, 0);  
  25.     myp.NewRow(60);  
  26.     float rowheight;  
  27.     rowheight = 70;  
  28.     //float mywidth;  
  29.   
  30.     myp.NewRow(rowheight);  
  31.     ss = "制表时间:" + System.String.Format("{0:f}", System.DateTime.Now);  
  32.   
  33.     myp.DrawText(ss, myp.PaperPrintWidth, rowheight, f4, StringAlignment.Far, StringAlignment.Center, falsetruefalsefalse, 6, 0);  
  34.   
  35.     myp.NewRow(rowheight);  
  36.     //正式开始打印表格  
  37.     rowheight = 60;//表格要打印的行高  
  38.     bool needprintheader = true;  
  39.     for (int i = 0; i < dgvsource.RowCount; i++)  
  40.     {  
  41.         if (needprintheader == true)  
  42.         {  
  43.             //打印表格头  
  44.             if (i != 0)  
  45.             {  
  46.   
  47.                 //不是第一页,需要打印标题行                     
  48.                 ss = "自来水公司\n欠费查询表";  
  49.                 myp.DrawTitle(ss, f1, Color.Black, 0);  
  50.                 ss = "" + "\n" + "\n";  
  51.                 myp.DrawTitle(ss, f2, Color.Black, 0);  
  52.                 myp.Currenty = myp.Currenty + 30;//留一点空白  
  53.   
  54.             }  
  55.             //再打印表格列标题 行  
  56.             myp.DrawDGVHeader(newdgv, rowheight, truetrue"1111", 6);  
  57.             needprintheader = false;  
  58.   
  59.         }  
  60.   
  61.         if (myp.IsNewPage(rowheight) == true)  
  62.         {  
  63.             //需要换页  
  64.             myp.NewPage(System.Drawing.Printing.PaperKind.A4, mymargin, false);  
  65.             needprintheader = true;  
  66.             i = i - 1;  
  67.   
  68.         }  
  69.         else  
  70.         {  
  71.             //打印当前行  
  72.             myp.DrawDGVRow(newdgv, i, rowheight, truefalse"1111", 6);  
  73.   
  74.         }  
  75.     }  
  76.     //以下开始打印表尾  
  77.     float footerheight = 700;//表尾要打印的高度,下面打印的内容不能超过这个高度  
  78.     if (myp.IsNewPage(footerheight) == true)  
  79.     {  
  80.         //说明表尾要不能全部打印下去,先换页  
  81.         myp.NewPage(System.Drawing.Printing.PaperKind.A4, mymargin, false);  
  82.     }  
  83.   
  84.     newdgv.Dispose();  
  85.     newdgv = null;  
  86. }  




  1. public List<string> columns(DataGridView dgv)  
  2.        {  
  3.            string columnsname = "";  
  4.            string columns = "";  
  5.            List<string> columnlist = new List<string>();  
  6.            for (int i = 0; i < dgv.Columns.Count; i++)  
  7.            {  
  8.                //Type type = dt.Columns[i].DataType;  
  9.                columns = dgv.Columns[i].HeaderCell.Value.ToString();  
  10.                //columnsname = dgv.Columns[i].HeaderCell.Value.GetType().ToString();  
  11.                columnsname = dgv.Columns[i].ValueType.ToString();  
  12.                if (columnsname != "System.String")  
  13.                {  
  14.                    //columns = dgv.Columns[i].ToString(); ;  
  15.                    columns = dgv.Columns[i].HeaderCell.Value.ToString();  
  16.                    if (columnsname == "System.DateTime")  
  17.                    {  
  18.                        continue;  
  19.                    }  
  20.                    if (columnsname != "System.String")  
  21.                    {  
  22.                        columns = dgv.Columns[i].HeaderCell.Value.ToString();  
  23.                        columnlist.Add(columns);  
  24.                    }  
  25.                }  
  26.            }  
  27.            return columnlist;  
  28.        }  
  29.        VBprinter.DGVprint dgvprint4 = new VBprinter.DGVprint();  
  30.        private void button6_Click(object sender, EventArgs e)  
  31.        {  
  32.            dgvprint4.MainTitle = treeView1.Nodes[0].Text + "\n" + "用户档案修改报表";  
  33.            //dgvprint4.MainTitle = "";//分组打印测试(3.5版新功能)按联系人姓名分组汇总邮政编码列,每组连续打印,且添加行号,行号每组从1开始重新编号  
  34.   
  35.            dgvprint4.SubTitle = textBox1.Text;//"您还可以改为分栏打印或跨页打印工资条打印试试,怎么样,本功能够强大吧";  
  36.            dgvprint4.Alignment = StringAlignment.Center;//'表格居中  
  37.            dgvprint4.PrintType = VBprinter.DGVprint.mytype.MulPagesPrint;  //'普通表格VBprinter.DGVprint.mytype.GeneralPrint;   
  38.            //dgvprint4.TableFooterLeft = "表格页脚内容(左边)";  
  39.            //dgvprint4.TableFooterMiddle = "表格脚眉内容(中边)";  
  40.            //dgvprint4.TableFooterRight = "表格页脚内容(右边)";  
  41.            //dgvprint4.SortColumn = "用水量";// '只能有一列(注意,此处是列的名称而不是显示的名称)  
  42.            //dgvprint4.GroupColumn = "用水量";// '只能有一列(注意,此处是列的名称而不是显示的名称)  
  43.            // s[0] = "户数"; s[1] = "计费水量"; s[2] = "上期滞纳金"; s[3] = "应收水费"; s[4] = "实用数"; s[5] = "应收费用"; s[6] = "其它费用"; s[7] = "合计"; s[8] = "水损";  
  44.            List<string> list = columns(dgvsource);  
  45.            string sumcolumns = "";  
  46.            foreach (string item in list)  
  47.            {  
  48.                sumcolumns += item + ";";  
  49.            }  
  50.            dgvprint4.SumColumns = sumcolumns;// '如果要汇总多列的话,可用英文的分号连接起来(注意,此处是列的名称而不是显示的名称)  
  51.   
  52.            dgvprint4.GroupNewPage = false;// '每组连续打印  
  53.            dgvprint4.IsAddRowID = true;// '添加行号  
  54.            dgvprint4.IsGroupNewRowID = true//'新组行号从1开始重新编号  
  55.            dgvprint4.PaperLandscape = false//'纵向打印  
  56.            dgvprint4.Print(dgvsource, true);// '也可用dgvprint1.print(d1,true),此时会显示一个打印参数设置窗口  
  57.        }  
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本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/ 。具体使用方法请参见帮助文件与实例文件,如有疑问或好的建议,请与我联系: 邮箱:myyouping@139.com Q Q:479781502

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值