blob: bc7d2ded7c07803aa6aa1bbadc1a06274a171ddd (
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
|
<?xml version="1.0" standalone="no"?>
<!DOCTYPE document PUBLIC "-//APACHE//DTD Documentation V1.1//EN"
"http://cvs.apache.org/viewcvs.cgi/*checkout*/xml-forrest/src/resources/schema/dtd/document-v11.dtd">
<document>
<header>
<title>Renderers</title>
<subtitle>Design of Renderers</subtitle>
<authors>
<person name="Keiron Liddle" email="keiron@aftexsw.com"/>
</authors>
</header>
<body>
<section id="issue-renderers-responsible">
<title>Renderers are Responsible</title>
<p>Each renderer is totally responsible for its output format.</p>
</section>
<section id="issue-output-stream">
<title>Send Output to a Stream</title>
</section>
<section id="intro">
<title>Introduction</title>
<p>A renderer is primarily designed to convert a given area tree into the output
document format. It should be able to produce pages and fill the pages
with the text and graphical content. Usually the output is sent to
an output stream.</p>
<p>Some output formats may support extra information that is not available
from the area tree or depends on the destination of the document.</p>
<p>Each renderer is given an area tree to render to its output format.
The area tree is simply a representation of the pages and the placement
of text and graphical objects on those pages.</p>
<p>The renderer will be given each page as it is ready and an output stream
to write the data out.
All pages are supplied in the order they appear in the document.
In order to save memory it is
possble to render the pages out of order. Any page that is not ready to
be rendered is setup by the renderer first so that it can reserve a space
or reference for when the page is ready to be rendered.The renderer is responsible for managing the
output format and associated data and flow.</p>
</section>
<section id="fonts">
<title>Fonts</title>
<p>Because font metrics (and therefore layout) are obtained in two different ways depending on the renderer, the renderer actually sets up the fonts being used. The font metrics are used
during the layout process to determine the size of characters.</p>
</section>
<section id="context">
<title>Render Context</title>
<p>The render context is used by handlers.
It contains information about the current state of the renderer, such as the page, the position, and any other miscellanous objects that are required to draw into the page.</p>
</section>
<section>
<title>XML Handling</title>
<p>A document may contain information in the form of XML for an image or instream foreign object.
This XML is handled through the user agent.
A standard extension for PDF is the SVG handler.</p>
<p>If there is XML in the SVG namespace it is given to the handler which renders the SVG into the pdf document at the given location.
This separation means that other XML handlers can easily be added.</p>
</section>
<section>
<title>Extensions</title>
<p>Document level extensions are handled with an extension handler.
This handles the information from the AreaTree and adds renders it to the document.
An example is the pdf bookmarks. This information first needs to have all references resolved.
Then the extension handler is ready to put the information into the pdf document.</p>
</section>
<section id="implement">
<title>Renderer Implementations</title>
<table>
<tr>
<th>Name</th>
<th>Type</th>
<th>Font Source</th>
<th>Font Embedding?</th>
<th>Out of Order Rendering?</th>
<th>Notes</th>
</tr>
<tr>
<td>PDF</td>
<td>Paginated</td>
<td>FOP</td>
<td>Yes</td>
<td>Yes</td>
<td>Uses the PDFDocument classes to create a PDF document. Most of the work is to insert text or create lines. SVG is handled by the XML handler that uses the PDFGraphics2D and batik to
draw the svg into the pdf page.</td>
</tr>
<tr>
<td>PostScript</td>
<td>Paginated</td>
<td>FOP</td>
<td>Not implemented</td>
<td>?</td>
<td>Similar to PDF.</td>
</tr>
<tr>
<td>PCL</td>
<td>Paginated</td>
<td>FOP</td>
<td>?</td>
<td>?</td>
<td>Similar to PDF.</td>
</tr>
<tr>
<td>SVG</td>
<td>Paginated</td>
<td>?</td>
<td>?</td>
<td>?</td>
<td>Creates a single svg document that contains all the pages rendered
with page sequences horizontally and pages vertically. Adds
links between the pages so that it can be viewed by clicking on the page
to go to the next page.</td>
</tr>
<tr>
<td>TXT</td>
<td>Paginated</td>
<td>N/A</td>
<td>N/A</td>
<td>No</td>
<td>Outputs to a text document.</td>
</tr>
<tr>
<td>AWT</td>
<td>Paginated</td>
<td>AWT</td>
<td>N/A</td>
<td>?</td>
<td>This draws the pages into an AWT graphic.</td>
</tr>
<tr>
<td>XML</td>
<td>Paginated</td>
<td>FOP</td>
<td>No</td>
<td>No</td>
<td>Creates an XML file that represents the AreaTree.</td>
</tr>
<tr>
<td>Print</td>
<td>Paginated</td>
<td>AWT</td>
<td>?</td>
<td>No</td>
<td>Prints the document using the java printing facitlities. The AWT
rendering is used to draw the pages onto the printjob.</td>
</tr>
<tr>
<td>RTF</td>
<td>Structural</td>
<td>N/A</td>
<td>N/A</td>
<td>No</td>
<td>Structural format uses a different rendering mechanism.</td>
</tr>
<tr>
<td>MIF</td>
<td>Structural</td>
<td>N/A</td>
<td>N/A</td>
<td>No</td>
<td>Structural format uses a different rendering mechanism.</td>
</tr>
</table>
</section>
<section id="add">
<title>Adding a Renderer</title>
<p>You can add other renderers by implementing the Renderer interface.
However, the AbstractRenderer does most of what is needed, including iterating through the tree parts, so it is probably better to extend this.
This means that you only need to implement the basic functionality such as text, images, and lines.
AbstractRenderer's methods can easily be overridden to handle things in a different way or do some extra processing.</p>
<p>The relevent AreaTree structures that will need to be rendered are:</p>
<ul>
<li>Page</li>
<li>Viewport</li>
<li>Region</li>
<li>Span</li>
<li>Block</li>
<li>Line</li>
<li>Inline</li>
</ul>
<p>A renderer implementation does the following:</p>
<ul>
<li>render each individual page</li>
<li>clip and align child areas to a viewport</li>
<li>handle all types of inline area, text, image etc.</li>
<li>draw various lines and rectangles</li>
</ul>
</section>
<section id="multiple">
<title>Multiple Renderers</title>
<p>The layout of the document depends mainly on the font being used.
If two renderers have the same font metrics then it is possible to use the same Area Tree to render both. This can be handled by the AreaTree Handler.</p>
</section>
</body>
</document>
|