jeremias 2005/06/09 05:50:14
Modified: src/java/org/apache/fop/render/bitmap PNGRenderer.java
Log:
Avoid NPEs when no filename is set on the UserAgent. Only the first page is
rendered in this case.
The resolution is written to the PNG file.
Revision Changes Path
1.2 +42 -19
xml-fop/src/java/org/apache/fop/render/bitmap/PNGRenderer.java
Index: PNGRenderer.java
===================================================================
RCS file:
/home/cvs/xml-fop/src/java/org/apache/fop/render/bitmap/PNGRenderer.java,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -r1.1 -r1.2
--- PNGRenderer.java 9 Jun 2005 08:49:27 -0000 1.1
+++ PNGRenderer.java 9 Jun 2005 12:50:14 -0000 1.2
@@ -25,7 +25,7 @@
public static final String MIME_TYPE = "image/png";
/** The file syntax prefix, eg. "page" will output "page1.png" etc */
- private String fileSyntax;
+ private String filePrefix;
/** The output directory where images are to be written */
private File outputDir;
@@ -60,16 +60,22 @@
// the file provided on the command line
File f = getUserAgent().getOutputFile();
-
- outputDir = f.getParentFile();
-
- // extracting file name syntax
- String s = f.getName();
- int i = s.lastIndexOf(".");
- if (s.charAt(i - 1) == '1') {
- i--; // getting rid of the "1"
+ if (f == null) {
+ //No filename information available. Only the first page will be
rendered.
+ outputDir = null;
+ filePrefix = null;
+ } else {
+ outputDir = f.getParentFile();
+
+ // extracting file name syntax
+ String s = f.getName();
+ int i = s.lastIndexOf(".");
+ if (s.charAt(i - 1) == '1') {
+ i--; // getting rid of the "1"
+ }
+ filePrefix = s.substring(0, i);
}
- fileSyntax = s.substring(0, i);
+
}
public void stopRenderer() throws IOException {
@@ -78,14 +84,27 @@
for (int i = 0; i < pageViewportList.size(); i++) {
+ OutputStream os = getCurrentOutputStream(i);
+ if (os == null) {
+ getLogger().warn("No filename information available."
+ + " Stopping early after the first page.");
+ break;
+ }
// Do the rendering: get the image for this page
RenderedImage image = (RenderedImage)
getPageImage((PageViewport) pageViewportList
.get(i));
// Encode this image
- getLogger().debug("Encoding Page " + (i + 1));
+ getLogger().debug("Encoding page " + (i + 1));
renderParams = PNGEncodeParam.getDefaultEncodeParam(image);
- OutputStream os = getCurrentOutputStream(i);
+
+ // Set resolution
+ float pixSzMM = userAgent.getPixelUnitToMillimeter();
+ // num Pixs in 1 Meter
+ int numPix = (int)((1000 / pixSzMM) + 0.5);
+ renderParams.setPhysicalDimension(numPix, numPix, 1); // 1 means
'pix/meter'
+
+ // Encode PNG image
PNGImageEncoder encoder = new PNGImageEncoder(os, renderParams);
encoder.encode(image);
os.flush();
@@ -103,14 +122,18 @@
return firstOutputStream;
}
- File f = new File(outputDir + File.separator + fileSyntax
- + (pageNumber + 1) + ".png");
- try {
- OutputStream os = new BufferedOutputStream(new
FileOutputStream(f));
- return os;
- } catch (FileNotFoundException e) {
- new FOPException("Can't build the OutputStream\n" + e);
+ if (filePrefix == null) {
return null;
+ } else {
+ File f = new File(outputDir + File.separator + filePrefix
+ + (pageNumber + 1) + ".png");
+ try {
+ OutputStream os = new BufferedOutputStream(new
FileOutputStream(f));
+ return os;
+ } catch (FileNotFoundException e) {
+ new FOPException("Can't build the OutputStream\n" + e);
+ return null;
+ }
}
}
}
---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]