summaryrefslogtreecommitdiff
path: root/trunk/pdf-over-gui
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/pdf-over-gui')
-rw-r--r--trunk/pdf-over-gui/pom.xml4
-rw-r--r--trunk/pdf-over-gui/src/main/java/at/asit/pdfover/gui/composites/PDFViewerComposite.java155
2 files changed, 159 insertions, 0 deletions
diff --git a/trunk/pdf-over-gui/pom.xml b/trunk/pdf-over-gui/pom.xml
index 68937df2..606f6d1b 100644
--- a/trunk/pdf-over-gui/pom.xml
+++ b/trunk/pdf-over-gui/pom.xml
@@ -34,6 +34,10 @@
<groupId>commons-httpclient</groupId>
<artifactId>commons-httpclient</artifactId>
</dependency>
+ <dependency>
+ <groupId>org.icepdf</groupId>
+ <artifactId>icepdf-core</artifactId>
+ </dependency>
</dependencies>
<profiles>
diff --git a/trunk/pdf-over-gui/src/main/java/at/asit/pdfover/gui/composites/PDFViewerComposite.java b/trunk/pdf-over-gui/src/main/java/at/asit/pdfover/gui/composites/PDFViewerComposite.java
new file mode 100644
index 00000000..1637da9e
--- /dev/null
+++ b/trunk/pdf-over-gui/src/main/java/at/asit/pdfover/gui/composites/PDFViewerComposite.java
@@ -0,0 +1,155 @@
+/*
+ * Copyright 2012 by A-SIT, Secure Information Technology Center Austria
+ *
+ * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by
+ * the European Commission - subsequent versions of the EUPL (the "Licence");
+ * You may not use this work except in compliance with the Licence.
+ * You may obtain a copy of the Licence at:
+ * http://joinup.ec.europa.eu/software/page/eupl
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the Licence is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the Licence for the specific language governing permissions and
+ * limitations under the Licence.
+ */
+package at.asit.pdfover.gui.composites;
+
+// Imports
+import java.awt.Canvas;
+import java.awt.Dimension;
+import java.awt.Frame;
+import java.awt.Graphics;
+import java.awt.geom.Rectangle2D;
+import java.io.File;
+import java.io.IOException;
+
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.awt.SWT_AWT;
+import org.eclipse.swt.events.KeyAdapter;
+import org.eclipse.swt.events.KeyEvent;
+import org.eclipse.swt.widgets.Composite;
+import org.icepdf.core.exceptions.PDFException;
+import org.icepdf.core.exceptions.PDFSecurityException;
+import org.icepdf.core.pobjects.Document;
+import org.icepdf.core.pobjects.Page;
+import org.icepdf.core.util.GraphicsRenderingHints;
+
+/**
+ * Displays a PDF document
+ */
+public class PDFViewerComposite extends Composite {
+
+ /**
+ * PDF document
+ */
+ protected Document document;
+
+ /**
+ * Currently selected page in the document
+ */
+ protected int page;
+
+ /**
+ * Get the currently selected page in the document
+ * @return current page
+ */
+ public int getPage() {
+ return this.page;
+ }
+
+ /**
+ * Set the visible page in the document
+ * @param page new active page
+ */
+ public void setPage(int page) {
+ this.page = page;
+ this.canvas.repaint();
+ }
+
+ /**
+ * AWT Canvas displaying the document
+ */
+ private Canvas canvas;
+
+ /**
+ * Create the PDF Viewer composite.
+ * @param parent parent Composite
+ * @param style
+ * @param document
+ * @throws PDFException Error parsing PDF document
+ * @throws PDFSecurityException Error decrypting PDF document (not supported)
+ * @throws IOException I/O Error
+ */
+ public PDFViewerComposite(Composite parent, int style, File document) throws PDFException, PDFSecurityException, IOException {
+ super(parent, style);
+ this.document = new Document();
+ this.document.setFile(document.getPath());
+ int pages = this.document.getNumberOfPages();
+
+ final Dimension[] base_dimensions = new Dimension[pages];
+ for (int page = 0; page < pages; ++page)
+ base_dimensions[page] = this.document.getPageDimension(page, 0f, 1.0f).toDimension();
+
+ this.page = pages - 1;
+
+ Frame frame = SWT_AWT.new_Frame(this);
+ this.canvas = new Canvas() {
+ private static final long serialVersionUID = 1L;
+
+ @Override
+ public void paint(Graphics g) {
+ if (g == null || g.getClip() == null)
+ return;
+ int page = getPage();
+ // Make page always fit to window
+ Rectangle2D clip = g.getClip().getBounds2D();
+ double h_zoom = clip.getWidth() / base_dimensions[page].width;
+ double v_zoom = clip.getHeight() / base_dimensions[page].height;
+ float zoom = (float) (h_zoom < v_zoom ? h_zoom : v_zoom);
+ if (v_zoom < h_zoom)
+ {
+ // Page is narrower than window, center it
+ g.translate((int) ((clip.getWidth() - (base_dimensions[page].width * zoom)) / 2), 0);
+ }
+
+ PDFViewerComposite.this.document.paintPage(page, g, GraphicsRenderingHints.SCREEN, Page.BOUNDARY_CROPBOX, 0f, zoom);
+ }
+ };
+ frame.add(this.canvas);
+ frame.pack();
+ frame.setVisible(true);
+
+ this.addKeyListener(new KeyAdapter() {
+ @Override
+ public void keyPressed(KeyEvent e) {
+ int page = getPage();
+ int old_page = page;
+
+ switch (e.keyCode)
+ {
+ case SWT.PAGE_DOWN:
+ if (page < (PDFViewerComposite.this.document.getNumberOfPages() - 1))
+ ++page;
+ break;
+
+ case SWT.PAGE_UP:
+ if (page > 0)
+ --page;
+ break;
+
+ case SWT.END:
+ page = (PDFViewerComposite.this.document.getNumberOfPages() - 1);
+ break;
+
+ case SWT.HOME:
+ page = 0;
+ break;
+ }
+
+ if (page != old_page)
+ setPage(page);
+ }
+ });
+ }
+}