Package org.apache.fop.pdf
Class PDFFunction
java.lang.Object
org.apache.fop.pdf.PDFObject
org.apache.fop.pdf.PDFFunction
- All Implemented Interfaces:
PDFWritable
class representing a PDF Function.
PDF Functions represent parameterized mathematical formulas and
sampled representations with
arbitrary resolution. Functions are used in two areas: device-dependent
rasterization information for halftoning and transfer
functions, and color specification for smooth shading (a PDF 1.3 feature).
All PDF Functions have a FunctionType (0,2,3, or 4), a Domain, and a Range.
-
Field Summary
-
Constructor Summary
ConstructorDescriptionPDFFunction
(List<Double> domain, List<Double> range, float[] cZero, float[] cOne, double interpolationExponentN) create an complete Function object of Type 2, an Exponential Interpolation function.PDFFunction
(Function function) PDFFunction
(Function function, List<PDFFunction> pdfFunctions) -
Method Summary
Modifier and TypeMethodDescriptionprotected boolean
contentEquals
(PDFObject obj) Check if the other PDFObject has the same content as the current object.byte[]
byte[]
toPDF()
represent as PDF.Methods inherited from class org.apache.fop.pdf.PDFObject
encode, encodeBinaryToHexString, encodeString, encodeText, formatObject, getChildren, getDocument, getDocumentSafely, getGeneration, getObjectID, getObjectNumber, getParent, hasObjectNumber, makeReference, output, outputInline, referencePDF, setDocument, setObjectNumber, setObjectNumber, setObjectNumber, setParent, toPDFString
-
Constructor Details
-
PDFFunction
public PDFFunction(List<Double> domain, List<Double> range, float[] cZero, float[] cOne, double interpolationExponentN) create an complete Function object of Type 2, an Exponential Interpolation function. Use null for an optional object parameter if you choose not to use it. For optional int parameters, pass the default.- Parameters:
domain
- List objects of Double objects. This is the domain of the function. See page 264 of the PDF 1.3 Spec.range
- List of Doubles that is the Range of the function. See page 264 of the PDF 1.3 Spec.cZero
- This is a vector of Double objects which defines the function result when x=0. This attribute is optional. It's described on page 268 of the PDF 1.3 spec.cOne
- This is a vector of Double objects which defines the function result when x=1. This attribute is optional. It's described on page 268 of the PDF 1.3 spec.interpolationExponentN
- This is the inerpolation exponent. This attribute is required. PDF Spec page 268
-
PDFFunction
-
PDFFunction
-
-
Method Details
-
getFunction
-
toPDF
public byte[] toPDF()represent as PDF. Whatever the FunctionType is, the correct representation spits out. The sets of required and optional attributes are different for each type, but if a required attribute's object was constructed as null, then no error is raised. Instead, the malformed PDF that was requested by the construction is dutifully output. This policy should be reviewed. -
toByteString
public byte[] toByteString() -
contentEquals
Check if the other PDFObject has the same content as the current object.Note: This function has a contract which is less binding than
Object.equals(Object)
. Whereas equals would require all values to be identical, this method is not required to check everything. In the case of PDFObjects, this means that the overriding function does not have to check forPDFObject.getObjectID()
.- Overrides:
contentEquals
in classPDFObject
- Parameters:
obj
- object to compare to.- Returns:
- true if the other object has the same content.
-