From 7a0e3b15238043c2e62e93c4faa8f75a191bf80c Mon Sep 17 00:00:00 2001 From: Werner Randelshofer Date: Fri, 13 Sep 2024 17:28:46 +0200 Subject: [PATCH] Fix the aspect ratio of the print. --- .../draw/io/PrinterExportFormat.java | 30 ++++++++++--------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/org.jhotdraw8.draw/src/main/java/org.jhotdraw8.draw/org/jhotdraw8/draw/io/PrinterExportFormat.java b/org.jhotdraw8.draw/src/main/java/org.jhotdraw8.draw/org/jhotdraw8/draw/io/PrinterExportFormat.java index 3e7204f9d..587f90e40 100755 --- a/org.jhotdraw8.draw/src/main/java/org.jhotdraw8.draw/org/jhotdraw8/draw/io/PrinterExportFormat.java +++ b/org.jhotdraw8.draw/src/main/java/org.jhotdraw8.draw/org/jhotdraw8/draw/io/PrinterExportFormat.java @@ -81,35 +81,37 @@ public Paper findPaper(CssDimension2D paperSize) { * Prints a slice of a drawing. * * @param pageSize the page size - * @param worldToLocal The worldToLocal transform of the viewport + * @param worldToLocal The worldToLocal transform of the viewport (in case the viewport is rotated) * @param viewportBounds the bounds of the viewport that we want to print * @param node the rendered node of the slice */ private void printSlice(CssDimension2D pageSize, @Nullable Transform worldToLocal, Bounds viewportBounds, Node node) { Paper paper = findPaper(pageSize); - Dimension2D psize = pageSize.getConvertedValue(); - PageLayout pl = job.getPrinter().createPageLayout(paper, psize.getWidth() <= psize.getHeight() ? PageOrientation.PORTRAIT : PageOrientation.LANDSCAPE, 0, 0, 0, 0); + Dimension2D pgSize = pageSize.getConvertedValue(); + PageLayout pl = job.getPrinter().createPageLayout(paper, pgSize.getWidth() <= pgSize.getHeight() ? PageOrientation.PORTRAIT : PageOrientation.LANDSCAPE, 0, 0, 0, 0); job.getJobSettings().setPageLayout(pl); paper = pl.getPaper(); if (paper == null) { paper = Paper.A4; } double pw, ph; + pw = paper.getWidth(); + ph = paper.getHeight(); if (pl.getPageOrientation() == PageOrientation.LANDSCAPE) { - pw = paper.getHeight(); - ph = paper.getWidth(); - } else { - pw = paper.getWidth(); - ph = paper.getHeight(); + double swap = pw; + pw = ph; + ph = swap; } - double paperAspect = paper.getWidth() / paper.getHeight(); - double pageAspect = viewportBounds.getWidth() / viewportBounds.getHeight(); + double paperAspect = pw / ph; + double vw = pgSize.getWidth(); + double vh = pgSize.getHeight(); + double viewAspect = vw / vh; double scaleFactor; - if (paperAspect < pageAspect) { - scaleFactor = ph / viewportBounds.getHeight(); + if (paperAspect < viewAspect) { + scaleFactor = pw / vw; } else { - scaleFactor = pw / viewportBounds.getWidth(); + scaleFactor = ph / vh; } Group oldParent = (node.getParent() instanceof Group) ? (Group) node.getParent() : null; @@ -190,7 +192,7 @@ public void print(PrinterJob job, Drawing drawing) throws IOException { } } if (hasPages) { - writePages(null, null, drawing); + writePages(null, null, drawing); } else { writeDrawing(drawing); }