java – 打印到物理形式 – 需要基本的理解
|
我不太确定我理解g.drawString. 我有一个写入预打印表单的程序.用户声称打印是不规则的…即,表单上的文本比先前的打印更高/更低.就个人而言,我认为他们错误地填写了表单,但由于他们付钱给我编写代码,我正在测量表单并将尺寸转换为像素并重写处理打印的部分. 要正确打印表单,c.getCostAmount()必须打印一个像素ABOVE c.getAppraisersAmount(),使其在其下方显示一行.然而,每个后续行低于4mm(或大约15个像素). 我的问题是我不理解垂直距离以及为什么第3行必须放在上一行之上的像素才能使其位于下方. 任何人都有一个快速简单的解释或指向教程/解释的链接? 非常感谢! 代码(h / t Alex,Java: Printing program output to a physical printer): public int print(Graphics g,PageFormat pf,int page,Check c){
final double MILLIMETER_IN_PIXELS = 3.779527559;
DecimalFormat df = new DecimalFormat("$#.00");
if (page > 0) {
return NO_SUCH_PAGE;
}
Graphics2D g2d = (Graphics2D) g;
int x = (int) pf.getImageableX();
int y = (int) pf.getImageableY();
g2d.translate(x,y + .5);
Font font = new Font("Courier New",Font.PLAIN,10);
g2d.setFont(font);
FontMetrics metrics = g.getFontMetrics(font);
g.drawString("CHECK #" + c.getCheckNumber(),((int) MILLIMETER_IN_PIXELS* 55),((int) MILLIMETER_IN_PIXELS*15));
int strWidth = SwingUtilities.computeStringWidth(metrics,df.format(c.getAppraisersAmount()));
g.drawString(df.format(c.getAppraisersAmount()),((int) ((MILLIMETER_IN_PIXELS*62)-strWidth)),((int) MILLIMETER_IN_PIXELS*23));
Date d = c.getJavaDate();
SimpleDateFormat sdf = new SimpleDateFormat("MM/dd/yyyy");
g.drawString(sdf.format(d),((int) MILLIMETER_IN_PIXELS*90),((int) MILLIMETER_IN_PIXELS*24));
strWidth = SwingUtilities.computeStringWidth(metrics,df.format(c.getCostAmount()));
g.drawString(df.format(c.getCostAmount()),((int) (MILLIMETER_IN_PIXELS*22)));
strWidth = SwingUtilities.computeStringWidth(metrics,df.format(c.getRefundsAmount()));
g.drawString(df.format(c.getRefundsAmount()),((int) (MILLIMETER_IN_PIXELS*26)));
strWidth = SwingUtilities.computeStringWidth(metrics,df.format(c.getOfficersAmount()));
g.drawString(df.format(c.getOfficersAmount()),((int) (MILLIMETER_IN_PIXELS*30)));
Double totalLeft = c.getAppraisersAmount() + c.getCostAmount() + c.getRefundsAmount() + c.getOfficersAmount();
strWidth = SwingUtilities.computeStringWidth(metrics,df.format(totalLeft));
g.drawString(df.format(totalLeft),((int) (MILLIMETER_IN_PIXELS*44)));
return PAGE_EXISTS;
}
解决方法我不确定你是如何确定MILLIMETER_IN_PIXELS值的,它对我来说完全是可疑的.但是,令您困惑的错误只是缺少大括号的情况: 您可以使用以下术语:((int)MILLIMETER_IN_PIXELS * 23),((int)MILLIMETER_IN_PIXELS * 24)和((int)(MILLIMETER_IN_PIXELS * 22)). 请注意,前两个术语缺少产品MILLIMETER_IN_PIXELS *周围的大括号…这意味着您首先将MILLIMETER_IN_PIXELS转换为int,得到值3,然后乘以,而不是先执行双乘,然后转换为int. 因此舍入误差是不同的.结果值为69,72,83. 注意,缺少括号的错误也出现在其他地方,水平位置也会受到影响. 作为附录,这里是你如何得到真正的DPI: Point2D p = g2d.getDeviceConfiguration().getDefaultTransform()
.transform(new Point2D.Float(72,72),null);
// normally,both are the same
int horizontalDPI=(int)p.getX(),verticalDPI=(int)p.getY();
说明:默认转换被指定为将72个用户空间像素转换为1英寸的转换,因此在将转换应用于72时,将导致设备像素的数量与1英寸匹配. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
