java 限制打印次数_java中实现高精度打印(CSDN限制还真多了,事多...)

在CSDN中看到这篇文章,代码比较乱,花了点时间改了一下代码格式,调试运行了一下,效果还不错,感谢作者....      __转自java技术网

在Java环境中,可以使用 java.awt.Toolkit.getScreenResolution()可以得到屏幕每英寸的象素数,但是好像没有什么方法能知道某一台打印机的分辨率,更别提去控制打印粒度了。于是可耻的使用着丑陋的缺省打印精度几年后,终于找到了解决方法,不知道该高兴还是悲伤,其原理说出来也是非常的简单:   提高打印精度,其实就是把本来是A3纸的内容往A4纸里画,也就是说,打印区域(这里对应着Java里的Graphics对象)需要缩小,然后由于缺省情况下打印是照72DPI来打的,不做改变的话,打印内容也会跟着变小。这样就不是我们想要的效果了,所以还得把打印内容成比例放大。一个缩小,一个放大,于是画完后,在指定大小的纸张内,便容纳了比以往更多象素的内容,这下世界总算完美了。   以上做法形象的说应该是这样:把需要产生的图形对象先放大,画在一张“纸上”,然后整体缩小,这样精度就提高了。   tips 1:在一般企业报表表格打印中,使用144DPI得到的表格线的宽度看起来最舒服。   tips 2:现在号称600DPI的打印机其实是576DPI,如果想使用这个分辨率的精度,需要用好一点的纸张,因为已经到极限了,纸张稍差点,打印墨粉就沾不上,导致线体残缺。

附源码(修改分辨率就改动变量iResMul就好):

import java.awt.*;

import java.awt.print.*;

public class MyPrintableObject implements Printable {     public int iResMul = 1; // 1 = 72 dpi; 4 = 288 dpi    public int print(Graphics g,PageFormat pf,int iPage) throws PrinterException {           final int FONTSIZE = 12;           final double PNT_MM = 25.4 / 72.;            if (0 != iPage)               return NO_SUCH_PAGE;           try {                int iPosX = 1; int iPosY = 1;               int iAddY = FONTSIZE * 3 / 2 * iResMul;               int iWdth = (int) Math.round(pf.getImageableWidth() * iResMul) - 3;                int iHght = (int) Math.round(pf.getImageableHeight() * iResMul) - 3;               int iCrcl = Math.min(iWdth,iHght) - 4 * iResMul; Graphics2D g2 = (Graphics2D) g;                PrinterJob prjob = ((PrinterGraphics) g2).getPrinterJob();               g2.translate(pf.getImageableX(),pf.getImageableY());                g2.scale(1.0 / iResMul,1.0 / iResMul);               g2.setFont(new Font("SansSerif",Font.PLAIN,FONTSIZE * iResMul));               g2.setColor(Color.black);               g2.drawRect(iPosX,iPosY,iWdth,iHght);               g2.drawLine(iPosX,iHght / 2 + iWdth / 50,iPosX + iWdth,iHght / 2 - iWdth / 50);               g2.drawLine(iPosX,iHght / 2 - iWdth / 50,iPosX + iWdth,iHght / 2 + iWdth / 50);               g2.drawOval(iPosX + 2 * iResMul,iHght - iCrcl - 2 * iResMul,iCrcl,iCrcl);                iPosX += iAddY; iPosY += iAddY / 2;                g2.drawString("PrinterJob-UserName: " + prjob.getUserName(),iPosX,iPosY += iAddY);                g2.drawString("Betriebssystem: " + System.getProperty("os.name") + " " + System.getProperty("os.version"),iPosX,iPosY += iAddY);               g2 .drawString("Java-Version: JDK " + System.getProperty("java.version"),iPosX,iPosY += iAddY);               g2.drawString("Width/Height: " + dbldgt(pf.getWidth()) + " / " + dbldgt(pf.getHeight()) + " points = " + dbldgt(pf.getWidth() * PNT_MM) + " / " + dbldgt(pf.getHeight() * PNT_MM) + " mm",iPosX,iPosY += iAddY);               g2.drawString("Imageable Width/Height: " + dbldgt(pf.getImageableWidth()) + " / " + dbldgt(pf.getImageableHeight()) + " points = " + dbldgt(pf.getImageableWidth() * PNT_MM) + " / " + dbldgt(pf.getImageableHeight() * PNT_MM) + " mm",iPosX,iPosY += iAddY);               g2.drawString("Imageable X/Y: " + dbldgt(pf.getImageableX()) + " / " + dbldgt(pf.getImageableY()) + " points = " + dbldgt(pf.getImageableX() * PNT_MM) + " / " + dbldgt(pf.getImageableY() * PNT_MM) + " mm",iPosX,iPosY += iAddY);               g2.drawString("versuchte Druckaufl sung: " + 72 * iResMul + " dpi", iPosX,iPosY += iAddY);           } catch (Exception ex) {                     throw new PrinterException(ex.getMessage());                  }              return PAGE_EXISTS;      }     private static double dbldgt(double d) {             return Math.round(d * 10.) / 10.; // show one digit after point       }      public static void main(String[] args) {          PrinterJob pj = PrinterJob.getPrinterJob();          pj.setPrintable(new MyPrintableObject());         if (pj.printDialog()) {            try {                 pj.print();             } catch (PrinterException e) {                  System.out.println(e);                  }           }     } }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值