setasign\SetaPDF2\FormFiller\Field

TextField A text field

File: /SetaPDF v2/FormFiller/Field/TextField.php
Old class name (alias): \SetaPDF_FormFiller_Field_Text

Class hierarchy

Uses

Implements

Summary

Constants

OVERFLOWS_HORIZONTALLY

public const int TextField::OVERFLOWS_HORIZONTALLY = 2

Constant saying that text overflows horizontally

OVERFLOWS_NONE

public const int TextField::OVERFLOWS_NONE = 0

Constant saying that no text overflows the visible area

OVERFLOWS_VERTICALLY

public const int TextField::OVERFLOWS_VERTICALLY = 1

Constant saying that text overflows vertically


Properties

$_annotation

The annotation object of this form field

$_appearanceCanvas

The canvas object of the appearance

$_appearanceCreated

protected bool AbstractField::$_appearanceCreated = false

$_appearanceValueCallback

protected callback TextField::$_appearanceValueCallback = array(...)

A callback that may change the appearance value (e.g. format a number)

$_fieldDictionary

The main field dictionary

$_fieldObject

The fields indirect object

$_fields

A reference to the fields instance

$_font

The font object, which should be used to create the appearance

$_fontSize

protected ?float AbstractField::$_fontSize

The font size, which should be used to create the appearance

$_lineHeightFactor

The factor to calculate the line height based on the font size

$_observeTextOverflow

protected bool TextField::$_observeTextOverflow = false

Defines whether observing text overflow is enabled or not

$_originalQualifiedName

The name without the suffix

$_page

The page instance on which the form field is placed

$_qualifiedName

protected string AbstractField::$_qualifiedName

The name including a suffix if needed ("Text#1")

$_textColor

An individual color object which should be used for drawing the text appearance

$_textColorSpace

An individual color space object which should be used for setting the non-stroking color space

$_textOverflow

protected ?int TextField::$_textOverflow

Flag indicating that the text overflows the visible area of the field.

$_textTranslateData

protected array TextField::$_textTranslateData = array(...)

Data to be used for translation of the initial x/y coordinates of the field appearance.


Methods

__construct()

public AbstractField::__construct (
\SetaPDF_FormFiller_Fields $fields,
string $qualifiedName,
\SetaPDF_Core_Type_IndirectObject $fieldObject,
string $originalQualifiedName = null
)

The constructor.

Parameters
$fields : \SetaPDF_FormFiller_Fields

The fields instance

$qualifiedName : string

The qualified name of the field

$fieldObject : \SetaPDF_Core_Type_IndirectObject

The indirect object holding the field dictionary (terminal field object)

$originalQualifiedName : string

The original qualified name of the field

Exceptions

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\Core\Type\IndirectReference\Exception

_checkPermission()

Checks for form-filling permissions.

Parameters
$permission : int
 
Exceptions

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

_getAppearanceReference()

Get the reference to the normal appearance stream object.

_getBorderWidthAndStyle()

protected AbstractField::_getBorderWidthAndStyle (
void
): array

Resolve the border width and style

Exceptions

Throws \setasign\SetaPDF2\Core\Type\Exception

_getFontRelation()

Get the font relation and copy the resources to the Resources entry if needed.

Parameters
$nDictionary : \SetaPDF_Core_Type_Dictionary
 
$fontName : string
 
Exceptions

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

_getTDictionary()

Get the dictionary that holds the last "T" entry.

_postDelete()

protected AbstractField::_postDelete (
void
): void

A method called after deleting a field.

This method forwards the deletion info to the fields instance.

_preDelete()

protected AbstractField::_preDelete (
void
): void

A method called before deleting a field.

This method forwards the deletion info to the fields instance.

Exceptions

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

_preFlatten()

protected AbstractField::_preFlatten (
void
): void

A method called before flattening a field.

This method forwards the flatten info to the fields instance.

Exceptions

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

_purgeValue()

protected TextField::_purgeValue (
string $value
): string

Purges the value accoring to field properties like "multiline" or "max-length".

Parameters
$value : string

Value in UTF-16BE encoding

_recreateAppearance()

protected AbstractField::_recreateAppearance (
bool $circle = false,
?\SetaPDF_Core_Canvas $canvas = null
): \SetaPDF_Core_Canvas

Recreate or creates the background appearance of the form field.

Parameters
$circle : bool
 
$canvas : ?\SetaPDF_Core_Canvas
 
Exceptions

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\NotImplementedException

cleanUp()

public TextField::cleanUp (
void
): void

Release cycled references and release memory.

flatten()

public AbstractField::flatten (
bool $recreateAppearanceIfNeedAppearancesIsSet = false
): void

Flatten the field to the pages content stream.

Parameters
$recreateAppearanceIfNeedAppearancesIsSet : bool

Defines whether the field appearance is re-created if the NeedAppearances flag is set.

Exceptions

Throws \setasign\SetaPDF2\Core\Document\ObjectNotFoundException

Throws \setasign\SetaPDF2\Core\Exception

Throws \setasign\SetaPDF2\Core\Parser\Pdf\InvalidTokenException

Throws \setasign\SetaPDF2\Core\Reader\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\Core\Type\IndirectReference\Exception

Throws \setasign\SetaPDF2\Exception

Throws \setasign\SetaPDF2\NotImplementedException

See

getAdditionalActions()

Gets the additional actions object instance for this field.

getAlign()

public VariableTextTrait::getAlign (
void
): string

Get the field alignment.

getAnnotation()

Get the widget annotation object from this field.

Exceptions

Throws \setasign\SetaPDF2\Core\Type\Exception

getAppearanceCanvas()

Get the appearance canvas of the "normal" appearance object.

Exceptions

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\NotImplementedException

getAppearanceTextColorSpace()

Get the individual color space object which should be used for setting the non-stroking color space.

getAppearanceValue()

public TextField::getAppearanceValue (
string $encoding = 'UTF-8'
): string

Get the appearance value.

Parameters
$encoding : string
 

getDefaultValue()

public TextField::getDefaultValue (
string $encoding = 'UTF-8'
): ?string

Returns the default value of the field.

This value is used if the form is reset.

Parameters
$encoding : string
 
See

getFieldDictionary()

Get the field dictionary.

getFieldFlags()

public AbstractField::getFieldFlags (
void
): int

Returns the current field flags.

getFieldObject()

Get the indirect object of the form field.

getFields()

Get the fields instance.

getLineHeightFactor()

public AbstractField::getLineHeightFactor (
void
): float

Get the line height factor

The line height is calculated by this factor in relation to the font size:

$lineHeight = $fontSize * $lineHeightFactor

By default, this value is calculated by the font bounding box values "ury - lly / 1000".

Exceptions

Throws \setasign\SetaPDF2\Core\Exception

Throws \setasign\SetaPDF2\Core\Font\Exception

Throws \setasign\SetaPDF2\Core\Parser\Pdf\InvalidTokenException

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\Core\Type\IndirectReference\Exception

Throws \setasign\SetaPDF2\NotImplementedException

Throws \setasign\SetaPDF2\FormFiller\Exception

Throws Exception

See

getMaxLength()

public TextField::getMaxLength (
void
): bool|int

Get the max length property if available.

getName()

public AbstractField::getName (
void
): string

Alias for getQualifiedName().

See

getNoExport()

public AbstractField::getNoExport (
void
): bool

Checks if the no-export flag is set.

getNormalAppearanceObject()

Get or create the normal appearance object (the object referenced in the N entry).

Parameters
$createNew : bool

Pass true to force a recreation

Exceptions

Throws \setasign\SetaPDF2\Core\Type\Exception

getObserveTextOverflow()

public TextField::getObserveTextOverflow (
void
): bool

Get whether observing text overflow is enabled or not.

getOriginalQualifiedName()

public AbstractField::getOriginalQualifiedName (
void
): string

Get the original qualified name (without suffix).

getPage()

Gets the page object on which the form field is placed.

Exceptions

Throws \setasign\SetaPDF2\Core\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws Exception

getQualifiedName()

public AbstractField::getQualifiedName (
void
): string

Returns the qualified name.

getTextOverflow()

public TextField::getTextOverflow (
void
): ?int

Check if the visible text overflows the visible area.

Return Values

If text does not overflow 0 is returned. Otherwise 1 if the text overflows vertically or 2 if the text overflows horizontally. 3 for both. Null is returned if the overflow is not calculated yet.

getTooltip()

public AbstractField::getTooltip (
string $encoding = 'UTF-8'
): bool|string

Get the tooltip value.

Parameters
$encoding : string
 

getValue()

public TextField::getValue (
string $encoding = 'UTF-8'
): string

Get the field value.

Parameters
$encoding : string

The output encoding

See

getVisibleValue()

public TextField::getVisibleValue (
string $encoding = 'UTF-8'
): string

Returns the field specific visible value.

Parameters
$encoding : string
 

isCombField()

public TextField::isCombField (
void
): bool

Check if the comb field flag is set.

isDoNotScrollSet()

public TextField::isDoNotScrollSet (
void
): bool

Check if the "do not scroll" flag is set.

isDoNotSpellCheckSet()

public TextField::isDoNotSpellCheckSet (
void
): bool

Check if the "do not spell check" flag is set.

isFieldFlagSet()

public AbstractField::isFieldFlagSet (
int $flag
): bool

Checks if a specific field flag is set.

Parameters
$flag : int
 

isMultiline()

public TextField::isMultiline (
void
): bool

Check if the multiline flag is set.

isPasswordField()

public TextField::isPasswordField (
void
): bool

Check if the password field flag is set.

isReadOnly()

public AbstractField::isReadOnly (
void
): bool

Checks if the field is set to read-only.

isRequired()

public AbstractField::isRequired (
void
): bool

Checks if the field is set to be required.

setAppearanceFont()

public AbstractField::setAppearanceFont (
\SetaPDF_Core_Font_FontInterface $font,
float $size = null
): void

Set the appearance font object.

Parameters
$font : \SetaPDF_Core_Font_FontInterface
 
$size : float
 

setAppearanceFontSize()

public AbstractField::setAppearanceFontSize (
?float $fontSize
): void

Set an individual font size.

Parameters
$fontSize : ?float
 

setAppearanceTextColor()

Set an individual appearance text color.

Parameters
$textColor : ?\SetaPDF_Core_DataStructure_Color
 

setAppearanceTextColorSpace()

Set the individual color space object which should be used for setting the non-stroking color space.

Parameters
$colorSpace : ?\SetaPDF_Core_ColorSpace
 

setAppearanceValueCallback()

public TextField::setAppearanceValueCallback (
callback $callback
): void

Set the appearance value callback (to e.g. format a number).

The callback will be called with 2 arguments:

  1. A reference to the field instance
  2. The requested encoding

It needs to return a value in the specified encoding (internal calls need UTF-16BE throughout).

Parameters
$callback : callback
 

setDefaultValue()

public TextField::setDefaultValue (
?string $value,
string $encoding = 'UTF-8'
): void

Set the default value of the field.

Parameters
$value : ?string
 
$encoding : string
 
Exceptions

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\Core\Type\IndirectReference\Exception

Throws \setasign\SetaPDF2\FormFiller\Exception

setDoNotScroll()

public TextField::setDoNotScroll (
bool $doNotScroll = true
): void

Set the "do not scroll" flag.

Parameters
$doNotScroll : bool
 

setDoNotSpellCheck()

public TextField::setDoNotSpellCheck (
bool $doNotSpellCheck = true
): void

Set the "do not spell check" flag.

Parameters
$doNotSpellCheck : bool
 
Exceptions

Throws Exception

setFieldFlags()

public AbstractField::setFieldFlags (
int $flags,
?bool $add = true
): void

Sets a field flag.

Parameters
$flags : int
 
$add : ?bool

Add = true, remove = false, set = null

setLineHeightFactor()

public AbstractField::setLineHeightFactor (
?float $lineHeightFactor
): void

Set the line height factor

The line height is calculated by this factor in relation to the font size:

$lineHeight = $fontSize * $lineHeightFactor

By default, this value is calculated by the font bounding box values "ury - lly / 1000".

Parameters
$lineHeightFactor : ?float
 
See

setMaxLength()

public TextField::setMaxLength (
int $maxLength
): void

Set the max length property.

Changing this flag will reset the value to a value that fits into the given maximal length.

Parameters
$maxLength : int
 
Exceptions

Throws \setasign\SetaPDF2\Core\Exception

Throws \setasign\SetaPDF2\Core\Font\Exception

Throws \setasign\SetaPDF2\Core\Parser\Pdf\InvalidTokenException

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\Core\Type\IndirectReference\Exception

Throws \setasign\SetaPDF2\NotImplementedException

Throws \setasign\SetaPDF2\FormFiller\Exception

Throws Exception

setMultiline()

setNoExport()

public AbstractField::setNoExport (
bool $noExport = true
): void

Set the no-export flag.

Parameters
$noExport : bool
 

setObserveTextOverflow()

public TextField::setObserveTextOverflow (
bool $observeTextOverflow
): void

Set whether observing text overflow is enabled or not.

Parameters
$observeTextOverflow : bool
 

setPasswordField()

setReadOnly()

public AbstractField::setReadOnly (
bool $readOnly = true
): void

Sets the read-only flag.

Parameters
$readOnly : bool
 
Exceptions

Throws \DOMException

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\Exception

Throws \setasign\SetaPDF2\NotImplementedException

Throws \setasign\SetaPDF2\FormFiller\Exception

setRequired()

public AbstractField::setRequired (
bool $required = true
): void

Sets the required flag.

Parameters
$required : bool
 

setTextTranslate()

public TextField::setTextTranslate (
int $x = 0,
int $y = 0
): void

Set translate data for the text appearance.

Parameters
$x : int

The value by which the text should be translated on the abscissa.

$y : int

The value by which the text should be translated on the ordinate.

setTooltip()

public AbstractField::setTooltip (
string|false $value,
string $encoding = 'UTF-8'
): void

Set the tooltip value.

Parameters
$value : string|false
 
$encoding : string
 

setValue()

public TextField::setValue (
string $value,
string $encoding = 'UTF-8'
): void

Set the field value.

If the fields multiline flag is set (see isMultiline()) the method accepts a string of several lines.

All common line delimiters are possible: \r\n, \n or \r

Internally they get normalized. So if you need to compare a value of the getValue() method keep this in mind.

Parameters
$value : string

The text field value

$encoding : string

The input encoding

Exceptions

Throws \setasign\SetaPDF2\Core\Exception

Throws \setasign\SetaPDF2\Core\Font\Exception

Throws \setasign\SetaPDF2\Core\Parser\Pdf\InvalidTokenException

Throws \setasign\SetaPDF2\Core\SecHandler\Exception

Throws \setasign\SetaPDF2\Core\Type\Exception

Throws \setasign\SetaPDF2\Core\Type\IndirectReference\Exception

Throws \setasign\SetaPDF2\NotImplementedException

Throws \setasign\SetaPDF2\FormFiller\Exception

Throws Exception

unsetFieldFlags()

public AbstractField::unsetFieldFlags (
int $flags
): void

Removes a field flag.

Parameters
$flags : int