📄 fdffield.java
字号:
/**
* Copyright (c) 2004, www.pdfbox.org
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. Neither the name of pdfbox; nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* http://www.pdfbox.org
*
*/
package org.pdfbox.pdmodel.fdf;
import java.io.IOException;
import java.io.Writer;
import java.util.ArrayList;
import java.util.List;
import org.pdfbox.cos.COSArray;
import org.pdfbox.cos.COSBase;
import org.pdfbox.cos.COSDictionary;
import org.pdfbox.cos.COSInteger;
import org.pdfbox.cos.COSName;
import org.pdfbox.cos.COSNumber;
import org.pdfbox.cos.COSStream;
import org.pdfbox.cos.COSString;
import org.pdfbox.pdmodel.common.COSObjectable;
import org.pdfbox.pdmodel.common.COSArrayList;
import org.pdfbox.pdmodel.common.PDTextStream;
import org.pdfbox.pdmodel.interactive.action.PDActionFactory;
import org.pdfbox.pdmodel.interactive.action.PDAdditionalActions;
import org.pdfbox.pdmodel.interactive.action.type.PDAction;
import org.pdfbox.pdmodel.interactive.annotation.PDAppearanceDictionary;
import org.pdfbox.util.XMLUtil;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
/**
* This represents an FDF field that is part of the FDF document.
*
* @author <a href="mailto:ben@benlitchfield.com">Ben Litchfield</a>
* @version $Revision: 1.5 $
*/
public class FDFField implements COSObjectable
{
private COSDictionary field;
/**
* Default constructor.
*/
public FDFField()
{
field = new COSDictionary();
}
/**
* Constructor.
*
* @param f The FDF field.
*/
public FDFField( COSDictionary f )
{
field = f;
}
/**
* This will create an FDF field from an XFDF XML document.
*
* @param fieldXML The XML document that contains the XFDF data.
* @throws IOException If there is an error reading from the dom.
*/
public FDFField( Element fieldXML ) throws IOException
{
this();
this.setPartialFieldName( fieldXML.getAttribute( "name" ) );
NodeList nodeList = fieldXML.getChildNodes();
List kids = new ArrayList();
for( int i=0; i<nodeList.getLength(); i++ )
{
Node node = nodeList.item( i );
if( node instanceof Element )
{
Element child = (Element)node;
if( child.getTagName().equals( "value" ) )
{
setValue( XMLUtil.getNodeValue( child ) );
}
else if( child.getTagName().equals( "value-richtext" ) )
{
setRichText( new PDTextStream( XMLUtil.getNodeValue( child ) ) );
}
else if( child.getTagName().equals( "field" ) )
{
kids.add( new FDFField( child ) );
}
}
}
if( kids.size() > 0 )
{
setKids( kids );
}
}
/**
* This will write this element as an XML document.
*
* @param output The stream to write the xml to.
*
* @throws IOException If there is an error writing the XML.
*/
public void writeXML( Writer output ) throws IOException
{
output.write( "<field name=\"" + getPartialFieldName() + "\">\n");
Object value = getValue();
if( value != null )
{
output.write( "<value>" + value + "</value>\n" );
}
PDTextStream rt = getRichText();
if( rt != null )
{
output.write( "<value-richtext>" + rt.getAsString() + "</value-richtext>\n" );
}
List kids = getKids();
if( kids != null )
{
for( int i=0; i<kids.size(); i++ )
{
((FDFField)kids.get( i ) ).writeXML( output );
}
}
output.write( "</field>\n");
}
/**
* Convert this standard java object to a COS object.
*
* @return The cos object that matches this Java object.
*/
public COSBase getCOSObject()
{
return field;
}
/**
* Convert this standard java object to a COS object.
*
* @return The cos object that matches this Java object.
*/
public COSDictionary getCOSDictionary()
{
return field;
}
/**
* This will get the list of kids. This will return a list of FDFField objects.
* This will return null if the underlying list is null.
*
* @return The list of kids.
*/
public List getKids()
{
COSArray kids = (COSArray)field.getDictionaryObject( "Kids" );
List retval = null;
if( kids != null )
{
List actuals = new ArrayList();
for( int i=0; i<kids.size(); i++ )
{
actuals.add( new FDFField( (COSDictionary)kids.getObject( i ) ) );
}
retval = new COSArrayList( actuals, kids );
}
return retval;
}
/**
* This will set the list of kids.
*
* @param kids A list of FDFField objects.
*/
public void setKids( List kids )
{
field.setItem( "Kids", COSArrayList.converterToCOSArray( kids ) );
}
/**
* This will get the "T" entry in the field dictionary. A partial field
* name. Where the fully qualified field name is a concatenation of
* the parent's fully qualified field name and "." as a separator. For example<br/>
* Address.State<br />
* Address.City<br />
*
* @return The partial field name.
*/
public String getPartialFieldName()
{
return field.getString( "T" );
}
/**
* This will set the partial field name.
*
* @param partial The partial field name.
*/
public void setPartialFieldName( String partial )
{
field.setString( "T", partial );
}
/**
* This will set the value for the field. This will return type will either be <br />
* String : Checkboxes, Radio Button <br />
* java.util.List of strings: Choice Field
* PDTextStream: Textfields
*
* @return The value of the field.
*
* @throws IOException If there is an error getting the value.
*/
public Object getValue() throws IOException
{
Object retval = null;
COSBase value = field.getDictionaryObject( "V" );
if( value instanceof COSName )
{
retval = ((COSName)value).getName();
}
else if( value instanceof COSArray )
{
retval = COSArrayList.convertCOSStringCOSArrayToList( (COSArray)value );
}
else if( value instanceof COSString || value instanceof COSStream )
{
retval = PDTextStream.createTextStream( value );
}
else if( value == null )
{
//Ok, value is null so do nothing
}
else
{
throw new IOException( "Error:Unknown type for field import" + value );
}
return retval;
}
/**
* You should pass in a string, or a java.util.List of strings to set the
* value.
*
* @param value The value that should populate when imported.
*
* @throws IOException If there is an error setting the value.
*/
public void setValue( Object value ) throws IOException
{
COSBase cos = null;
if( value instanceof List )
{
cos = COSArrayList.convertStringListToCOSStringCOSArray( (List)value );
}
else if( value instanceof String )
{
cos = COSName.getPDFName( (String)value );
}
else if( value instanceof COSObjectable )
{
cos = ((COSObjectable)value).getCOSObject();
}
else if( value == null )
{
//do nothing and let cos remain null as well.
}
else
{
throw new IOException( "Error:Unknown type for field import" + value );
}
field.setItem( "V", cos );
}
/**
* This will get the Ff entry of the cos dictionary. If it it not present then
* this method will return null.
*
* @return The field flags.
*/
public Integer getFieldFlags()
{
Integer retval = null;
COSNumber ff = (COSNumber)field.getDictionaryObject( "Ff" );
if( ff != null )
{
retval = new Integer( ff.intValue() );
}
return retval;
}
/**
* This will get the field flags that are associated with this field. The Ff entry
* in the FDF field dictionary.
*
* @param ff The new value for the field flags.
*/
public void setFieldFlags( Integer ff )
{
COSInteger value = null;
if( ff != null )
{
value = new COSInteger( ff.intValue() );
}
field.setItem( "Ff", value );
}
/**
* This will get the field flags that are associated with this field. The Ff entry
* in the FDF field dictionary.
*
* @param ff The new value for the field flags.
*/
public void setFieldFlags( int ff )
{
field.setItem( "Ff", new COSInteger( ff ) );
}
/**
* This will get the SetFf entry of the cos dictionary. If it it not present then
* this method will return null.
*
* @return The field flags.
*/
public Integer getSetFieldFlags()
{
Integer retval = null;
COSNumber ff = (COSNumber)field.getDictionaryObject( "SetFf" );
if( ff != null )
{
retval = new Integer( ff.intValue() );
}
return retval;
}
/**
* This will get the field flags that are associated with this field. The SetFf entry
* in the FDF field dictionary.
*
* @param ff The new value for the "set field flags".
*/
public void setSetFieldFlags( Integer ff )
{
COSInteger value = null;
if( ff != null )
{
value = new COSInteger( ff.intValue() );
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -