aboutsummaryrefslogtreecommitdiff
path: root/pdf-as-web/src/main/java/at/gv/egiz/pdfas
diff options
context:
space:
mode:
Diffstat (limited to 'pdf-as-web/src/main/java/at/gv/egiz/pdfas')
-rw-r--r--pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/servlets/PlaceholderGeneratorServlet.java80
1 files changed, 65 insertions, 15 deletions
diff --git a/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/servlets/PlaceholderGeneratorServlet.java b/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/servlets/PlaceholderGeneratorServlet.java
index bd64c75d..f27a0e81 100644
--- a/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/servlets/PlaceholderGeneratorServlet.java
+++ b/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/servlets/PlaceholderGeneratorServlet.java
@@ -36,6 +36,11 @@ public class PlaceholderGeneratorServlet extends HttpServlet implements Placehol
public static final String PARAM_ID = "id";
public static final String PARAM_PROFILE = "profile";
+ public static final String PARAM_WIDTH = "w";
+ public static final String PARAM_HEIGHT = "h";
+ public static final String PARAM_BORDER = "b";
+
+ public static final int MAX_SIZE = 1024;
private static final Logger logger = LoggerFactory
.getLogger(ExternSignServlet.class);
@@ -90,7 +95,40 @@ public class PlaceholderGeneratorServlet extends HttpServlet implements Placehol
//if(id != null || profile != null) {
// We need to generate the image
-
+ // default values set for pdf-as wai on buergerkarte.at
+ int height = 85;
+ int width = 250;
+ int border = 2;
+
+ if(req.getParameter(PARAM_HEIGHT) != null) {
+ try {
+ height = Integer.parseInt(req.getParameter(PARAM_HEIGHT));
+ } catch(NumberFormatException e) {
+ logger.info("Parameter {} has to be a number.", PARAM_HEIGHT);
+ resp.sendError(HttpStatus.SC_NOT_ACCEPTABLE);
+ }
+ }
+
+ if(req.getParameter(PARAM_WIDTH) != null) {
+ try {
+ width = Integer.parseInt(req.getParameter(PARAM_WIDTH));
+ } catch(NumberFormatException e) {
+ logger.info("Parameter {} has to be a number.", PARAM_WIDTH);
+ resp.sendError(HttpStatus.SC_NOT_ACCEPTABLE);
+ }
+ }
+
+ if(req.getParameter(PARAM_BORDER) != null) {
+ try {
+ border = Integer.parseInt(req.getParameter(PARAM_BORDER));
+ } catch(NumberFormatException e) {
+ logger.info("Parameter {} has to be a number.", PARAM_BORDER);
+ resp.sendError(HttpStatus.SC_NOT_ACCEPTABLE);
+ }
+ }
+
+ int qrSize = height - ( 2 * border);
+
InputStream is = this.getClass().getClassLoader().getResourceAsStream(baseImage);
if(is == null) {
logger.warn("Cannot open resource {} to generator QR placeholder", baseImage);
@@ -102,7 +140,7 @@ public class PlaceholderGeneratorServlet extends HttpServlet implements Placehol
// generate QR code
try {
- QRCodeGenerator.generateQRCode(buildString, baos, 90);
+ QRCodeGenerator.generateQRCode(buildString, baos, qrSize);
} catch (WriterException e) {
logger.warn("Failed to generate QR Code for placeholder generationg", e);
resp.sendError(HttpStatus.SC_INTERNAL_SERVER_ERROR);
@@ -110,39 +148,51 @@ public class PlaceholderGeneratorServlet extends HttpServlet implements Placehol
}
baos.close();
-
- BufferedImage base = ImageIO.read(is);
BufferedImage qr = ImageIO.read(new ByteArrayInputStream(baos.toByteArray()));
BufferedImage off_Image =
- new BufferedImage(250, 98,
+ new BufferedImage(width, height,
BufferedImage.TYPE_INT_ARGB);
Graphics g = off_Image.getGraphics();
- g.drawImage(base, 0, 0, 250, 98, 0, 0, base.getWidth(), base.getHeight(), null);
- g.drawImage(qr, 4, 4, 94, 94, 0, 0, qr.getWidth(), qr.getHeight(), null);
+ g.setColor(Color.BLUE);
+ g.fillRect(0, 0, width, height);
g.setColor(Color.WHITE);
- g.fillRect(94, 4, 152, 90);
+ g.fillRect(border, border, width - (2 * border), height - (2 * border));
+ //g.drawImage(base, 0, 0, 250, 98, 0, 0, base.getWidth(), base.getHeight(), null);
+ g.drawImage(qr, border, border, qrSize + border, qrSize + border, 0, 0, qr.getWidth(), qr.getHeight(), null);
+
//g.(x, y, width, height);
Font writeFont = new Font(Font.SANS_SERIF, Font.BOLD, 14);
g.setFont(writeFont);
g.setColor(Color.BLACK);
+ int lineSpace = 14 + 4;
+
+ int textHeight = 3 * lineSpace;
+
+ if(id != null && !id.isEmpty()) {
+ textHeight = 4 * lineSpace;
+ }
+
+ int start = (height - textHeight) / 2;
+
if(profile != null && profile.endsWith("_EN")) {
- g.drawString("placeholder for", 102, 13+18);
- g.drawString("the electronic", 102, 13+18 + 18);
- g.drawString("signature", 102, 13+18 + 18 + 18);
+
+ g.drawString("placeholder for", qrSize + ( 3 * border), start + lineSpace);
+ g.drawString("the electronic", qrSize + ( 3 * border), start + (2 * lineSpace));
+ g.drawString("signature", qrSize + ( 3 * border), start + (3 * lineSpace));
} else {
- g.drawString("Platzhalter für", 102, 13+18);
- g.drawString("die elektronische", 102, 13+18 + 18);
- g.drawString("Signatur", 102, 13+18 + 18 + 18);
+ g.drawString("Platzhalter für", qrSize + ( 3 * border), start + lineSpace);
+ g.drawString("die elektronische", qrSize + ( 3 * border), start + (2 * lineSpace));
+ g.drawString("Signatur", qrSize + ( 3 * border), start + (3 * lineSpace));
}
if(id != null && !id.isEmpty()) {
Font nrFont = new Font(Font.SANS_SERIF, Font.BOLD | Font.ITALIC, 14);
g.setFont(nrFont);
- g.drawString("NR: " + id, 102, 13+18 + 18 + 18 + 18);
+ g.drawString("NR: " + id, qrSize + ( 3 * border), start + (4 * lineSpace));
}
logger.info("serving qr placeholder for '{}'", buildString);