blob: ba38477bd2be81b679d6a3abb975df8457614a8a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
package org.apache.fop.render.bitmap;
import java.awt.image.RenderedImage;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import org.apache.batik.ext.awt.image.codec.PNGEncodeParam;
import org.apache.batik.ext.awt.image.codec.PNGImageEncoder;
import org.apache.fop.apps.FOPException;
import org.apache.fop.area.PageViewport;
import org.apache.fop.render.java2d.Java2DRenderer;
/**
* PNG Renderer This class actually does not render itself, instead it extends
* <code>org.apache.fop.render.java2D.Java2DRenderer</code> and just encode
* rendering results into PNG format using Batik's image codec
*/
public class PNGRenderer_onthefly extends Java2DRenderer {
/** The MIME type for png-Rendering */
public static final String MIME_TYPE = "image/png";
/** The file syntax prefix, eg. "page" will output "page1.png" etc */
private String fileSyntax;
/** The output directory where images are to be written */
private File outputDir;
/** The PNGEncodeParam for the image */
private PNGEncodeParam renderParams;
/** The OutputStream for the first Image */
private OutputStream firstOutputStream;
/** default constructor */
public PNGRenderer_onthefly() {}
/** @see org.apache.fop.render.AbstractRenderer */
public String getMimeType() {
return MIME_TYPE;
}
public boolean supportsOutOfOrder() {
return true;
}
/** @see org.apache.fop.render.Renderer#startRenderer(java.io.OutputStream) */
public void startRenderer(OutputStream outputStream) throws IOException {
log.info("rendering areas to PNG");
setOutputDirectory();
this.firstOutputStream = outputStream;
}
/**
* Sets the output directory, either from the outfile specified on the
* command line, or from the directory specified in configuration file. Also
* sets the file name syntax, eg. "page"
*/
private void setOutputDirectory() {
// 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"
}
fileSyntax = s.substring(0, i);
}
public void renderPage(PageViewport pageViewport) throws IOException,
FOPException {
// Do the rendering: get the image for this page
RenderedImage image = (RenderedImage) getPageImage(pageViewport);
// Encode this image
log.debug("Encoding page" + (getCurrentPageNumber() + 1));
renderParams = PNGEncodeParam.getDefaultEncodeParam(image);
OutputStream os = getCurrentOutputStream(getCurrentPageNumber());
PNGImageEncoder encoder = new PNGImageEncoder(os, renderParams);
encoder.encode(image);
os.flush();
setCurrentPageNumber(getCurrentPageNumber() + 1);
}
/**
* Builds the OutputStream corresponding to this page
* @param 0-based pageNumber
* @return the corresponding OutputStream
*/
private OutputStream getCurrentOutputStream(int pageNumber) {
if (pageNumber == 0) {
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);
return null;
}
}
}
|