diff --git a/.drone.yml b/.drone.yml
index 86a075d..8e96831 100644
--- a/.drone.yml
+++ b/.drone.yml
@@ -3,36 +3,36 @@ type: docker
name: default
steps:
- name: build
- image: maven:3.9-eclipse-temurin-21
+ image: maven:3.9-eclipse-temurin-25
commands:
- mvn clean install -DskipTests=true -Dmaven.javadoc.skip=true -B -V
when:
ref:
include:
- - refs/head/master
+ - refs/head/main
- refs/head/feature/**
- refs/tags/**
- name: test
- image: maven:3.9-eclipse-temurin-21
+ image: maven:3.9-eclipse-temurin-25
commands:
- mvn test -B
when:
branch:
include:
- - master
+ - main
- feature/*
- - name: deploy
- image: maven:3.9-eclipse-temurin-21
- environment:
- REPO_TOKEN:
- from_secret: repo-token
- REPO_TOKEN_OSSRH:
- from_secret: repo-token-ossrh
- commands:
- - mvn -s maven-settings.xml deploy -DskipTests=true
- when:
- branch:
- - master
- event:
- exclude:
- - pull_request
+# - name: deploy
+# image: maven:3.9-eclipse-temurin-25
+# environment:
+# REPO_TOKEN:
+# from_secret: repo-token
+# REPO_TOKEN_OSSRH:
+# from_secret: repo-token-ossrh
+# commands:
+# - mvn -s maven-settings.xml deploy -DskipTests=true
+# when:
+# branch:
+# - main
+# event:
+# exclude:
+# - pull_request
diff --git a/pom.xml b/pom.xml
index a39c758..3ccfe2e 100644
--- a/pom.xml
+++ b/pom.xml
@@ -10,7 +10,7 @@
ch.fritteli.a-maze-r
maze-generator
- 0.4.0
+ 0.5.1-SNAPSHOT
A-Maze-R Generator
A-Maze-R, The Maze Generator. It is a library for generating mazes in various output formats.
@@ -44,7 +44,7 @@
scm:git:https://gittr.ch/java/maze-generator.git
scm:git:ssh://git@gittr.ch/java/maze-generator.git
https://gittr.ch/java/maze-generator
- v0.4.0
+ HEAD
diff --git a/src/main/java/ch/fritteli/maze/generator/renderer/pdf/Generator.java b/src/main/java/ch/fritteli/maze/generator/renderer/pdf/Generator.java
index 6d44efa..3fdfc48 100644
--- a/src/main/java/ch/fritteli/maze/generator/renderer/pdf/Generator.java
+++ b/src/main/java/ch/fritteli/maze/generator/renderer/pdf/Generator.java
@@ -5,7 +5,6 @@ import ch.fritteli.maze.generator.model.Maze;
import ch.fritteli.maze.generator.model.Position;
import ch.fritteli.maze.generator.model.Tile;
import io.vavr.control.Option;
-import lombok.RequiredArgsConstructor;
import lombok.Value;
import lombok.extern.slf4j.Slf4j;
import org.apache.pdfbox.pdmodel.PDDocument;
@@ -20,18 +19,31 @@ import java.awt.*;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
-@RequiredArgsConstructor
@Slf4j
class Generator {
+ private static final PDRectangle REFERENCE_PAGE = PDRectangle.A4;
+ private static final int DPI = 72;
+ private static final double CM_PER_INCH = 2.54;
+ private static final double DOT_PER_CM = DPI / CM_PER_INCH;
+ // 1.5cm margin on each side of the page
+ private static final float MARGIN = (float) (1.5 * DOT_PER_CM);
@NonNull
private final Maze maze;
+ private final float stepSize;
+
+ Generator(@NonNull final Maze maze) {
+ this.maze = maze;
+
+ final float usableWidth = REFERENCE_PAGE.getWidth() - 2 * MARGIN;
+ final float usableHeight = REFERENCE_PAGE.getHeight() - 2 * MARGIN;
+ final float stepWidth = usableWidth / maze.getWidth();
+ final float stepHeight = usableHeight / maze.getHeight();
+ this.stepSize = Math.min(stepWidth, stepHeight);
+ }
@NonNull
public ByteArrayOutputStream generate() {
- final float pageWidth = this.maze.getWidth() * PDFRenderer.SCALE + 2 * PDFRenderer.MARGIN;
- final float pageHeight = this.maze.getHeight() * PDFRenderer.SCALE + 2 * PDFRenderer.MARGIN;
-
final PDDocument pdDocument = new PDDocument();
final PDDocumentInformation info = new PDDocumentInformation();
info.setTitle("Maze %sx%s, ID %s (%s)".formatted(
@@ -41,8 +53,8 @@ class Generator {
this.maze.getAlgorithm()
));
pdDocument.setDocumentInformation(info);
- final PDPage puzzlePage = new PDPage(new PDRectangle(pageWidth, pageHeight));
- final PDPage solutionPage = new PDPage(new PDRectangle(pageWidth, pageHeight));
+ final PDPage puzzlePage = new PDPage(REFERENCE_PAGE);
+ final PDPage solutionPage = new PDPage(REFERENCE_PAGE);
pdDocument.addPage(puzzlePage);
pdDocument.addPage(solutionPage);
try (final PDPageContentStream puzzlePageContentStream = new PDPageContentStream(pdDocument, puzzlePage);
@@ -75,7 +87,7 @@ class Generator {
private void drawHorizontalLines(@NonNull final PDPageContentStream... contentStreams) throws IOException {
// PDF has the origin in the lower left corner. We want it in the upper left corner, hence some magic is required.
- Coordinate coordinate = new Coordinate(0f, 0f);
+ Coordinate coordinate = new Coordinate(0, 0);
// Draw the TOP borders of all tiles.
for (int y = 0; y < this.maze.getHeight(); y++) {
boolean isPainting = false;
@@ -248,11 +260,15 @@ class Generator {
@Value
private class Coordinate {
-
float x;
float y;
- public Coordinate(final float x, final float y) {
+ public Coordinate(final int x, final int y) {
+ this.x = this.calcX(x);
+ this.y = this.calcY(y);
+ }
+
+ private Coordinate(final float x, final float y) {
this.x = x;
this.y = y;
}
@@ -262,7 +278,7 @@ class Generator {
}
private float calcX(final int x) {
- return x * PDFRenderer.SCALE + PDFRenderer.MARGIN;
+ return x * Generator.this.stepSize + Generator.MARGIN;
}
public Coordinate withY(final int y) {
@@ -270,7 +286,7 @@ class Generator {
}
private float calcY(final int y) {
- return (Generator.this.maze.getHeight() - y) * PDFRenderer.SCALE + PDFRenderer.MARGIN;
+ return (Generator.this.maze.getHeight() - y) * Generator.this.stepSize + Generator.MARGIN;
}
}
@@ -286,11 +302,11 @@ class Generator {
}
private float calcX(final int x) {
- return x * PDFRenderer.SCALE + PDFRenderer.SCALE / 2 + PDFRenderer.MARGIN;
+ return x * Generator.this.stepSize + Generator.this.stepSize / 2 + Generator.MARGIN;
}
private float calcY(final int y) {
- return (Generator.this.maze.getHeight() - y) * PDFRenderer.SCALE - PDFRenderer.SCALE / 2 + PDFRenderer.MARGIN;
+ return (Generator.this.maze.getHeight() - y) * Generator.this.stepSize - Generator.this.stepSize / 2 + Generator.MARGIN;
}
}
}