Foxit PDF SDK
|
Public Member Functions | |
def | PDFPage (document, page_dict) |
Constructor, from a PDF dictionary which represents a PDF page and the PDF document which contains the dictionary.. More... | |
def | AddAnnot (type, rect) |
Add an annotation to current PDF page. More... | |
def | AddImage (image, frame_index, position, width, height, auto_generate_content) |
Add an image to current page. More... | |
def | AddImageFromFilePath (file_path, position, width, height, auto_generate_content) |
Add an image to current page from file path. More... | |
def | AddSignature (rect) |
Add an ordinary signature to PDF page. More... | |
def | AddText (text, rect, style) |
Add text to current page. More... | |
def | CalcContentBBox (mode) |
Calculate the content area of PDF page. More... | |
def | ClearRenderCache () |
Clear render cache. More... | |
def | Flatten (for_display, options) |
Flatten current PDF page: annotations or form fields may be made to be a part of the page contents according to specified options. More... | |
def | FlattenAnnot (annot) |
Flatten an annotation: the annotation is made to be a part of the page contents and be removed then. More... | |
def | GetAnnot (index) |
Get an annotation by index. More... | |
def | GetAnnotAtDevicePoint (position, tolerance, matrix) |
Get the annotation at a specified position, in device coordinate system. More... | |
def | GetAnnotAtPoint (position, tolerance) |
Get the annotation at a specified position, in [PDF coordinate system] (). More... | |
def | GetAnnotCount () |
Get the count of annotations. More... | |
def | GetAnnots () |
Get the PDF array of "Annots". More... | |
def | GetAnnotsAtDevicePoint (position, tolerance, matrix) |
Get all the annotations at a specified position, in device coordinate system. More... | |
def | GetAnnotsAtPoint (position, tolerance) |
Get all the annotations at a specified position, in [PDF coordinate system] (). More... | |
def | GetBox (box_type) |
Get page box. More... | |
def | GetContents () |
Get the PDF object of "Contents". More... | |
def | GetDict () |
Get the page dictionary. More... | |
def | GetDisplayMatrix (left, top, width, height, rotate) |
Get the display matrix of PDF page, from [PDF coordinate system] () to targeted device coordinate system. More... | |
def | GetDocument () |
Get the PDF document, to which current PDF page belongs. More... | |
def | GetGraphicsObjectAtDevicePoint (point, tolerance, matrix, filter) |
Get the topmost graphics object in specified point in device coordinate system, with specified type filter. More... | |
def | GetGraphicsObjectAtPoint (point, tolerance, filter) |
Get the topmost graphics object in specified point, with specified type filter. More... | |
def | GetGraphicsObjectAtRectangle (rect, filter) |
Get the topmost graphics object whose rectangle interasects with a specified rectangle, with specified type filter. More... | |
def | GetGraphicsObjectsAtDevicePoint (point, tolerance, matrix, filter) |
Get all the graphics objects in specified point in device coordinate system, with specified type filter. More... | |
def | GetGraphicsObjectsAtPoint (point, tolerance, filter) |
Get all the graphics objects in specified point, with specified type filter. More... | |
def | GetGraphicsObjectsAtRectangle (rect, filter) |
Get all the graphics objects whose rectangles intersect with a specified rectangle, with specified type filter. More... | |
def | GetHeight () |
Get the page height (unit is 1/72 inch). More... | |
def | GetIndex () |
Get page index. More... | |
def | GetInheritedAttribute (attruibute_name) |
Get the PDF object for specified attribute which may be inherited from the ancestor node in the page tree. More... | |
def | GetResources () |
Get the PDF dictionary of "Resources". More... | |
def | GetRotation () |
Get the page rotation. More... | |
def | GetSuggestedRect (render_result, render_matrix, point) |
Get the suggested rectangle (in [PDF coordinate system] ()) for a point (in [PDF coordinate system] ()) based on the rendering result bitmap. More... | |
def | GetThumb () |
Get the PDF stream of "Thumb". More... | |
def | GetUserUnitSize () |
Get the user unit. More... | |
def | GetWidth () |
Get the page width (unit is 1/72 inch). More... | |
def | HasTransparency () |
Check whether current PDF page has transparency or not. More... | |
def | HasWatermark () |
Check whether the current page has any watermark (not including Foxit PDF SDK trial watermark). More... | |
def | IsParsed () |
Check if current page has been parsed or not. More... | |
def | LoadThumbnail () |
Load the thumbnail bitmap. More... | |
def | MoveAnnotToFirst (annot) |
Change specified annotation to be the first one of all annotations. More... | |
def | MoveAnnotToLast (annot) |
Change specified annotation to be the last one of all annotations. More... | |
def | MoveAnnotToNext (annot) |
Exchange the indexes of current annotation and its next annotation. More... | |
def | MoveAnnotToPrev (annot) |
Exchange the indexes of current annotation and its previous annotation. More... | |
def | Normalize () |
Transform current PDF page by undoing any rotation and removing the offset to the page's "CropBox". More... | |
def | RemoveAllWatermarks () |
Remove all watermarks. More... | |
def | RemoveAnnot (annot) |
Remove an annotation. More... | |
def | SetAnnotGroup (annot_array, header_index) |
Group all the input markup annotations together. More... | |
def | SetBox (box_type, box) |
Set page box. More... | |
def | SetClipRect (clip_rect) |
Set clip rectangle for all graphics objects on current PDF page. More... | |
def | SetRotation (rotate) |
Set page rotation. More... | |
def | SetSize (width, height) |
Set page width and height. More... | |
def | SetThumbnail (thumbnail) |
Set page thumbnail. More... | |
def | SetUserUnitSize (user_unit) |
Set the user unit. More... | |
def | StartParse (flags, pause, is_reparse) |
Start to parse current page. More... | |
def | Transform (matrix, need_transform_clip_path, need_transform_annotations) |
Transform a PDF page, including annotations and form fields on the page. More... | |
def | UpdateAnnotList () |
Update the annotation list. More... | |
![]() | |
def | GraphicsObjects (other) |
Constructor, with another GraphicsObjects object. More... | |
def | GenerateContent () |
Generate contents of current graphics objects. More... | |
def | GetFirstGraphicsObjectPosition (filter) |
Get the position of first graphics object in graphics object list, based on type filter. More... | |
def | GetGraphicsObject (position) |
Get the graphics object by position in graphics object list. More... | |
def | GetGraphicsObjectCount () |
Get the count of graphics objects in graphics object list. More... | |
def | GetGraphicsObjectIndex (graphics_object) |
Get the index of a specified graphics object in graphics object list. More... | |
def | GetGraphicsObjectPosition (graphics_object) |
Get the position of the specified graphics object. More... | |
def | GetLastGraphicsObjectPosition (filter) |
Get the position of last graphics object in graphics object list, based on type filter. More... | |
def | GetNextGraphicsObjectPosition (position, filter) |
Get the position of next graphics object in graphics object list, based on type filter and specified current position. More... | |
def | GetPrevGraphicsObjectPosition (position, filter) |
Get the position of previous graphics object in graphics object list, based on type filter and specified current position. More... | |
def | InsertGraphicsObject (position_insert_after, graphics_object) |
Insert a graphics object after the specified position. More... | |
def | IsEmpty () |
Check whether current object is empty or not. More... | |
def | MoveGraphicsObjectByPosition (current_position, position_move_after) |
Move a graphics object from a position to another position. More... | |
def | RemoveGraphicsObject (graphics_object) |
Remove a graphics object. More... | |
def | RemoveGraphicsObjectByPosition (position) |
Remove a graphics object by position. More... | |
Static Public Attributes | |
e_ArtBox = _fsdk.PDFPage_e_ArtBox | |
Art Box for page boundary. More... | |
e_BleedBox = _fsdk.PDFPage_e_BleedBox | |
Bleed Box for page boundary. More... | |
e_CalcContentsBox = _fsdk.PDFPage_e_CalcContentsBox | |
Calculate margin according to bounding box of all contents. | |
e_CalcDetection = _fsdk.PDFPage_e_CalcDetection | |
Calculate margin by detecting paths or images. | |
e_CropBox = _fsdk.PDFPage_e_CropBox | |
Crop Box for page boundary. More... | |
e_FlattenAll = _fsdk.PDFPage_e_FlattenAll | |
Flatten all contents of a PDF page. | |
e_FlattenNoAnnot = _fsdk.PDFPage_e_FlattenNoAnnot | |
Flatten a PDF page without annotations. | |
e_FlattenNoFormControl = _fsdk.PDFPage_e_FlattenNoFormControl | |
Flatten a PDF page without form controls. | |
e_MediaBox = _fsdk.PDFPage_e_MediaBox | |
Media Box for page boundary. More... | |
e_ParsePageNormal = _fsdk.PDFPage_e_ParsePageNormal | |
Parsing flag for normal mode, which means to parse all the contents in a PDF page. | |
e_ParsePageTextOnly = _fsdk.PDFPage_e_ParsePageTextOnly | |
Parsing flag for text-only mode. | |
e_SizeA2 = _fsdk.PDFPage_e_SizeA2 | |
Page size: A2. | |
e_SizeA3 = _fsdk.PDFPage_e_SizeA3 | |
Page size: A3. | |
e_SizeA4 = _fsdk.PDFPage_e_SizeA4 | |
Page size: A4. | |
e_SizeA5 = _fsdk.PDFPage_e_SizeA5 | |
Page size: A5. | |
e_SizeA6 = _fsdk.PDFPage_e_SizeA6 | |
Page size: A6. | |
e_SizeB2 = _fsdk.PDFPage_e_SizeB2 | |
Page size: B2. | |
e_SizeB3 = _fsdk.PDFPage_e_SizeB3 | |
Page size: B3. | |
e_SizeB4 = _fsdk.PDFPage_e_SizeB4 | |
Page size: B4. | |
e_SizeB5 = _fsdk.PDFPage_e_SizeB5 | |
Page size: B5. | |
e_SizeB6 = _fsdk.PDFPage_e_SizeB6 | |
Page size: B6. | |
e_SizeLegal = _fsdk.PDFPage_e_SizeLegal | |
Page size: legal. | |
e_SizeLetter = _fsdk.PDFPage_e_SizeLetter | |
Page size: letter. | |
e_TrimBox = _fsdk.PDFPage_e_TrimBox | |
Trim Box for page boundary. More... | |
![]() | |
e_TextMergeBTET = _fsdk.GraphicsObjects_e_TextMergeBTET | |
Merge consecutive BTETs as a new one. More... | |
e_TextMergeNone = _fsdk.GraphicsObjects_e_TextMergeNone | |
No text merge. | |
e_TextMergeTJY = _fsdk.GraphicsObjects_e_TextMergeTJY | |
Merge consecutive text-showing operators with equal y coordinates. | |
A PDF page is defined in PDF coordinate system which uses the lower-left corner of the page as origin point (0, 0).
Usually, a PDF page object is retrieved from a PDF document by function FoxitPDFSDKPython2.PDFDoc.GetPage . For most case, a PDF page should be parsed first and then be used. Function FoxitPDFSDKPython2.PDFPage.IsParsed can be used to judge whether the PDF page has been parsed or not. For a unparsed page, please use function FoxitPDFSDKPython2.PDFPage.StartParse to parse it.
This class offers functions to get/set data of a PDF page, such as page width/height, page rotation, display matrix and so on. Also, this class offers functions to retrieve PDF annotations:
To get a PDF annotation, use function FoxitPDFSDKPython2.PDFPage.GetAnnot , FoxitPDFSDKPython2.PDFPage.GetAnnotAtPoint , or FoxitPDFSDKPython2.PDFPage.GetAnnotAtDevicePoint .
To add a new PDF annotation, use function FoxitPDFSDKPython2.PDFPage.AddAnnot .
To remove a PDF annotation, use function FoxitPDFSDKPython2.PDFPage.RemoveAnnot .
Class FoxitPDFSDKPython2.PDFPage is derived from class FoxitPDFSDKPython2.GraphicsObjects , so class PDFPage also offers functions to retrieve PDF graphics objects:
To get a PDF graphics object, use functions FoxitPDFSDKPython2.GraphicsObjects.GetFirstGraphicsObjectPosition , FoxitPDFSDKPython2.GraphicsObjects.GetNextGraphicsObjectPosition , FoxitPDFSDKPython2.GraphicsObjects.GetLastGraphicsObjectPosition , FoxitPDFSDKPython2.GraphicsObjects.GetPrevGraphicsObjectPosition and FoxitPDFSDKPython2.GraphicsObjects.GetGraphicsObject (these functions are inherited from parent class), or FoxitPDFSDKPython2.PDFPage.GetGraphicsObjectAtPoint .
To insert a PDF graphics object, use function FoxitPDFSDKPython2.GraphicsObjects.InsertGraphicsObject (inherited from parent class).
To remove a PDF graphics object, use functions FoxitPDFSDKPython2.GraphicsObjects.RemoveGraphicsObjectByPosition or FoxitPDFSDKPython2.GraphicsObjects.RemoveGraphicsObject (these functions are inherited from parent class).
This class object can also be used to construct objects of other classes in order to access specified information in PDF page:
To access text content in PDF page, please construct a TextPage with PDF page object.
To do reflowing, please construct a ReflowPage with PDF page object.
To access additional actions, please construct an FoxitPDFSDKPython2.AdditionalAction object with PDF page object.
To manage the tab order of annotations in PDF page, please construct a TabOrderMgr with PDF page object.
def FoxitPDFSDKPython2.PDFPage.PDFPage | ( | document, | |
page_dict | |||
) |
Constructor, from a PDF dictionary which represents a PDF page and the PDF document which contains the dictionary..
Constructor, with parent class object.
[in] | document | A valid PDF document. |
[in] | page_dict | A PDF dictionary of a PDF page. It should belong to the PDF document specified by parameter document. |
[in] | other | Parent class object. |
def FoxitPDFSDKPython2.PDFPage.AddAnnot | ( | type, | |
rect | |||
) |
Add an annotation to current PDF page.
Add an annotation (by a valid annotation dictionary) to current PDF page.
Currently, this function can support to add most annotation types except:
Widget, Sound, Movie, PrinterMark, TrapNet, Watermark, 3D, PSInk, Redact.
Attention:
Widget annotation are used to represent the appearance of a form field, including signature field:
For signature field, function FoxitPDFSDKPython2.PDFPage.AddSignature can be called to add a new signature object.
For other types of form field, function FoxitPDFSDKPython2.Form.AddControl can be called to add a new form field (with form control).
PSInk annotation should be converted from a PSI object by function FoxitPDFSDKPython2.PSI.ConvertToPDFAnnot .
Redact annotation should be added to mark areas in PDF page by function FoxitPDFSDKPython2.Redaction.MarkRedactAnnot .
For supported annotations types, if user does not set any properties of the newly created annotation (except the required properties) and directly calls function FoxitPDFSDKPython2.Annot.ResetAppearanceStream , default appearance will be used. Please refer to comment of concrete annotation class for more details of their own default appearance.
[in] | type | The type of annotation to be added. Please refer to values starting from FoxitPDFSDKPython2.Annot.e_Note and this should be one of these values except FoxitPDFSDKPython2.Annot.e_PSInk , FoxitPDFSDKPython2.Annot.e_Sound , FoxitPDFSDKPython2.Annot.e_Movie , FoxitPDFSDKPython2.Annot.e_Widget , FoxitPDFSDKPython2.Annot.e_PrinterMark , FoxitPDFSDKPython2.Annot.e_TrapNet , FoxitPDFSDKPython2.Annot.e_Watermark , FoxitPDFSDKPython2.Annot.e_3D . |
[in] | rect | Rectangle of the new annotation.
|
[in] | annot_dict | An valid annotation dictionary which is to be added as an annotation to current PDF page. |
def FoxitPDFSDKPython2.PDFPage.AddImage | ( | image, | |
frame_index, | |||
position, | |||
width, | |||
height, | |||
auto_generate_content | |||
) |
Add an image to current page.
If the type of image is FoxitPDFSDKPython2.Image.e_JPG , the image should be kept valid until the related document is closed.
[in] | image | An image. One of its frames will be set to current page. This image contains at least one frame and the image type should not be FoxitPDFSDKPython2.Image.e_Unknown . |
[in] | frame_index | Frame index. Valid range: from 0 to (count-1). count is returned by function FoxitPDFSDKPython2.Image.GetFrameCount . |
[in] | position | A specified position which is the bottom left corner of image object, in [PDF coordinate system] (). |
[in] | width | The width which is used for the image to set into page. The value should be larger than 0. |
[in] | height | The height which is used for the image to set into page. The value should be larger than 0. |
[in] | auto_generate_content | true means to generate content internally. When using false, user should ensure to call function FoxitPDFSDKPython2.GraphicsObjects.GenerateContent after adding image. Please refer to function FoxitPDFSDKPython2.GraphicsObjects.GenerateContent for more details. |
def FoxitPDFSDKPython2.PDFPage.AddImageFromFilePath | ( | file_path, | |
position, | |||
width, | |||
height, | |||
auto_generate_content | |||
) |
Add an image to current page from file path.
If input image (specified by file path) has more than one frame, only the first frame will be added to current page acquiescently.
[in] | file_path | A full path of an existing image file. It should not be an empty string. |
[in] | position | A specified position which is the bottom left corner of image object, in [PDF coordinate system] (). |
[in] | width | The width which is used for the image to set into page. The value should be larger than 0. |
[in] | height | The height which is used for the image to set into page. The value should be larger than 0. |
[in] | auto_generate_content | true means to generate content internally. When using false, user should ensure to call function FoxitPDFSDKPython2.GraphicsObjects.GenerateContent after adding image. Please refer to function FoxitPDFSDKPython2.GraphicsObjects.GenerateContent for more details. |
def FoxitPDFSDKPython2.PDFPage.AddSignature | ( | rect | ) |
Add an ordinary signature to PDF page.
Add a signature to PDF page.
For a new ordinary signature, its filter will be "Adobe.PPKLite" and sub filter will be "adbe.pkcs7.detached" by default. Please refer to class Signature for more details about signature's filter and sub-filter.
Before signing the new signature, user can also call setting functions of class Signature to set other information used for signing and signed appearance.
[in] | rect | Rectangle position for the new signature, in [PDF coordinate system] (). It should be a valid rectangle in [PDF coordinate system] (). |
For a new ordinary signature, its filter will be "Adobe.PPKLite" and sub filter will be "adbe.pkcs7.detached" by default. Please refer to class Signature for more details about signature's filter and sub-filter.
Before signing the new signature, user can also call setting functions of class Signature to set other information used for signing and signed appearance.
[in] | rect | Rectangle position for the new signature, in [PDF coordinate system] (). It should be a valid rectangle in [PDF coordinate system] (). |
[in] | field_name | The signature field name. This can be an empty string. |
For a new ordinary signature, its filter will be "Adobe.PPKLite" and sub filter will be "adbe.pkcs7.detached" by default. For a new time stamp signature, its filter will be "Adobe.PPKLite" and sub filter will be "ETSI.RFC3161" by default. Please refer to class Signature for more details about signature's filter and sub-filter.
Before signing the new signature, user can also call setting functions of class Signature to set other information used for signing and signed appearance.
[in] | rect | Rectangle position for the new signature, in [PDF coordinate system] (). If parameter signature_type is FoxitPDFSDKPython2.Signature.e_SignatureTypeTimeStamp , this rectangle will be ignored; otherwise, this should be a valid rectangle in [PDF coordinate system] (). |
[in] | field_name | The signature field name. This can be an empty string. |
[in] | signature_type | Signature type. Please refer to values starting from FoxitPDFSDKPython2.Signature.e_SignatureTypeOrdinary and this should be one of these values. |
[in] | to_check_permission | A boolean value to decide whether Foxit PDF SDK should check PDF document's permission before adding signature: true means Foxit PDF SDK should check document permission to decide if adding signature is allowed, while false means Foxit PDF SDK should not check document permission before adding signature. When this parameter is false, user should ensure to check document permission to check if adding signature is allowed. |
def FoxitPDFSDKPython2.PDFPage.AddText | ( | text, | |
rect, | |||
style | |||
) |
Add text to current page.
The text wraps around if it is too long to fit the rectangle.
[in] | text | Content of the new text string. This should not be an empty string. |
[in] | rect | The box rectangle, in [PDF coordinate system] (). |
[in] | style | Style data used for the new text string. |
def FoxitPDFSDKPython2.PDFPage.CalcContentBBox | ( | mode | ) |
Calculate the content area of PDF page.
Before using this function, please ensure current page has been parsed.
[in] | mode | Calculation mode. It should be one of following values:
|
def FoxitPDFSDKPython2.PDFPage.ClearRenderCache | ( | ) |
Clear render cache.
def FoxitPDFSDKPython2.PDFPage.Flatten | ( | for_display, | |
options | |||
) |
Flatten current PDF page: annotations or form fields may be made to be a part of the page contents according to specified options.
Annotation flag can decide if an annotation can be displayed or if an annotation can be printed. This also affects the flattened result:
If the flattened result is used for displaying, only annotations which can be displayed will be flattened to be a part of page contents.
If the flattened result is used for printing, only annotations which can be printed will be flattened to be a part of page contents.
Form field's appearance is represents by widget annotation which is a kind of annotation and treated as form control in Foxit PDF SDK. So annotation flag affects a form field as well when a form field is to be flattened. For more details about annotation flag, please refer to values starting from FoxitPDFSDKPython2.Annot.e_FlagInvisible and Section 8.4.2 "Annotation Flags" in <PDF Reference 1.7>.
After an annotation or a form field is flattened, it will not be an annotation or a form field any more. After flattening current page successfully, user should re-parse this page by function FoxitPDFSDKPython2.PDFPage.StartParse .
[in] | for_display | Decide the purpose of the flattened result: true means the flatten result is used for display only, and false means the flatten result is used for print only. |
[in] | options | The flatten options. Please refer to values starting from FoxitPDFSDKPython2.PDFPage.e_FlattenAll and this should one or a combination of them. Specially, if FoxitPDFSDKPython2.PDFPage.e_FlattenNoAnnot and FoxitPDFSDKPython2.PDFPage.e_FlattenNoFormControl are used together, that means nothing is to be flatten to page and this function will return true directly. |
def FoxitPDFSDKPython2.PDFPage.FlattenAnnot | ( | annot | ) |
Flatten an annotation: the annotation is made to be a part of the page contents and be removed then.
After flattening the annotation successfully, user should re-parse this page by function FoxitPDFSDKPython2.PDFPage.StartParse .
[in] | annot | An annotation to be flattened and removed. |
def FoxitPDFSDKPython2.PDFPage.GetAnnot | ( | index | ) |
Get an annotation by index.
[in] | index | Annotation index. Valid range: from 0 to (count-1). count is returned by function FoxitPDFSDKPython2.PDFPage.GetAnnotCount . |
def FoxitPDFSDKPython2.PDFPage.GetAnnotAtDevicePoint | ( | position, | |
tolerance, | |||
matrix | |||
) |
Get the annotation at a specified position, in device coordinate system.
If there are several annotations in this specified position, this function will always return the topmost annotation. Annotations with flag FoxitPDFSDKPython2.Annot.e_FlagNoView or FoxitPDFSDKPython2.Annot.e_FlagHidden or FoxitPDFSDKPython2.Annot.e_FlagInvisible will not be retrieved by this function.If the returned annotation has a flag FoxitPDFSDKPython2.Annot.e_FlagReadOnly ,it cannot be modified.
[in] | position | The specified position, in device coordinate system. |
[in] | tolerance | Tolerance value. Valid range: 0.0f to 30.0f. |
[in] | matrix | The transformation matrix. Usually this is returned by function FoxitPDFSDKPython2.PDFPage.GetDisplayMatrix . If this is null, current function will have the same feature as function FoxitPDFSDKPython2.PDFPage.GetAnnotAtPoint . |
def FoxitPDFSDKPython2.PDFPage.GetAnnotAtPoint | ( | position, | |
tolerance | |||
) |
Get the annotation at a specified position, in [PDF coordinate system] ().
If there are several annotations in this specified position, this function will always return the topmost annotation. Annotations with flag FoxitPDFSDKPython2.Annot.e_FlagNoView or FoxitPDFSDKPython2.Annot.e_FlagHidden or FoxitPDFSDKPython2.Annot.e_FlagInvisible will not be retrieved by this function. If the returned annotation has a flag FoxitPDFSDKPython2.Annot.e_FlagReadOnly ,it cannot be modified.
[in] | position | The specified position, in [PDF coordinate system] (). |
[in] | tolerance | Tolerance value. Valid range: 0.0f to 30.0f. |
def FoxitPDFSDKPython2.PDFPage.GetAnnotCount | ( | ) |
Get the count of annotations.
def FoxitPDFSDKPython2.PDFPage.GetAnnots | ( | ) |
Get the PDF array of "Annots".
def FoxitPDFSDKPython2.PDFPage.GetAnnotsAtDevicePoint | ( | position, | |
tolerance, | |||
matrix | |||
) |
Get all the annotations at a specified position, in device coordinate system.
In one specified position, there may exist several annotations. This function can be used to retrieve all these annotations in the specified position. Annotations with flag FoxitPDFSDKPython2.Annot.e_FlagNoView or FoxitPDFSDKPython2.Annot.e_FlagHidden or FoxitPDFSDKPython2.Annot.e_FlagInvisible will not be retrieved by this function.
If the return annotation object of function FoxitPDFSDKPython2.AnnotArray.GetAt for the returned annotation array object has flag FoxitPDFSDKPython2.Annot.e_FlagReadOnly , that means the annotation cannot be modified.
[in] | position | The specified position, in device coordinate system. |
[in] | tolerance | Tolerance value. Valid range: 0.0f to 30.0f. |
[in] | matrix | The transformation matrix. Usually this is returned by function FoxitPDFSDKPython2.PDFPage.GetDisplayMatrix . If this is null, current function will have the same feature as function FoxitPDFSDKPython2.PDFPage.GetAnnotAtPoint . |
def FoxitPDFSDKPython2.PDFPage.GetAnnotsAtPoint | ( | position, | |
tolerance | |||
) |
Get all the annotations at a specified position, in [PDF coordinate system] ().
In one specified position, there may exist several annotations. This function can be used to retrieve all these annotations in the specified position. Annotations with flag FoxitPDFSDKPython2.Annot.e_FlagNoView or FoxitPDFSDKPython2.Annot.e_FlagHidden or FoxitPDFSDKPython2.Annot.e_FlagInvisible will not be retrieved by this function.
If the return annotation object of function FoxitPDFSDKPython2.AnnotArray.GetAt for the returned annotation array object has flag FoxitPDFSDKPython2.Annot.e_FlagReadOnly , that means the annotation cannot be modified.
[in] | position | The specified position, in [PDF coordinate system] (). |
[in] | tolerance | Tolerance value. Valid range: 0.0f to 30.0f. |
def FoxitPDFSDKPython2.PDFPage.GetBox | ( | box_type | ) |
Get page box.
[in] | box_type | Page box type. Please refer to values starting from FoxitPDFSDKPython2.PDFPage.e_MediaBox and this should be one of these values. |
def FoxitPDFSDKPython2.PDFPage.GetContents | ( | ) |
Get the PDF object of "Contents".
def FoxitPDFSDKPython2.PDFPage.GetDict | ( | ) |
Get the page dictionary.
def FoxitPDFSDKPython2.PDFPage.GetDisplayMatrix | ( | left, | |
top, | |||
width, | |||
height, | |||
rotate | |||
) |
Get the display matrix of PDF page, from [PDF coordinate system] () to targeted device coordinate system.
[in] | left | Left position of the transformation area in device coordinate system, commonly in pixels. |
[in] | top | Top position of the transformation area in device coordinate system, commonly in pixels. |
[in] | width | Width of the transformation area in device coordinate system, commonly in pixels. |
[in] | height | Height of the transformation area in device coordinate system, commonly in pixels. |
[in] | rotate | Rotation value. Please refer to values starting from FoxitPDFSDKPython2.e_Rotation0 and this should be one of these values except FoxitPDFSDKPython2.e_RotationUnknown . |
def FoxitPDFSDKPython2.PDFPage.GetDocument | ( | ) |
Get the PDF document, to which current PDF page belongs.
def FoxitPDFSDKPython2.PDFPage.GetGraphicsObjectAtDevicePoint | ( | point, | |
tolerance, | |||
matrix, | |||
filter | |||
) |
Get the topmost graphics object in specified point in device coordinate system, with specified type filter.
[in] | point | A specified position, in device coordinate system. |
[in] | tolerance | Tolerance value for a graphics object hit detection, in point units. It should be positive. |
[in] | matrix | The transformation matrix. Usually this is returned by function FoxitPDFSDKPython2.PDFPage.GetDisplayMatrix . |
[in] | filter | Type filter that specifies which kind of graphics object is to be gotten. Please refer to values starting from FoxitPDFSDKPython2.GraphicsObject.e_TypeAll and this should be one of these values. FoxitPDFSDKPython2.GraphicsObject.e_TypeAll means for all kinds of graphics objects. |
def FoxitPDFSDKPython2.PDFPage.GetGraphicsObjectAtPoint | ( | point, | |
tolerance, | |||
filter | |||
) |
Get the topmost graphics object in specified point, with specified type filter.
[in] | point | A specified position, in [PDF coordinate system] (). |
[in] | tolerance | Tolerance value for a graphics object hit detection, in point units. It should be positive. |
[in] | filter | Type filter that specifies which kind of graphics object is to be gotten. Please refer to values starting from FoxitPDFSDKPython2.GraphicsObject.e_TypeAll and this should be one of these values. FoxitPDFSDKPython2.GraphicsObject.e_TypeAll means for all kinds of graphics objects. |
def FoxitPDFSDKPython2.PDFPage.GetGraphicsObjectAtRectangle | ( | rect, | |
filter | |||
) |
Get the topmost graphics object whose rectangle interasects with a specified rectangle, with specified type filter.
[in] | rect | A specified rectangle, in [PDF coordinate system] (). |
[in] | filter | Type filter that specifies which kind of graphics object is to be gotten. Please refer to values starting from FoxitPDFSDKPython2.GraphicsObject.e_TypeAll and this should be one of these values. FoxitPDFSDKPython2.GraphicsObject.e_TypeAll means for all kinds of graphics objects. |
def FoxitPDFSDKPython2.PDFPage.GetGraphicsObjectsAtDevicePoint | ( | point, | |
tolerance, | |||
matrix, | |||
filter | |||
) |
Get all the graphics objects in specified point in device coordinate system, with specified type filter.
[in] | point | A specified position, in device coordinate system. |
[in] | tolerance | Tolerance value for a graphics object hit detection, in point units. It should be positive. |
[in] | matrix | The transformation matrix. Usually this is returned by function FoxitPDFSDKPython2.PDFPage.GetDisplayMatrix . |
[in] | filter | Type filter that specifies which kind of graphics object is to be gotten. Please refer to values starting from FoxitPDFSDKPython2.GraphicsObject.e_TypeAll and this should be one of these values. FoxitPDFSDKPython2.GraphicsObject.e_TypeAll means for all kinds of graphics objects. |
def FoxitPDFSDKPython2.PDFPage.GetGraphicsObjectsAtPoint | ( | point, | |
tolerance, | |||
filter | |||
) |
Get all the graphics objects in specified point, with specified type filter.
[in] | point | A specified position, in [PDF coordinate system] (). |
[in] | tolerance | Tolerance value for a graphics object hit detection, in point units. It should be positive. |
[in] | filter | Type filter that specifies which kind of graphics object is to be gotten. Please refer to values starting from FoxitPDFSDKPython2.GraphicsObject.e_TypeAll and this should be one of these values. FoxitPDFSDKPython2.GraphicsObject.e_TypeAll means for all kinds of graphics objects. |
def FoxitPDFSDKPython2.PDFPage.GetGraphicsObjectsAtRectangle | ( | rect, | |
filter | |||
) |
Get all the graphics objects whose rectangles intersect with a specified rectangle, with specified type filter.
[in] | rect | A specified rectangle, in [PDF coordinate system] (). |
[in] | filter | Type filter that specifies which kind of graphics object is to be gotten. Please refer to values starting from FoxitPDFSDKPython2.GraphicsObject.e_TypeAll and this should be one of these values. FoxitPDFSDKPython2.GraphicsObject.e_TypeAll means for all kinds of graphics objects. |
def FoxitPDFSDKPython2.PDFPage.GetHeight | ( | ) |
Get the page height (unit is 1/72 inch).
def FoxitPDFSDKPython2.PDFPage.GetIndex | ( | ) |
Get page index.
def FoxitPDFSDKPython2.PDFPage.GetInheritedAttribute | ( | attruibute_name | ) |
Get the PDF object for specified attribute which may be inherited from the ancestor node in the page tree.
Some of the page attributes are designated as inheritable, such as "Resources", "MediaBox", "CropBox", and "Rotate". Please refer to "TABLE 3.27 Entries in a page object" in <PDF Reference 1.7> P145 and "Inheritance of Page Attributes" in <PDF Reference 1.7> P149 for more details.
[in] | attruibute_name | The name of attribute to be found. |
def FoxitPDFSDKPython2.PDFPage.GetResources | ( | ) |
Get the PDF dictionary of "Resources".
def FoxitPDFSDKPython2.PDFPage.GetRotation | ( | ) |
Get the page rotation.
def FoxitPDFSDKPython2.PDFPage.GetSuggestedRect | ( | render_result, | |
render_matrix, | |||
point | |||
) |
Get the suggested rectangle (in [PDF coordinate system] ()) for a point (in [PDF coordinate system] ()) based on the rendering result bitmap.
This function can help user to locate a rectangle area (as a suggested rectangle) around a specified point. When a valid suggested rectangle is retrieved, user can use the rectangle to add something to PDF page, such as a new annotation, a new form field, a new signature and etc.
The suggested rectangle for a point means a rectangle which contains specified point and can be drawn in the spare place around the specified point as large as possible. BUT, if any of left/right/top/bottom directions from the point reaches the input bitmap edges directly, no suggested rectangle can be retrieved.
This function does not support a Rbg565 bitmap. If input bitmap is a Rbg565 bitmap, this function will return an empty rectangle directly.
[in] | render_result | Bitmap as the result of rendering current PDF page. This should be a valid bitmap object. |
[in] | render_matrix | The transformation matrix used for rendering current PDF page and generating parameter render_result as rendering result. |
[in] | point | A point (in [PDF coordinate system] ()) for which a suggested rectangle is to be found. |
def FoxitPDFSDKPython2.PDFPage.GetThumb | ( | ) |
Get the PDF stream of "Thumb".
def FoxitPDFSDKPython2.PDFPage.GetUserUnitSize | ( | ) |
Get the user unit.
A positive number giving the size of default user space units, in multiples of 1/72 inch. The range of supported values is implementation-dependent.
def FoxitPDFSDKPython2.PDFPage.GetWidth | ( | ) |
Get the page width (unit is 1/72 inch).
def FoxitPDFSDKPython2.PDFPage.HasTransparency | ( | ) |
Check whether current PDF page has transparency or not.
Before using this function, please ensure current page has been parsed.
def FoxitPDFSDKPython2.PDFPage.HasWatermark | ( | ) |
Check whether the current page has any watermark (not including Foxit PDF SDK trial watermark).
Before using this function, please ensure current page has been parsed.
def FoxitPDFSDKPython2.PDFPage.IsParsed | ( | ) |
Check if current page has been parsed or not.
def FoxitPDFSDKPython2.PDFPage.LoadThumbnail | ( | ) |
Load the thumbnail bitmap.
def FoxitPDFSDKPython2.PDFPage.MoveAnnotToFirst | ( | annot | ) |
Change specified annotation to be the first one of all annotations.
In PDF page, all the annotations are managed in an annotation list. In the annotation list, annotations with small indexes (as in the font part of the list) will be drawn to the page first, and annotations with large indexes (as in the last part of the list) will be drawn to the page later. So, in a page, if an annotation is shown on the top of other annotations in z-order, that means its index is larger than other annotations in the annotation list.
This function is used to move an annotation from current index position to the first position in the annotation list, in order to move the annotation to the bottom in z-order when displayed.
[in] | annot | An annotation object to be moved to first. It should be in current PDF page. |
def FoxitPDFSDKPython2.PDFPage.MoveAnnotToLast | ( | annot | ) |
Change specified annotation to be the last one of all annotations.
In PDF page, all the annotations are managed in an annotation list. In the annotation list, annotations with small indexes (as in the font part of the list) will be drawn to the page first, and annotations with large indexes (as in the last part of the list) will be drawn to the page later. So, in a page, if an annotation is shown on the top of other annotations in z-order, that means its index is larger than other annotations in the annotation list.
This function is used to move an annotation from current index position to the last position in the annotation list, in order to move the annotation to the top in z-order when displayed.
[in] | annot | An annotation object to be moved to last. It should be in current PDF page. |
def FoxitPDFSDKPython2.PDFPage.MoveAnnotToNext | ( | annot | ) |
Exchange the indexes of current annotation and its next annotation.
In PDF page, all the annotations are managed in an annotation list. In the annotation list, annotations with small indexes (as in the font part of the list) will be drawn to the page first, and annotations with large indexes (as in the last part of the list) will be drawn to the page later. So, in a page, if an annotation is shown on the top of other annotations in z-order, that means its index is larger than other annotations in the annotation list.
This function is used to exchange the indexes position of current annotation and its next annotation in the annotation list, in order to move the annotation to an upper level in z-order when displayed.
[in] | annot | An annotation object to be moved. It should be in current PDF page. |
def FoxitPDFSDKPython2.PDFPage.MoveAnnotToPrev | ( | annot | ) |
Exchange the indexes of current annotation and its previous annotation.
In PDF page, all the annotations are managed in an annotation list. In the annotation list, annotations with small indexes (as in the font part of the list) will be drawn to the page first, and annotations with large indexes (as in the last part of the list) will be drawn to the page later. So, in a page, if an annotation is shown on the top of other annotations in z-order, that means its index is larger than other annotations in the annotation list.
This function is used to exchange the indexes position of current annotation and its previous annotation in the annotation list, in order to move the annotation to a lower level in z-order when displayed.
[in] | annot | An annotation object to be moved. It should be in current PDF page. |
def FoxitPDFSDKPython2.PDFPage.Normalize | ( | ) |
Transform current PDF page by undoing any rotation and removing the offset to the page's "CropBox".
def FoxitPDFSDKPython2.PDFPage.RemoveAllWatermarks | ( | ) |
Remove all watermarks.
Before using this function, please ensure current page has been parsed.
def FoxitPDFSDKPython2.PDFPage.RemoveAnnot | ( | annot | ) |
Remove an annotation.
This function can remove any annotation returned by getting function or adding function.
But for widget annotation, this function can only remove an independent widget annotation. If the widget annotation is associated with a form field, this function cannot remove it and will throw exception FoxitPDFSDKPython2.e_ErrUnsupported .
For a widget annotation associated with a form field, please call function FoxitPDFSDKPython2.Form.RemoveControl to remove it along with associated form control.
[in] | annot | An annotation object to be removed. It should be in current PDF page. |
def FoxitPDFSDKPython2.PDFPage.SetAnnotGroup | ( | annot_array, | |
header_index | |||
) |
Group all the input markup annotations together.
Markup annotations can be grouped. The group consists of a primary annotation and one or more subordinate annotations. Some entries in the primary annotation are treated as group attributes that should apply to the group as a whole; the corresponding entries in the subordinate annotations should be ignored. These entries are contents, last modification time, fill color/border color, title, pop-up annotation, creation time, subject, and open status. So user should respect the group property: when a property of an annotation in the group is changed, the other annotations in the same group should be changed too.
Operations that manipulate any annotation in a group, such as movement, cut, and copy, should be treated by viewer applications as acting on the entire group.
[in] | annot_array | An array of Markup objects that specifies markup annotations which are to be grouped together. This array should contains at least 2 markup annotations, and all the markup annotations in this array should be different from others. All the markup annotations in this array should be in current page. Specially, if a markup annotation in this array is already in another group, that group will be set to the new group with the new header as well. |
[in] | header_index | The index that specifies a markup annotation in parameter annot_array to be the header of the group. Valid range: from 0 to (annot_count -1). |
def FoxitPDFSDKPython2.PDFPage.SetBox | ( | box_type, | |
box | |||
) |
Set page box.
[in] | box_type | Page box type. Please refer to values starting from FoxitPDFSDKPython2.PDFPage.e_MediaBox and this should be one of these values. |
[in] | box | New box rectangle, in [PDF coordinate system] (). |
def FoxitPDFSDKPython2.PDFPage.SetClipRect | ( | clip_rect | ) |
Set clip rectangle for all graphics objects on current PDF page.
After this function finishes successfully, please re-parse current page by function FoxitPDFSDKPython2.PDFPage.StartParse with parameter is_reparse true.
[in] | clip_rect | New clip rectangle, in [PDF coordinate system] (). |
def FoxitPDFSDKPython2.PDFPage.SetRotation | ( | rotate | ) |
Set page rotation.
[in] | rotate | New page rotation value. Please refer to values starting from FoxitPDFSDKPython2.e_Rotation0 and this should be one of these values except FoxitPDFSDKPython2.e_RotationUnknown . |
def FoxitPDFSDKPython2.PDFPage.SetSize | ( | width, | |
height | |||
) |
Set page width and height.
Set page size type.
When changing page width/height, Foxit PDF SDK will always do as following:
First, choose "page rotation is 0" as the basis page status and choose the left-bottom corner of the page (with page rotation is 0) as the basis point. And then, always change the position of top page boundary and right page boundary (with page rotation is 0) to change page size.
[in] | width | New page width. It should be a positive value and the unit is 1/72 inch. |
[in] | height | New page height. It should be a positive value and the unit is 1/72 inch. |
When changing page size, Foxit PDF SDK will always do as following:
First, choose "page rotation is 0" as the basis page status and choose the left-bottom corner of the page (with page rotation is 0) as the basis point. And then, always change the position of top page boundary and right page boundary (with page rotation is 0) to change page size.
[in] | size | Size type to specify the new size of current page. Please refer to values starting from FoxitPDFSDKPython2.PDFPage.e_SizeLetter and this should be one of these values. |
def FoxitPDFSDKPython2.PDFPage.SetThumbnail | ( | thumbnail | ) |
Set page thumbnail.
Thumbnail bitmap does not use alpha channel. So user is recommended to set a bitmap without alpha channel to be the new thumbnail. If a bitmap with alpha channel is set, the new thumbnail will use white background by default. Currently, this function does not support the bitmap with format FoxitPDFSDKPython2.Bitmap.e_DIBRgb565 .
[in] | thumbnail | New page thumbnail. It should be a valid bitmap. |
def FoxitPDFSDKPython2.PDFPage.SetUserUnitSize | ( | user_unit | ) |
Set the user unit.
A positive number giving the size of default user space units, in multiples of 1/72 inch. The range of supported values is implementation-dependent. If not set, Foxit PDF SDK will use default value 1.0 (user unit is 1/72 inch).
[in] | user_unit | A positive number giving the size of default user space units, in multiples of 1/72 inch. |
def FoxitPDFSDKPython2.PDFPage.StartParse | ( | flags, | |
pause, | |||
is_reparse | |||
) |
Start to parse current page.
It may take a long time to parsing a PDF page, so Foxit PDF SDK uses a progressive process to do this. All the resources of page content will be loaded after the PDF page is parsed.
[in] | flags | Parsing flags. Please refer to values starting from FoxitPDFSDKPython2.PDFPage.e_ParsePageNormal and this should be one or a combination of these values. |
[in] | pause | Pause callback object which decides if the parsing process needs to be paused. This can be null which means not to pause during the parsing process. If this is not null, it should be a valid pause object implemented by user. |
[in] | is_reparse | true means to re-parse current page, while false means not to re-parse current page. |
def FoxitPDFSDKPython2.PDFPage.Transform | ( | matrix, | |
need_transform_clip_path, | |||
need_transform_annotations | |||
) |
Transform a PDF page, including annotations and form fields on the page.
[in] | matrix | Transform matrix. |
[in] | need_transform_clip_path | true means to transform the page with clip rectangle, while false means not. |
[in] | need_transform_annotations | true means to transform the page with annotations. while false means not. |
def FoxitPDFSDKPython2.PDFPage.UpdateAnnotList | ( | ) |
Update the annotation list.
If any annotation is modified(added/removed...) by changing "Annots" dictionary item directly, please call this function to update the annotation list after the changing.
|
static |
Art Box for page boundary.
The intended dimensions of a finished page after trimming.
|
static |
Bleed Box for page boundary.
The extent of page's meaningful content (including potential white space) as intended by page's creator.
|
static |
Crop Box for page boundary.
The region to which the contents of page are to be clipped (cropped) while displaying or printing.
|
static |
Media Box for page boundary.
The boundary of the physical medium on which page is to be displayed or printed.
|
static |
Trim Box for page boundary.
The region to which the contents of page should be clipped while outputting in a production environment.