Class RtfExternalGraphic
- java.lang.Object
-
- org.apache.fop.render.rtf.rtflib.rtfdoc.RtfElement
-
- org.apache.fop.render.rtf.rtflib.rtfdoc.RtfExternalGraphic
-
public class RtfExternalGraphic extends RtfElement
Creates an RTF image from an external graphic file. This class belongs to the fo:external-graphic tag processing.
Supports relative path like "../test.gif", too (01-08-24)
Limitations: Only the image types PNG, JPEG and EMF are supported The GIF is supported, too, but will be converted to JPG Only the attributes SRC (required), WIDTH, HEIGHT, SCALING are supported The SCALING attribute supports (uniform | non-uniform) Known Bugs: If the emf image has a desired size, the image will be clipped The emf, jpg, png image will not be displayed in correct size This work was originally authored by Andreas Putz This work was originally authored by Gianugo Rabellino gianugo@rabellino.it
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classRtfExternalGraphic.ExternalGraphicExceptionException thrown when an image file/URL cannot be read
-
Field Summary
Fields Modifier and Type Field Description protected intgraphicCompressionRateGraphic compression rateprotected intheightThe height of the image (in pixels)protected intheightDesiredThe desired height (in twips)protected booleanperCentHFlag whether the desired height is a percentageprotected booleanperCentWFlag whether the desired width is a percentageprotected booleanscaleUniformFlag whether the image size shall be adjustedprotected java.net.URLurlThe url of the imageprotected intwidthThe width of the image (in pixels)protected intwidthDesiredThe desired width (in twips)-
Fields inherited from class org.apache.fop.render.rtf.rtflib.rtfdoc.RtfElement
attrib, parent, writer
-
-
Constructor Summary
Constructors Constructor Description RtfExternalGraphic(RtfContainer container, java.io.Writer writer)Default constructor.RtfExternalGraphic(RtfContainer container, java.io.Writer writer, RtfAttributes attributes)Default constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intgetCompressionRate()Gets the compression rate for the image in percent.booleanisEmpty()booleansetCompressionRate(int percent)Sets the compression rate for the image in percent.voidsetCropping(int left, int top, int right, int bottom)Sets cropping values for all four edges for the \piccrop*N commands.voidsetHeight(java.lang.String theHeight)Sets the desired height of the image.voidsetHeightTwips(int twips)Sets the desired height of the image.voidsetImageData(byte[] data)Sets the binary imagedata of the image.voidsetScaling(java.lang.String value)Sets the flag whether the image size shall be adjusted.voidsetUniformScaling(boolean uniform)Sets the flag whether the image size shall be adjusted.voidsetURL(java.lang.String urlString)Sets the url of the image.voidsetWidth(java.lang.String theWidth)Sets the desired width of the image.voidsetWidthTwips(int twips)Sets the desired width of the image.protected voidwriteRtfContent()RtfElement override - catches ExternalGraphicException and writes a warning message to the document if image cannot be readprotected voidwriteRtfContentWithException()Writes the RTF content to m_writer - this one throws ExternalGraphicExceptions-
Methods inherited from class org.apache.fop.render.rtf.rtflib.rtfdoc.RtfElement
close, getParentOfClass, getRtfAttributes, newLine, okToWriteRtf, toString, writeAttributes, writeControlWord, writeControlWordNS, writeExceptionInRtf, writeGroupMark, writeOneAttribute, writeOneAttributeNS, writeRtf, writeRtfPrefix, writeRtfSuffix, writeStarControlWord, writeStarControlWordNS
-
-
-
-
Field Detail
-
url
protected java.net.URL url
The url of the image
-
height
protected int height
The height of the image (in pixels)
-
heightDesired
protected int heightDesired
The desired height (in twips)
-
perCentH
protected boolean perCentH
Flag whether the desired height is a percentage
-
width
protected int width
The width of the image (in pixels)
-
widthDesired
protected int widthDesired
The desired width (in twips)
-
perCentW
protected boolean perCentW
Flag whether the desired width is a percentage
-
scaleUniform
protected boolean scaleUniform
Flag whether the image size shall be adjusted
-
graphicCompressionRate
protected int graphicCompressionRate
Graphic compression rate
-
-
Constructor Detail
-
RtfExternalGraphic
public RtfExternalGraphic(RtfContainer container, java.io.Writer writer) throws java.io.IOException
Default constructor. Create an RTF element as a child of given container.- Parameters:
container- aRtfContainervaluewriter- aWritervalue- Throws:
java.io.IOException- for I/O problems
-
RtfExternalGraphic
public RtfExternalGraphic(RtfContainer container, java.io.Writer writer, RtfAttributes attributes) throws java.io.IOException
Default constructor.- Parameters:
container- aRtfContainervaluewriter- aWritervalueattributes- aRtfAttributesvalue- Throws:
java.io.IOException- for I/O problems
-
-
Method Detail
-
writeRtfContent
protected void writeRtfContent() throws java.io.IOExceptionRtfElement override - catches ExternalGraphicException and writes a warning message to the document if image cannot be read- Specified by:
writeRtfContentin classRtfElement- Throws:
java.io.IOException- for I/O problems
-
writeRtfContentWithException
protected void writeRtfContentWithException() throws java.io.IOExceptionWrites the RTF content to m_writer - this one throws ExternalGraphicExceptions- Throws:
java.io.IOException- On error
-
setHeight
public void setHeight(java.lang.String theHeight)
Sets the desired height of the image.- Parameters:
theHeight- The desired image height (as a string in twips or as a percentage)
-
setWidth
public void setWidth(java.lang.String theWidth)
Sets the desired width of the image.- Parameters:
theWidth- The desired image width (as a string in twips or as a percentage)
-
setWidthTwips
public void setWidthTwips(int twips)
Sets the desired width of the image.- Parameters:
twips- The desired image width (in twips)
-
setHeightTwips
public void setHeightTwips(int twips)
Sets the desired height of the image.- Parameters:
twips- The desired image height (in twips)
-
setScaling
public void setScaling(java.lang.String value)
Sets the flag whether the image size shall be adjusted.- Parameters:
value- true image width or height shall be adjusted automatically\n false no adjustment
-
setUniformScaling
public void setUniformScaling(boolean uniform)
Sets the flag whether the image size shall be adjusted.- Parameters:
uniform- true image width or height shall be adjusted automatically\n false no adjustment
-
setCropping
public void setCropping(int left, int top, int right, int bottom)Sets cropping values for all four edges for the \piccrop*N commands. A positive value crops toward the center of the picture; a negative value crops away from the center, adding a space border around the picture- Parameters:
left- left cropping value (in twips)top- top cropping value (in twips)right- right cropping value (in twips)bottom- bottom cropping value (in twips)
-
setImageData
public void setImageData(byte[] data) throws java.io.IOExceptionSets the binary imagedata of the image.- Parameters:
data- binary imagedata as read from file.- Throws:
java.io.IOException- On error
-
setURL
public void setURL(java.lang.String urlString) throws java.io.IOExceptionSets the url of the image.- Parameters:
urlString- Image url like "file://..."- Throws:
java.io.IOException- On error
-
getCompressionRate
public int getCompressionRate()
Gets the compression rate for the image in percent.- Returns:
- Compression rate
-
setCompressionRate
public boolean setCompressionRate(int percent)
Sets the compression rate for the image in percent.- Parameters:
percent- Compression rate- Returns:
- true if the compression rate is valid (0..100), false if invalid
-
isEmpty
public boolean isEmpty()
- Specified by:
isEmptyin classRtfElement- Returns:
- true if this element would generate no "useful" RTF content
-
-