Class PDChoice
- java.lang.Object
-
- org.apache.pdfbox.pdmodel.interactive.form.PDField
-
- org.apache.pdfbox.pdmodel.interactive.form.PDTerminalField
-
- org.apache.pdfbox.pdmodel.interactive.form.PDVariableText
-
- org.apache.pdfbox.pdmodel.interactive.form.PDChoice
-
- All Implemented Interfaces:
COSObjectable
- Direct Known Subclasses:
PDComboBox,PDListBox
public abstract class PDChoice extends PDVariableText
A choice field contains several text items, one or more of which shall be selected as the field value.
-
-
Field Summary
Fields Modifier and Type Field Description (package private) static intFLAG_COMBOprivate static intFLAG_COMMIT_ON_SEL_CHANGEprivate static intFLAG_DO_NOT_SPELL_CHECKprivate static intFLAG_MULTI_SELECTprivate static intFLAG_SORT-
Fields inherited from class org.apache.pdfbox.pdmodel.interactive.form.PDVariableText
QUADDING_CENTERED, QUADDING_LEFT, QUADDING_RIGHT
-
-
Constructor Summary
Constructors Constructor Description PDChoice(PDAcroForm acroForm)PDChoice(PDAcroForm acroForm, COSDictionary field, PDNonTerminalField parent)Constructor.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description (package private) abstract voidconstructAppearances()Constructs appearance streams and appearance dictionaries for all widget annotations.java.util.List<java.lang.String>getDefaultValue()Returns the default values, or an empty List.java.util.List<java.lang.String>getOptions()This will get the option values "Opt".java.util.List<java.lang.String>getOptionsDisplayValues()This will get the display values from the options.java.util.List<java.lang.String>getOptionsExportValues()This will get the export values from the options.java.util.List<java.lang.Integer>getSelectedOptionsIndex()This will get the indices of the selected options - the 'I' key.java.util.List<java.lang.String>getValue()Returns the selected values, or an empty List.java.lang.StringgetValueAsString()Returns a string representation of the "V" entry, or an empty string.private java.util.List<java.lang.String>getValueFor(COSName name)Returns the selected values, or an empty List, for the given key.booleanisCombo()Determines if Combo is set.booleanisCommitOnSelChange()Determines if CommitOnSelChange is set.booleanisDoNotSpellCheck()Determines if DoNotSpellCheck is set.booleanisMultiSelect()Determines if MultiSelect is set.booleanisSort()Determines if Sort is set.voidsetCombo(boolean combo)Set the Combo bit.voidsetCommitOnSelChange(boolean commitOnSelChange)Set the CommitOnSelChange bit.voidsetDefaultValue(java.lang.String value)Sets the default value of this field.voidsetDoNotSpellCheck(boolean doNotSpellCheck)Set the DoNotSpellCheck bit.voidsetMultiSelect(boolean multiSelect)Set the MultiSelect bit.voidsetOptions(java.util.List<java.lang.String> displayValues)This will set the display values - the 'Opt' key.voidsetOptions(java.util.List<java.lang.String> exportValues, java.util.List<java.lang.String> displayValues)This will set the display and export values - the 'Opt' key.voidsetSelectedOptionsIndex(java.util.List<java.lang.Integer> values)This will set the indices of the selected options - the 'I' key.voidsetSort(boolean sort)Set the Sort bit.voidsetValue(java.lang.String value)Set the selected value of this field, and try to update the visual appearance.voidsetValue(java.util.List<java.lang.String> values)Sets the entry "V" to the given values.private voidupdateSelectedOptionsIndex(java.util.List<java.lang.String> values, java.util.List<java.lang.String> options)Update the 'I' key based on values set.-
Methods inherited from class org.apache.pdfbox.pdmodel.interactive.form.PDVariableText
getDefaultAppearance, getDefaultAppearanceString, getDefaultStyleString, getQ, getRichTextValue, getStringOrStream, setDefaultAppearance, setDefaultStyleString, setQ, setRichTextValue
-
Methods inherited from class org.apache.pdfbox.pdmodel.interactive.form.PDTerminalField
applyChange, exportFDF, getFieldFlags, getFieldType, getWidgets, importFDF, setActions, setWidgets
-
Methods inherited from class org.apache.pdfbox.pdmodel.interactive.form.PDField
findKid, fromDictionary, getAcroForm, getActions, getAlternateFieldName, getCOSObject, getFullyQualifiedName, getInheritableAttribute, getMappingName, getParent, getPartialName, isNoExport, isReadOnly, isRequired, setAlternateFieldName, setFieldFlags, setMappingName, setNoExport, setPartialName, setReadOnly, setRequired, toString
-
-
-
-
Field Detail
-
FLAG_COMBO
static final int FLAG_COMBO
- See Also:
- Constant Field Values
-
FLAG_SORT
private static final int FLAG_SORT
- See Also:
- Constant Field Values
-
FLAG_MULTI_SELECT
private static final int FLAG_MULTI_SELECT
- See Also:
- Constant Field Values
-
FLAG_DO_NOT_SPELL_CHECK
private static final int FLAG_DO_NOT_SPELL_CHECK
- See Also:
- Constant Field Values
-
FLAG_COMMIT_ON_SEL_CHANGE
private static final int FLAG_COMMIT_ON_SEL_CHANGE
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
PDChoice
public PDChoice(PDAcroForm acroForm)
- Parameters:
acroForm- The acroform.- See Also:
PDField(PDAcroForm)
-
PDChoice
PDChoice(PDAcroForm acroForm, COSDictionary field, PDNonTerminalField parent)
Constructor.- Parameters:
acroForm- The form that this field is part of.field- the PDF object to represent as a field.parent- the parent node of the node
-
-
Method Detail
-
getOptions
public java.util.List<java.lang.String> getOptions()
This will get the option values "Opt".For a choice field the options array can either be an array of text strings or an array of a two-element arrays.
The method always only returns either the text strings or, in case of two-element arrays, an array of the first element of the two-element arraysUse
getOptionsExportValues()andgetOptionsDisplayValues()to get the entries of two-element arrays.- Returns:
- List containing the export values.
-
setOptions
public void setOptions(java.util.List<java.lang.String> displayValues)
This will set the display values - the 'Opt' key.The Opt array specifies the list of options in the choice field either as an array of text strings representing the display value or as an array of a two-element array where the first element is the export value and the second the display value.
To set both the export and the display value use
setOptions(List, List)- Parameters:
displayValues- List containing all possible options.
-
setOptions
public void setOptions(java.util.List<java.lang.String> exportValues, java.util.List<java.lang.String> displayValues)This will set the display and export values - the 'Opt' key.This will set both, the export value and the display value of the choice field. If either one of the parameters is null or an empty list is supplied the options will be removed.
An
IllegalArgumentExceptionwill be thrown if the number of items in the list differ.- Parameters:
exportValues- List containing all possible export values.displayValues- List containing all possible display values.- See Also:
setOptions(List)
-
getOptionsDisplayValues
public java.util.List<java.lang.String> getOptionsDisplayValues()
This will get the display values from the options.For options with an array of text strings the display value and export value are the same.
For options with an array of two-element arrays the display value is the second entry in the two-element array.- Returns:
- List containing all the display values.
-
getOptionsExportValues
public java.util.List<java.lang.String> getOptionsExportValues()
This will get the export values from the options.For options with an array of text strings the display value and export value are the same.
For options with an array of two-element arrays the export value is the first entry in the two-element array.- Returns:
- List containing all export values.
-
getSelectedOptionsIndex
public java.util.List<java.lang.Integer> getSelectedOptionsIndex()
This will get the indices of the selected options - the 'I' key.This is only needed if a choice field allows multiple selections and two different items have the same export value or more than one values is selected.
The indices are zero-based
- Returns:
- List containing the indices of all selected options.
-
setSelectedOptionsIndex
public void setSelectedOptionsIndex(java.util.List<java.lang.Integer> values)
This will set the indices of the selected options - the 'I' key.This method is preferred over
setValue(List)for choice fields which- do support multiple selections
- have export values with the same value
Setting the index will set the value too.
- Parameters:
values- List containing the indices of all selected options.
-
isSort
public boolean isSort()
Determines if Sort is set.If set, the field’s option items shall be sorted alphabetically. The sorting has to be done when writing the PDF. PDF Readers are supposed to display the options in the order in which they occur in the Opt array.
- Returns:
- true if the options are sorted.
-
setSort
public void setSort(boolean sort)
Set the Sort bit.- Parameters:
sort- The value for Sort.- See Also:
isSort()
-
isMultiSelect
public boolean isMultiSelect()
Determines if MultiSelect is set.- Returns:
- true if multi select is allowed.
-
setMultiSelect
public void setMultiSelect(boolean multiSelect)
Set the MultiSelect bit.- Parameters:
multiSelect- The value for MultiSelect.
-
isDoNotSpellCheck
public boolean isDoNotSpellCheck()
Determines if DoNotSpellCheck is set.- Returns:
- true if spell checker is disabled.
-
setDoNotSpellCheck
public void setDoNotSpellCheck(boolean doNotSpellCheck)
Set the DoNotSpellCheck bit.- Parameters:
doNotSpellCheck- The value for DoNotSpellCheck.
-
isCommitOnSelChange
public boolean isCommitOnSelChange()
Determines if CommitOnSelChange is set.- Returns:
- true if value shall be committed as soon as a selection is made.
-
setCommitOnSelChange
public void setCommitOnSelChange(boolean commitOnSelChange)
Set the CommitOnSelChange bit.- Parameters:
commitOnSelChange- The value for CommitOnSelChange.
-
isCombo
public boolean isCombo()
Determines if Combo is set.- Returns:
- true if value the choice is a combo box..
-
setCombo
public void setCombo(boolean combo)
Set the Combo bit.- Parameters:
combo- The value for Combo.
-
setValue
public void setValue(java.lang.String value) throws java.io.IOExceptionSet the selected value of this field, and try to update the visual appearance.
-
setDefaultValue
public void setDefaultValue(java.lang.String value)
Sets the default value of this field.- Parameters:
value- The name of the selected item.
-
setValue
public void setValue(java.util.List<java.lang.String> values) throws java.io.IOExceptionSets the entry "V" to the given values. RequiresisMultiSelect()to be true.- Parameters:
values- the list of values- Throws:
java.io.IOException- if the appearance couldn't be generated.
-
getValue
public java.util.List<java.lang.String> getValue()
Returns the selected values, or an empty List. This list always contains a single item unlessisMultiSelect()is true.- Returns:
- A non-null string.
-
getDefaultValue
public java.util.List<java.lang.String> getDefaultValue()
Returns the default values, or an empty List. This list always contains a single item unlessisMultiSelect()is true.- Returns:
- A non-null string.
-
getValueFor
private java.util.List<java.lang.String> getValueFor(COSName name)
Returns the selected values, or an empty List, for the given key.
-
getValueAsString
public java.lang.String getValueAsString()
Description copied from class:PDFieldReturns a string representation of the "V" entry, or an empty string.- Specified by:
getValueAsStringin classPDField- Returns:
- The list of widget annotations.
-
updateSelectedOptionsIndex
private void updateSelectedOptionsIndex(java.util.List<java.lang.String> values, java.util.List<java.lang.String> options)Update the 'I' key based on values set.
-
constructAppearances
abstract void constructAppearances() throws java.io.IOExceptionDescription copied from class:PDTerminalFieldConstructs appearance streams and appearance dictionaries for all widget annotations. Subclasses should not call this method directly but viaPDTerminalField.applyChange().- Specified by:
constructAppearancesin classPDTerminalField- Throws:
java.io.IOException- if the appearance couldn't be generated
-
-