public abstract class DocWriter extends Object implements DocListener
Writer
class for documents.
DocWriter
is the abstract class of several writers such
as PdfWriter
and HtmlWriter
.
A DocWriter
can be added as a DocListener
to a certain Document
by getting an instance (see method
getInstance()
in the specific writer-classes).
Every Element
added to the original Document
will be written to the OutputStream
of the listening
DocWriter
.
Document
,
DocListener
Modifier and Type | Field and Description |
---|---|
protected boolean |
closeStream
Closes the stream on document close
|
protected Document |
document
This is the document that has to be written.
|
static byte |
EQUALS
This is some byte that is often used.
|
static byte |
FORWARD
This is some byte that is often used.
|
static byte |
GT
This is some byte that is often used.
|
static byte |
LT
This is some byte that is often used.
|
static byte |
NEWLINE
This is some byte that is often used.
|
protected boolean |
open
Is the writer open for writing?
|
protected OutputStreamCounter |
os
The outputstream of this writer.
|
protected Rectangle |
pageSize
The pageSize.
|
protected boolean |
pause
Do we have to pause all writing actions?
|
static byte |
QUOTE
This is some byte that is often used.
|
static byte |
SPACE
This is some byte that is often used.
|
static byte |
TAB
This is some byte that is often used.
|
Modifier | Constructor and Description |
---|---|
protected |
DocWriter() |
protected |
DocWriter(Document document,
OutputStream os)
Constructs a
DocWriter . |
Modifier and Type | Method and Description |
---|---|
boolean |
add(Element element)
Signals that an
Element was added to the Document . |
protected void |
addTabs(int indent)
Writes a number of tabs.
|
void |
close()
Signals that the
Document was closed and that no other
Elements will be added. |
void |
flush()
Flushes the
BufferedOutputStream . |
static byte[] |
getISOBytes(String text)
Converts a
String into a Byte array
according to the ISO-8859-1 codepage. |
boolean |
isCloseStream()
Checks if the stream is to be closed on document close
|
boolean |
isPaused()
Checks if writing is paused.
|
boolean |
newPage()
Signals that an new page has to be started.
|
void |
open()
Signals that the
Document was opened. |
void |
pause()
Let the writer know that all writing has to be paused.
|
void |
resetFooter()
Resets the footer of this document.
|
void |
resetHeader()
Resets the header of this document.
|
void |
resetPageCount()
Sets the page number to 0.
|
void |
resume()
Let the writer know that writing may be resumed.
|
void |
setCloseStream(boolean closeStream)
Sets the close state of the stream after document close
|
void |
setFooter(HeaderFooter footer)
Changes the footer of this document.
|
void |
setHeader(HeaderFooter header)
Changes the header of this document.
|
boolean |
setMarginMirroring(boolean MarginMirroring)
Parameter that allows you to do left/right margin mirroring (odd/even pages)
|
boolean |
setMarginMirroringTopBottom(boolean MarginMirroring)
Parameter that allows you to do top/bottom margin mirroring (odd/even pages)
|
boolean |
setMargins(float marginLeft,
float marginRight,
float marginTop,
float marginBottom)
Sets the margins.
|
void |
setPageCount(int pageN)
Sets the page number.
|
boolean |
setPageSize(Rectangle pageSize)
Sets the pagesize.
|
protected void |
write(String string)
Writes a
String to the OutputStream . |
protected void |
write(String key,
String value)
Writes a key-value pair to the outputstream.
|
protected void |
writeEnd()
Writes an endtag to the outputstream.
|
protected void |
writeEnd(String tag)
Writes an endtag to the outputstream.
|
protected boolean |
writeMarkupAttributes(Properties markup)
Writes the markup attributes of the specified
MarkupAttributes
object to the OutputStream . |
protected void |
writeStart(String tag)
Writes a starttag to the outputstream.
|
public static final byte NEWLINE
public static final byte TAB
public static final byte LT
public static final byte SPACE
public static final byte EQUALS
public static final byte QUOTE
public static final byte GT
public static final byte FORWARD
protected Rectangle pageSize
protected Document document
protected OutputStreamCounter os
protected boolean open
protected boolean pause
protected boolean closeStream
protected DocWriter()
protected DocWriter(Document document, OutputStream os)
DocWriter
.document
- The Document
that has to be writtenos
- The OutputStream
the writer has to write to.public boolean add(Element element) throws DocumentException
Element
was added to the Document
.
This method should be overridden in the specific DocWriter
classes
derived from this abstract class.
add
in interface ElementListener
element
- A high level object to addfalse
DocumentException
- when a document isn't open yet, or has been closedpublic void open()
Document
was opened.open
in interface DocListener
public boolean setPageSize(Rectangle pageSize)
setPageSize
in interface DocListener
pageSize
- the new pagesizeboolean
public boolean setMargins(float marginLeft, float marginRight, float marginTop, float marginBottom)
This does nothing. Has to be overridden if needed.
setMargins
in interface DocListener
marginLeft
- the margin on the leftmarginRight
- the margin on the rightmarginTop
- the margin on the topmarginBottom
- the margin on the bottomfalse
public boolean newPage()
This does nothing. Has to be overridden if needed.
newPage
in interface DocListener
true
if the page was added, false
if not.public void setHeader(HeaderFooter header)
This method should be overridden in the specific DocWriter
classes
derived from this abstract class if they actually support the use of
headers.
setHeader
in interface DocListener
header
- the new headerpublic void resetHeader()
This method should be overridden in the specific DocWriter
classes
derived from this abstract class if they actually support the use of
headers.
resetHeader
in interface DocListener
public void setFooter(HeaderFooter footer)
This method should be overridden in the specific DocWriter
classes
derived from this abstract class if they actually support the use of
footers.
setFooter
in interface DocListener
footer
- the new footerpublic void resetFooter()
This method should be overridden in the specific DocWriter
classes
derived from this abstract class if they actually support the use of
footers.
resetFooter
in interface DocListener
public void resetPageCount()
This method should be overridden in the specific DocWriter
classes
derived from this abstract class if they actually support the use of
pagenumbers.
resetPageCount
in interface DocListener
public void setPageCount(int pageN)
This method should be overridden in the specific DocWriter
classes
derived from this abstract class if they actually support the use of
pagenumbers.
setPageCount
in interface DocListener
pageN
- the new page numberpublic void close()
Document
was closed and that no other
Elements
will be added.close
in interface DocListener
public static final byte[] getISOBytes(String text)
String
into a Byte
array
according to the ISO-8859-1 codepage.text
- the text to be convertedpublic void pause()
public boolean isPaused()
true
if writing temporarily has to be paused, false
otherwise.public void resume()
public void flush()
BufferedOutputStream
.protected void write(String string) throws IOException
String
to the OutputStream
.string
- the String
to writeIOException
protected void addTabs(int indent) throws IOException
indent
- the number of tabs to addIOException
protected void write(String key, String value) throws IOException
key
- the name of an attributevalue
- the value of an attributeIOException
protected void writeStart(String tag) throws IOException
tag
- the name of the tagIOException
protected void writeEnd(String tag) throws IOException
tag
- the name of the tagIOException
protected void writeEnd() throws IOException
IOException
protected boolean writeMarkupAttributes(Properties markup) throws IOException
MarkupAttributes
object to the OutputStream
.markup
- a Properties
collection to write.IOException
public boolean isCloseStream()
public void setCloseStream(boolean closeStream)
closeStream
- true if the stream is closed on document closepublic boolean setMarginMirroring(boolean MarginMirroring)
DocListener
setMarginMirroring
in interface DocListener
DocListener.setMarginMirroring(boolean)
public boolean setMarginMirroringTopBottom(boolean MarginMirroring)
DocListener
setMarginMirroringTopBottom
in interface DocListener
DocListener.setMarginMirroring(boolean)
Copyright © 2018. All rights reserved.