C#打印源码的具体实现是怎样的

技术C#打印源码的具体实现是怎样的本篇文章给大家分享的是有关C#打印源码的具体实现是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。C#打印源码也是打印

本文就是和大家分享一下C#打印源代码的具体实现。边肖觉得挺实用的,所以分享给大家学习。希望你看完这篇文章能有所收获。让我们和边肖一起看看。

C#打印源代码也是打印控制的功能之一。这里介绍的C#打印源代码可以实现自动打印处理,但是需要mdi文件的支持。

打印的原理是:生成mdi文件,当系统遇到mdi时,会通过打印自动处理。所以,无论使用什么样的模板或方法;在PrintPage的事件处理中生成要打印的内容的图片就可以了!

C#打印源代码如下:

# regionPrint privatevodtnprint _ click(对象发送者,event args e){//打印预览///printpreviewdialogppd=new printpreviewdialog();print document PD=new print document();//设置边距margin=新边距(20,20,20,20);警局。默认页面设置。边距=边距;////纸张设置默认值//paper size page size=new paper size(' first custom size ',800,600);//pd。defaultpage settings . paper size=page size;//打印事件设置PD . Print page=new printpageeventhandler(this . PD _ Print page);//ppd。文档=pd//ppd。ShowDialog();尝试

         {                  pd.Print();              }              catch (Exception ex)              {                  MessageBox.Show(ex.Message, "打印出错", MessageBoxButtons.OK, MessageBoxIcon.Error);                  pd.PrintController.OnEndPrint(pd, new PrintEventArgs());              }          }          //打印事件处理          private void pd_PrintPage(object sender, PrintPageEventArgs e)          {              string date = lblDate.Text; //当前日期              string flowId = lblFlowId.Text; //流水号              string payDate = PayDate.Year.ToString() + "年" + PayDate.Month.ToString() + "月"; //应收年月              string adminId = lblAdminId.Text; //操作员编号              string baseExpense = lblBaseExpense.Text; //应交基本费用              string fine = lblFine.Text; //罚款数目              string upExpense = lblUpExpense.Text; //上月上余              string actualExpense = txtActualExpense.Text; //实际应交费用              string chineseExpense = DecimalToChinese.ConvertSum(actualExpense); //实际应交费用的中文大写      //读取图片模板              Image temp = Image.FromFile(@"Receipts.jpg");              GetResultIntoImage(ref temp, UserId, flowId, date, baseExpense, fine, upExpense, actualExpense, chineseExpense, payDate, adminId);              int x = e.MarginBounds.X;              int y = e.MarginBounds.Y;              int width = temp.Width;              int height = temp.Height;              Rectangle destRect = new Rectangle(x, y, width, height);              e.Graphics.DrawImage(temp, destRect, 0, 0, temp.Width, temp.Height, System.Drawing.GraphicsUnit.Pixel);          }           ///          /// 将收费结果填充到图片模板          ///          private void GetResultIntoImage(              ref Image temp,              string userId,              string flowId,              string currentDate,              string baseExpense,              string fine,              string upExpense,              string actualExpense,              string chineseExpense,              string payDate,              string adminName)          {              //读取图片模板              Graphics g = Graphics.FromImage(temp);               Font f = new Font("宋体", 12);              Brush b = new SolidBrush(Color.Black);                   //填充数据到图片模板(位置要在制作图片模板的时候度量好)              g.DrawImage(temp, 0, 0, temp.Width, temp.Height);              g.DrawString(userId, f, b, 168, 105);              g.DrawString(UserName, f, b, 166, 134);              g.DrawString(flowId, f, b, 535, 105);              g.DrawString(currentDate, f, b, 535, 134);              g.DrawString(baseExpense, f, b, 219, 202);              g.DrawString(fine, f, b, 372, 202);              g.DrawString(upExpense, f, b, 486, 202);              g.DrawString(actualExpense, f, b, 596, 202);              g.DrawString(chineseExpense, f, b, 196, 238);              g.DrawString(payDate, f, b, 176, 269);              g.DrawString(adminName, f, b, 497, 298);               g.Dispose();          }          #endregion

以上就是C#打印源码的具体实现是怎样的,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注行业资讯频道。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/113753.html

(0)

相关推荐

  • SQL如何限制查询结果

    技术SQL如何限制查询结果小编给大家分享一下SQL如何限制查询结果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!SQL查询结果只显示指定的行项

    攻略 2021年11月11日
  • Python中怎么控制from xxx import *导入的成员

    技术Python中怎么控制from xxx import *导入的成员本篇内容介绍了“Python中怎么控制from xxx import *导入的成员”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下

    攻略 2021年11月25日
  • 微信清空聊天记录,手机微信聊天信息如何清屏

    技术微信清空聊天记录,手机微信聊天信息如何清屏1、打开手机,在手机桌面找到微信选项软件,点击进入微信清空聊天记录。2、在微信界面中,点击我选项进入。3、在我界面中,点击设置选项进入。4、在设置界面中,点击聊天选项进入。5

    2021年10月23日
  • 品牌男装排行榜,时尚商务男装品牌排名是

    技术品牌男装排行榜,时尚商务男装品牌排名是男 人 买 衣 服 , 其实只 有三个 字 品牌男装排行榜: 少 而精, 选 择知 名品牌 一般 不会 错。中国十 大知名 时 尚 男装
    1、 九牧 王—— 男裤 及茄 克 已经

    生活 2021年10月20日
  • linux三剑客之grep 文本过滤器

    技术linux三剑客之grep 文本过滤器 linux三剑客之grep 文本过滤器Linux 三剑客之grep
    三剑客之一:grep 定义: 文本过滤器: 根据文本内容过滤文件。语法格式 :grep 参

    礼包 2021年12月21日
  • JavaScript中var与let的区别是什么

    技术JavaScript中var与let的区别是什么本篇文章给大家分享的是有关JavaScript中var与let的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小

    攻略 2021年12月8日