| // Copyright 2014 The PDFium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
| |
| #ifndef PUBLIC_FPDF_FORMFILL_H_ |
| #define PUBLIC_FPDF_FORMFILL_H_ |
| |
| // clang-format off |
| // NOLINTNEXTLINE(build/include) |
| #include "fpdfview.h" |
| |
| // These values are return values for a public API, so should not be changed |
| // other than the count when adding new values. |
| #define FORMTYPE_NONE 0 // Document contains no forms |
| #define FORMTYPE_ACRO_FORM 1 // Forms are specified using AcroForm spec |
| #define FORMTYPE_XFA_FULL 2 // Forms are specified using entire XFA spec |
| #define FORMTYPE_XFA_FOREGROUND 3 // Forms are specified using the XFAF subset |
| // of XFA spec |
| #define FORMTYPE_COUNT 4 // The number of form types |
| |
| #define JSPLATFORM_ALERT_BUTTON_OK 0 // OK button |
| #define JSPLATFORM_ALERT_BUTTON_OKCANCEL 1 // OK & Cancel buttons |
| #define JSPLATFORM_ALERT_BUTTON_YESNO 2 // Yes & No buttons |
| #define JSPLATFORM_ALERT_BUTTON_YESNOCANCEL 3 // Yes, No & Cancel buttons |
| #define JSPLATFORM_ALERT_BUTTON_DEFAULT JSPLATFORM_ALERT_BUTTON_OK |
| |
| #define JSPLATFORM_ALERT_ICON_ERROR 0 // Error |
| #define JSPLATFORM_ALERT_ICON_WARNING 1 // Warning |
| #define JSPLATFORM_ALERT_ICON_QUESTION 2 // Question |
| #define JSPLATFORM_ALERT_ICON_STATUS 3 // Status |
| #define JSPLATFORM_ALERT_ICON_ASTERISK 4 // Asterisk |
| #define JSPLATFORM_ALERT_ICON_DEFAULT JSPLATFORM_ALERT_ICON_ERROR |
| |
| #define JSPLATFORM_ALERT_RETURN_OK 1 // OK |
| #define JSPLATFORM_ALERT_RETURN_CANCEL 2 // Cancel |
| #define JSPLATFORM_ALERT_RETURN_NO 3 // No |
| #define JSPLATFORM_ALERT_RETURN_YES 4 // Yes |
| |
| #define JSPLATFORM_BEEP_ERROR 0 // Error |
| #define JSPLATFORM_BEEP_WARNING 1 // Warning |
| #define JSPLATFORM_BEEP_QUESTION 2 // Question |
| #define JSPLATFORM_BEEP_STATUS 3 // Status |
| #define JSPLATFORM_BEEP_DEFAULT 4 // Default |
| |
| // Exported Functions |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| typedef struct _IPDF_JsPlatform { |
| /* |
| * Version number of the interface. Currently must be 2. |
| */ |
| int version; |
| |
| /* Version 1. */ |
| |
| /* |
| * Method: app_alert |
| * Pop up a dialog to show warning or hint. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * Msg - A string containing the message to be displayed. |
| * Title - The title of the dialog. |
| * Type - The type of button group, one of the |
| * JSPLATFORM_ALERT_BUTTON_* values above. |
| * nIcon - The type of the icon, one of the |
| * JSPLATFORM_ALERT_ICON_* above. |
| * Return Value: |
| * Option selected by user in dialogue, one of the |
| * JSPLATFORM_ALERT_RETURN_* values above. |
| */ |
| int (*app_alert)(struct _IPDF_JsPlatform* pThis, |
| FPDF_WIDESTRING Msg, |
| FPDF_WIDESTRING Title, |
| int Type, |
| int Icon); |
| |
| /* |
| * Method: app_beep |
| * Causes the system to play a sound. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself |
| * nType - The sound type, see JSPLATFORM_BEEP_TYPE_* |
| * above. |
| * Return Value: |
| * None |
| */ |
| void (*app_beep)(struct _IPDF_JsPlatform* pThis, int nType); |
| |
| /* |
| * Method: app_response |
| * Displays a dialog box containing a question and an entry field for |
| * the user to reply to the question. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself |
| * Question - The question to be posed to the user. |
| * Title - The title of the dialog box. |
| * Default - A default value for the answer to the question. If |
| * not specified, no default value is presented. |
| * cLabel - A short string to appear in front of and on the |
| * same line as the edit text field. |
| * bPassword - If true, indicates that the user's response should |
| * be shown as asterisks (*) or bullets (?) to mask |
| * the response, which might be sensitive information. |
| * response - A string buffer allocated by PDFium, to receive the |
| * user's response. |
| * length - The length of the buffer in bytes. Currently, it is |
| * always 2048. |
| * Return Value: |
| * Number of bytes the complete user input would actually require, not |
| * including trailing zeros, regardless of the value of the length |
| * parameter or the presence of the response buffer. |
| * Comments: |
| * No matter on what platform, the response buffer should be always |
| * written using UTF-16LE encoding. If a response buffer is |
| * present and the size of the user input exceeds the capacity of the |
| * buffer as specified by the length parameter, only the |
| * first "length" bytes of the user input are to be written to the |
| * buffer. |
| */ |
| int (*app_response)(struct _IPDF_JsPlatform* pThis, |
| FPDF_WIDESTRING Question, |
| FPDF_WIDESTRING Title, |
| FPDF_WIDESTRING Default, |
| FPDF_WIDESTRING cLabel, |
| FPDF_BOOL bPassword, |
| void* response, |
| int length); |
| |
| /* |
| * Method: Doc_getFilePath |
| * Get the file path of the current document. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself |
| * filePath - The string buffer to receive the file path. Can |
| * be NULL. |
| * length - The length of the buffer, number of bytes. Can |
| * be 0. |
| * Return Value: |
| * Number of bytes the filePath consumes, including trailing zeros. |
| * Comments: |
| * The filePath should always be provided in the local encoding. |
| * The return value always indicated number of bytes required for |
| * the buffer, even when there is no buffer specified, or the buffer |
| * size is less than required. In this case, the buffer will not |
| * be modified. |
| */ |
| int (*Doc_getFilePath)(struct _IPDF_JsPlatform* pThis, |
| void* filePath, |
| int length); |
| |
| /* |
| * Method: Doc_mail |
| * Mails the data buffer as an attachment to all recipients, with or |
| * without user interaction. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself |
| * mailData - Pointer to the data buffer to be sent. Can be NULL. |
| * length - The size,in bytes, of the buffer pointed by |
| * mailData parameter. Can be 0. |
| * bUI - If true, the rest of the parameters are used in a |
| * compose-new-message window that is displayed to the |
| * user. If false, the cTo parameter is required and |
| * all others are optional. |
| * To - A semicolon-delimited list of recipients for the |
| * message. |
| * Subject - The subject of the message. The length limit is |
| * 64 KB. |
| * CC - A semicolon-delimited list of CC recipients for |
| * the message. |
| * BCC - A semicolon-delimited list of BCC recipients for |
| * the message. |
| * Msg - The content of the message. The length limit is |
| * 64 KB. |
| * Return Value: |
| * None. |
| * Comments: |
| * If the parameter mailData is NULL or length is 0, the current |
| * document will be mailed as an attachment to all recipients. |
| */ |
| void (*Doc_mail)(struct _IPDF_JsPlatform* pThis, |
| void* mailData, |
| int length, |
| FPDF_BOOL bUI, |
| FPDF_WIDESTRING To, |
| FPDF_WIDESTRING Subject, |
| FPDF_WIDESTRING CC, |
| FPDF_WIDESTRING BCC, |
| FPDF_WIDESTRING Msg); |
| |
| /* |
| * Method: Doc_print |
| * Prints all or a specific number of pages of the document. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * bUI - If true, will cause a UI to be presented to the |
| * user to obtain printing information and confirm |
| * the action. |
| * nStart - A 0-based index that defines the start of an |
| * inclusive range of pages. |
| * nEnd - A 0-based index that defines the end of an |
| * inclusive page range. |
| * bSilent - If true, suppresses the cancel dialog box while |
| * the document is printing. The default is false. |
| * bShrinkToFit - If true, the page is shrunk (if necessary) to |
| * fit within the imageable area of the printed page. |
| * bPrintAsImage - If true, print pages as an image. |
| * bReverse - If true, print from nEnd to nStart. |
| * bAnnotations - If true (the default), annotations are |
| * printed. |
| * Return Value: |
| * None. |
| */ |
| void (*Doc_print)(struct _IPDF_JsPlatform* pThis, |
| FPDF_BOOL bUI, |
| int nStart, |
| int nEnd, |
| FPDF_BOOL bSilent, |
| FPDF_BOOL bShrinkToFit, |
| FPDF_BOOL bPrintAsImage, |
| FPDF_BOOL bReverse, |
| FPDF_BOOL bAnnotations); |
| |
| /* |
| * Method: Doc_submitForm |
| * Send the form data to a specified URL. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself |
| * formData - Pointer to the data buffer to be sent. |
| * length - The size,in bytes, of the buffer pointed by |
| * formData parameter. |
| * URL - The URL to send to. |
| * Return Value: |
| * None. |
| */ |
| void (*Doc_submitForm)(struct _IPDF_JsPlatform* pThis, |
| void* formData, |
| int length, |
| FPDF_WIDESTRING URL); |
| |
| /* |
| * Method: Doc_gotoPage |
| * Jump to a specified page. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself |
| * nPageNum - The specified page number, zero for the first page. |
| * Return Value: |
| * None. |
| * |
| */ |
| void (*Doc_gotoPage)(struct _IPDF_JsPlatform* pThis, int nPageNum); |
| |
| /* |
| * Method: Field_browse |
| * Show a file selection dialog, and return the selected file path. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * filePath - Pointer to the data buffer to receive the file |
| * path. Can be NULL. |
| * length - The length of the buffer, in bytes. Can be 0. |
| * Return Value: |
| * Number of bytes the filePath consumes, including trailing zeros. |
| * Comments: |
| * The filePath shoule always be provided in local encoding. |
| */ |
| int (*Field_browse)(struct _IPDF_JsPlatform* pThis, |
| void* filePath, |
| int length); |
| |
| /* |
| * Pointer for embedder-specific data. Unused by PDFium, and despite |
| * its name, can be any data the embedder desires, though traditionally |
| * a FPDF_FORMFILLINFO interface. |
| */ |
| void* m_pFormfillinfo; |
| |
| /* Version 2. */ |
| |
| void* m_isolate; /* Unused in v3, retain for compatibility. */ |
| unsigned int m_v8EmbedderSlot; /* Unused in v3, retain for compatibility. */ |
| |
| /* Version 3. */ |
| /* Version 3 moves m_Isolate and m_v8EmbedderSlot to FPDF_LIBRARY_CONFIG. */ |
| } IPDF_JSPLATFORM; |
| |
| // Flags for Cursor type |
| #define FXCT_ARROW 0 |
| #define FXCT_NESW 1 |
| #define FXCT_NWSE 2 |
| #define FXCT_VBEAM 3 |
| #define FXCT_HBEAM 4 |
| #define FXCT_HAND 5 |
| |
| /* |
| * Function signature for the callback function passed to the FFI_SetTimer |
| * method. |
| * Parameters: |
| * idEvent - Identifier of the timer. |
| * Return value: |
| * None. |
| */ |
| typedef void (*TimerCallback)(int idEvent); |
| |
| /* |
| * Declares of a struct type to the local system time. |
| */ |
| typedef struct _FPDF_SYSTEMTIME { |
| unsigned short wYear; /* years since 1900 */ |
| unsigned short wMonth; /* months since January - [0,11] */ |
| unsigned short wDayOfWeek; /* days since Sunday - [0,6] */ |
| unsigned short wDay; /* day of the month - [1,31] */ |
| unsigned short wHour; /* hours since midnight - [0,23] */ |
| unsigned short wMinute; /* minutes after the hour - [0,59] */ |
| unsigned short wSecond; /* seconds after the minute - [0,59] */ |
| unsigned short wMilliseconds; /* milliseconds after the second - [0,999] */ |
| } FPDF_SYSTEMTIME; |
| |
| #ifdef PDF_ENABLE_XFA |
| |
| // Pageview event flags |
| #define FXFA_PAGEVIEWEVENT_POSTADDED 1 // After a new pageview is added. |
| #define FXFA_PAGEVIEWEVENT_POSTREMOVED 3 // After a pageview is removed. |
| |
| // Definitions for Right Context Menu Features Of XFA Fields |
| #define FXFA_MENU_COPY 1 |
| #define FXFA_MENU_CUT 2 |
| #define FXFA_MENU_SELECTALL 4 |
| #define FXFA_MENU_UNDO 8 |
| #define FXFA_MENU_REDO 16 |
| #define FXFA_MENU_PASTE 32 |
| |
| // Definitions for File Type. |
| #define FXFA_SAVEAS_XML 1 |
| #define FXFA_SAVEAS_XDP 2 |
| |
| #endif // PDF_ENABLE_XFA |
| |
| typedef struct _FPDF_FORMFILLINFO { |
| /* |
| * Version number of the interface. |
| * Version 1 contains stable interfaces. Version 2 has additional |
| * experimental interfaces. |
| * When PDFium is built without the XFA module, version can be 1 or 2. |
| * With version 1, only stable interfaces are called. With version 2, |
| * additional experimental interfaces are also called. |
| * When PDFium is built with the XFA module, version must be 2. |
| * All the XFA related interfaces are experimental. If PDFium is built with |
| * the XFA module and version 1 then none of the XFA related interfaces |
| * would be called. When PDFium is built with XFA module then the version |
| * must be 2. |
| */ |
| int version; |
| |
| /* Version 1. */ |
| /* |
| * Method: Release |
| * Give the implementation a chance to release any resources after the |
| * interface is no longer used. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * No |
| * Comments: |
| * Called by PDFium during the final cleanup process. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself |
| * Return Value: |
| * None |
| */ |
| void (*Release)(struct _FPDF_FORMFILLINFO* pThis); |
| |
| /* |
| * Method: FFI_Invalidate |
| * Invalidate the client area within the specified rectangle. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * page - Handle to the page. Returned by FPDF_LoadPage(). |
| * left - Left position of the client area in PDF page |
| * coordinates. |
| * top - Top position of the client area in PDF page |
| * coordinates. |
| * right - Right position of the client area in PDF page |
| * coordinates. |
| * bottom - Bottom position of the client area in PDF page |
| * coordinates. |
| * Return Value: |
| * None. |
| * Comments: |
| * All positions are measured in PDF "user space". |
| * Implementation should call FPDF_RenderPageBitmap() for repainting |
| * the specified page area. |
| */ |
| void (*FFI_Invalidate)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_PAGE page, |
| double left, |
| double top, |
| double right, |
| double bottom); |
| |
| /* |
| * Method: FFI_OutputSelectedRect |
| * When the user selects text in form fields with the mouse, this |
| * callback function will be invoked with the selected areas. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * No |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * page - Handle to the page. Returned by FPDF_LoadPage()/ |
| * left - Left position of the client area in PDF page |
| * coordinates. |
| * top - Top position of the client area in PDF page |
| * coordinates. |
| * right - Right position of the client area in PDF page |
| * coordinates. |
| * bottom - Bottom position of the client area in PDF page |
| * coordinates. |
| * Return Value: |
| * None. |
| * Comments: |
| * This callback function is useful for implementing special text |
| * selection effects. An implementation should first record the |
| * returned rectangles, then draw them one by one during the next |
| * painting period. Lastly, it should remove all the recorded |
| * rectangles when finished painting. |
| */ |
| void (*FFI_OutputSelectedRect)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_PAGE page, |
| double left, |
| double top, |
| double right, |
| double bottom); |
| |
| /* |
| * Method: FFI_SetCursor |
| * Set the Cursor shape. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * nCursorType - Cursor type, see Flags for Cursor type for details. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_SetCursor)(struct _FPDF_FORMFILLINFO* pThis, int nCursorType); |
| |
| /* |
| * Method: FFI_SetTimer |
| * This method installs a system timer. An interval value is specified, |
| * and every time that interval elapses, the system must call into the |
| * callback function with the timer ID as returned by this function. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * uElapse - Specifies the time-out value, in milliseconds. |
| * lpTimerFunc - A pointer to the callback function-TimerCallback. |
| * Return value: |
| * The timer identifier of the new timer if the function is successful. |
| * An application passes this value to the FFI_KillTimer method to kill |
| * the timer. Nonzero if it is successful; otherwise, it is zero. |
| */ |
| int (*FFI_SetTimer)(struct _FPDF_FORMFILLINFO* pThis, |
| int uElapse, |
| TimerCallback lpTimerFunc); |
| |
| /* |
| * Method: FFI_KillTimer |
| * This method uninstalls a system timer, as set by an earlier call to |
| * FFI_SetTimer. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * nTimerID - The timer ID returned by FFI_SetTimer function. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_KillTimer)(struct _FPDF_FORMFILLINFO* pThis, int nTimerID); |
| |
| /* |
| * Method: FFI_GetLocalTime |
| * This method receives the current local time on the system. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * Return value: |
| * The local time. See FPDF_SYSTEMTIME above for details. |
| * Note: Unused. |
| */ |
| FPDF_SYSTEMTIME (*FFI_GetLocalTime)(struct _FPDF_FORMFILLINFO* pThis); |
| |
| /* |
| * Method: FFI_OnChange |
| * This method will be invoked to notify the implementation when the |
| * value of any FormField on the document had been changed. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * no |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_OnChange)(struct _FPDF_FORMFILLINFO* pThis); |
| |
| /* |
| * Method: FFI_GetPage |
| * This method receives the page handle associated with a specified |
| * page index. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * document - Handle to document. Returned by FPDF_LoadDocument(). |
| * nPageIndex - Index number of the page. 0 for the first page. |
| * Return value: |
| * Handle to the page, as previously returned to the implementation by |
| * FPDF_LoadPage(). |
| * Comments: |
| * The implementation is expected to keep track of the page handles it |
| * receives from PDFium, and their mappings to page numbers. In some |
| * cases, the document-level JavaScript action may refer to a page |
| * which hadn't been loaded yet. To successfully run the Javascript |
| * action, the implementation needs to load the page. |
| */ |
| FPDF_PAGE (*FFI_GetPage)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_DOCUMENT document, |
| int nPageIndex); |
| |
| /* |
| * Method: FFI_GetCurrentPage |
| * This method receives the handle to the current page. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * Yes when V8 support is present, otherwise unused. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * document - Handle to document. Returned by FPDF_LoadDocument(). |
| * Return value: |
| * Handle to the page. Returned by FPDF_LoadPage(). |
| * Comments: |
| * PDFium doesn't keep keep track of the "current page" (e.g. the one |
| * that is most visible on screen), so it must ask the embedder for |
| * this information. |
| */ |
| FPDF_PAGE (*FFI_GetCurrentPage)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_DOCUMENT document); |
| |
| /* |
| * Method: FFI_GetRotation |
| * This method receives currently rotation of the page view. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * page - Handle to page, as returned by FPDF_LoadPage(). |
| * Return value: |
| * A number to indicate the page rotation in 90 degree increments |
| * in a clockwise direction: |
| * 0 - 0 degrees |
| * 1 - 90 degrees |
| * 2 - 180 degrees |
| * 3 - 270 degrees |
| * Note: Unused. |
| */ |
| int (*FFI_GetRotation)(struct _FPDF_FORMFILLINFO* pThis, FPDF_PAGE page); |
| |
| /* |
| * Method: FFI_ExecuteNamedAction |
| * This method will execute a named action. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * yes |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * namedAction - A byte string which indicates the named action, |
| * terminated by 0. |
| * Return value: |
| * None. |
| * Comments: |
| * See ISO 32000-1:2008, section 12.6.4.11 for descriptions of the |
| * standard named actions, but note that a document may supply any |
| * name of its choosing. |
| */ |
| void (*FFI_ExecuteNamedAction)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_BYTESTRING namedAction); |
| /* |
| * Method: FFI_SetTextFieldFocus |
| * Called when a text field is getting or losing focus. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * no |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * value - The string value of the form field, in UTF-16LE |
| * format. |
| * valueLen - The length of the string value. This is the |
| * number of characters, not bytes. |
| * is_focus - True if the form field is getting focus, false |
| * if the form field is losing focus. |
| * Return value: |
| * None. |
| * Comments: |
| * Only supports text fields and combobox fields. |
| */ |
| void (*FFI_SetTextFieldFocus)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_WIDESTRING value, |
| FPDF_DWORD valueLen, |
| FPDF_BOOL is_focus); |
| |
| /* |
| * Method: FFI_DoURIAction |
| * Ask the implementation to navigate to a uniform resource identifier. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * No |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * bsURI - A byte string which indicates the uniform |
| * resource identifier, terminated by 0. |
| * Return value: |
| * None. |
| * Comments: |
| * If the embedder is version 2 or higher and have implementation for |
| * FFI_DoURIActionWithKeyboardModifier, then |
| * FFI_DoURIActionWithKeyboardModifier takes precedence over |
| * FFI_DoURIAction. |
| * See the URI actions description of <<PDF Reference, version 1.7>> |
| * for more details. |
| */ |
| void (*FFI_DoURIAction)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_BYTESTRING bsURI); |
| |
| /* |
| * Method: FFI_DoGoToAction |
| * This action changes the view to a specified destination. |
| * Interface Version: |
| * 1 |
| * Implementation Required: |
| * No |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * nPageIndex - The index of the PDF page. |
| * zoomMode - The zoom mode for viewing page. See below. |
| * fPosArray - The float array which carries the position info. |
| * sizeofArray - The size of float array. |
| * PDFZoom values: |
| * - XYZ = 1 |
| * - FITPAGE = 2 |
| * - FITHORZ = 3 |
| * - FITVERT = 4 |
| * - FITRECT = 5 |
| * - FITBBOX = 6 |
| * - FITBHORZ = 7 |
| * - FITBVERT = 8 |
| * Return value: |
| * None. |
| * Comments: |
| * See the Destinations description of <<PDF Reference, version 1.7>> |
| * in 8.2.1 for more details. |
| */ |
| void (*FFI_DoGoToAction)(struct _FPDF_FORMFILLINFO* pThis, |
| int nPageIndex, |
| int zoomMode, |
| float* fPosArray, |
| int sizeofArray); |
| |
| /* |
| * Pointer to IPDF_JSPLATFORM interface. |
| * Unused if PDFium is built without V8 support. Otherwise, if NULL, then |
| * JavaScript will be prevented from executing while rendering the document. |
| */ |
| IPDF_JSPLATFORM* m_pJsPlatform; |
| |
| /* Version 2 - Experimental. */ |
| /* |
| * Whether the XFA module is disabled when built with the XFA module. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| */ |
| FPDF_BOOL xfa_disabled; |
| |
| /* |
| * Method: FFI_DisplayCaret |
| * This method will show the caret at specified position. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * page - Handle to page. Returned by FPDF_LoadPage(). |
| * left - Left position of the client area in PDF page |
| * coordinates. |
| * top - Top position of the client area in PDF page |
| * coordinates. |
| * right - Right position of the client area in PDF page |
| * coordinates. |
| * bottom - Bottom position of the client area in PDF page |
| * coordinates. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_DisplayCaret)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_PAGE page, |
| FPDF_BOOL bVisible, |
| double left, |
| double top, |
| double right, |
| double bottom); |
| |
| /* |
| * Method: FFI_GetCurrentPageIndex |
| * This method will get the current page index. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * document - Handle to document from FPDF_LoadDocument(). |
| * Return value: |
| * The index of current page. |
| */ |
| int (*FFI_GetCurrentPageIndex)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_DOCUMENT document); |
| |
| /* |
| * Method: FFI_SetCurrentPage |
| * This method will set the current page. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * document - Handle to document from FPDF_LoadDocument(). |
| * iCurPage - The index of the PDF page. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_SetCurrentPage)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_DOCUMENT document, |
| int iCurPage); |
| |
| /* |
| * Method: FFI_GotoURL |
| * This method will navigate to the specified URL. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * document - Handle to document from FPDF_LoadDocument(). |
| * wsURL - The string value of the URL, in UTF-16LE format. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_GotoURL)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_DOCUMENT document, |
| FPDF_WIDESTRING wsURL); |
| |
| /* |
| * Method: FFI_GetPageViewRect |
| * This method will get the current page view rectangle. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * page - Handle to page. Returned by FPDF_LoadPage(). |
| * left - The pointer to receive left position of the page |
| * view area in PDF page coordinates. |
| * top - The pointer to receive top position of the page |
| * view area in PDF page coordinates. |
| * right - The pointer to receive right position of the |
| * page view area in PDF page coordinates. |
| * bottom - The pointer to receive bottom position of the |
| * page view area in PDF page coordinates. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_GetPageViewRect)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_PAGE page, |
| double* left, |
| double* top, |
| double* right, |
| double* bottom); |
| |
| /* |
| * Method: FFI_PageEvent |
| * This method fires when pages have been added to or deleted from |
| * the XFA document. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * page_count - The number of pages to be added or deleted. |
| * event_type - See FXFA_PAGEVIEWEVENT_* above. |
| * Return value: |
| * None. |
| * Comments: |
| * The pages to be added or deleted always start from the last page |
| * of document. This means that if parameter page_count is 2 and |
| * event type is FXFA_PAGEVIEWEVENT_POSTADDED, 2 new pages have been |
| * appended to the tail of document; If page_count is 2 and |
| * event type is FXFA_PAGEVIEWEVENT_POSTREMOVED, the last 2 pages |
| * have been deleted. |
| */ |
| void (*FFI_PageEvent)(struct _FPDF_FORMFILLINFO* pThis, |
| int page_count, |
| FPDF_DWORD event_type); |
| |
| /* |
| * Method: FFI_PopupMenu |
| * This method will track the right context menu for XFA fields. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * page - Handle to page. Returned by FPDF_LoadPage(). |
| * hWidget - Always null, exists for compatibility. |
| * menuFlag - The menu flags. Please refer to macro definition |
| * of FXFA_MENU_XXX and this can be one or a |
| * combination of these macros. |
| * x - X position of the client area in PDF page |
| * coordinates. |
| * y - Y position of the client area in PDF page |
| * coordinates. |
| * Return value: |
| * TRUE indicates success; otherwise false. |
| */ |
| FPDF_BOOL (*FFI_PopupMenu)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_PAGE page, |
| FPDF_WIDGET hWidget, |
| int menuFlag, |
| float x, |
| float y); |
| |
| /* |
| * Method: FFI_OpenFile |
| * This method will open the specified file with the specified mode. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * fileFlag - The file flag. Please refer to macro definition |
| * of FXFA_SAVEAS_XXX and use one of these macros. |
| * wsURL - The string value of the file URL, in UTF-16LE |
| * format. |
| * mode - The mode for open file, e.g. "rb" or "wb". |
| * Return value: |
| * The handle to FPDF_FILEHANDLER. |
| */ |
| FPDF_FILEHANDLER* (*FFI_OpenFile)(struct _FPDF_FORMFILLINFO* pThis, |
| int fileFlag, |
| FPDF_WIDESTRING wsURL, |
| const char* mode); |
| |
| /* |
| * Method: FFI_EmailTo |
| * This method will email the specified file stream to the specified |
| * contact. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * pFileHandler - Handle to the FPDF_FILEHANDLER. |
| * pTo - A semicolon-delimited list of recipients for the |
| * message,in UTF-16LE format. |
| * pSubject - The subject of the message,in UTF-16LE format. |
| * pCC - A semicolon-delimited list of CC recipients for |
| * the message,in UTF-16LE format. |
| * pBcc - A semicolon-delimited list of BCC recipients for |
| * the message,in UTF-16LE format. |
| * pMsg - Pointer to the data buffer to be sent.Can be |
| * NULL,in UTF-16LE format. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_EmailTo)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_FILEHANDLER* fileHandler, |
| FPDF_WIDESTRING pTo, |
| FPDF_WIDESTRING pSubject, |
| FPDF_WIDESTRING pCC, |
| FPDF_WIDESTRING pBcc, |
| FPDF_WIDESTRING pMsg); |
| |
| /* |
| * Method: FFI_UploadTo |
| * This method will upload the specified file stream to the |
| * specified URL. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * pFileHandler - Handle to the FPDF_FILEHANDLER. |
| * fileFlag - The file flag. Please refer to macro definition |
| * of FXFA_SAVEAS_XXX and use one of these macros. |
| * uploadTo - Pointer to the URL path, in UTF-16LE format. |
| * Return value: |
| * None. |
| */ |
| void (*FFI_UploadTo)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_FILEHANDLER* fileHandler, |
| int fileFlag, |
| FPDF_WIDESTRING uploadTo); |
| |
| /* |
| * Method: FFI_GetPlatform |
| * This method will get the current platform. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * platform - Pointer to the data buffer to receive the |
| * platform,in UTF-16LE format. Can be NULL. |
| * length - The length of the buffer in bytes. Can be |
| * 0 to query the required size. |
| * Return value: |
| * The length of the buffer, number of bytes. |
| */ |
| int (*FFI_GetPlatform)(struct _FPDF_FORMFILLINFO* pThis, |
| void* platform, |
| int length); |
| |
| /* |
| * Method: FFI_GetLanguage |
| * This method will get the current language. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * language - Pointer to the data buffer to receive the |
| * current language. Can be NULL. |
| * length - The length of the buffer in bytes. Can be |
| * 0 to query the required size. |
| * Return value: |
| * The length of the buffer, number of bytes. |
| */ |
| int (*FFI_GetLanguage)(struct _FPDF_FORMFILLINFO* pThis, |
| void* language, |
| int length); |
| |
| /* |
| * Method: FFI_DownloadFromURL |
| * This method will download the specified file from the URL. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * URL - The string value of the file URL, in UTF-16LE |
| * format. |
| * Return value: |
| * The handle to FPDF_FILEHANDLER. |
| */ |
| FPDF_FILEHANDLER* (*FFI_DownloadFromURL)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_WIDESTRING URL); |
| /* |
| * Method: FFI_PostRequestURL |
| * This method will post the request to the server URL. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * wsURL - The string value of the server URL, in UTF-16LE |
| * format. |
| * wsData - The post data,in UTF-16LE format. |
| * wsContentType - The content type of the request data, in |
| * UTF-16LE format. |
| * wsEncode - The encode type, in UTF-16LE format. |
| * wsHeader - The request header,in UTF-16LE format. |
| * response - Pointer to the FPDF_BSTR to receive the response |
| * data from the server, in UTF-16LE format. |
| * Return value: |
| * TRUE indicates success, otherwise FALSE. |
| */ |
| FPDF_BOOL (*FFI_PostRequestURL)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_WIDESTRING wsURL, |
| FPDF_WIDESTRING wsData, |
| FPDF_WIDESTRING wsContentType, |
| FPDF_WIDESTRING wsEncode, |
| FPDF_WIDESTRING wsHeader, |
| FPDF_BSTR* response); |
| |
| /* |
| * Method: FFI_PutRequestURL |
| * This method will put the request to the server URL. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * Required for XFA, otherwise set to NULL. |
| * Parameters: |
| * pThis - Pointer to the interface structure itself. |
| * wsURL - The string value of the server URL, in UTF-16LE |
| * format. |
| * wsData - The put data, in UTF-16LE format. |
| * wsEncode - The encode type, in UTR-16LE format. |
| * Return value: |
| * TRUE indicates success, otherwise FALSE. |
| */ |
| FPDF_BOOL (*FFI_PutRequestURL)(struct _FPDF_FORMFILLINFO* pThis, |
| FPDF_WIDESTRING wsURL, |
| FPDF_WIDESTRING wsData, |
| FPDF_WIDESTRING wsEncode); |
| |
| /* |
| * Method: FFI_OnFocusChange |
| * Called when the focused annotation is updated. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * No |
| * Parameters: |
| * param - Pointer to the interface structure itself. |
| * annot - The focused annotation. |
| * page_index - Index number of the page which contains the |
| * focused annotation. 0 for the first page. |
| * Return value: |
| * None. |
| * Comments: |
| * This callback function is useful for implementing any view based |
| * action such as scrolling the annotation rect into view. The |
| * embedder should not copy and store the annot as its scope is |
| * limited to this call only. |
| */ |
| void (*FFI_OnFocusChange)(struct _FPDF_FORMFILLINFO* param, |
| FPDF_ANNOTATION annot, |
| int page_index); |
| |
| /** |
| * Method: FFI_DoURIActionWithKeyboardModifier |
| * Ask the implementation to navigate to a uniform resource identifier |
| * with the specified modifiers. |
| * Interface Version: |
| * Ignored if |version| < 2. |
| * Implementation Required: |
| * No |
| * Parameters: |
| * param - Pointer to the interface structure itself. |
| * uri - A byte string which indicates the uniform |
| * resource identifier, terminated by 0. |
| * modifiers - Keyboard modifier that indicates which of |
| * the virtual keys are down, if any. |
| * Return value: |
| * None. |
| * Comments: |
| * If the embedder who is version 2 and does not implement this API, |
| * then a call will be redirected to FFI_DoURIAction. |
| * See the URI actions description of <<PDF Reference, version 1.7>> |
| * for more details. |
| */ |
| void(*FFI_DoURIActionWithKeyboardModifier)(struct _FPDF_FORMFILLINFO* param, |
| FPDF_BYTESTRING uri, |
| int modifiers); |
| } FPDF_FORMFILLINFO; |
| |
| /* |
| * Function: FPDFDOC_InitFormFillEnvironment |
| * Initialize form fill environment. |
| * Parameters: |
| * document - Handle to document from FPDF_LoadDocument(). |
| * formInfo - Pointer to a FPDF_FORMFILLINFO structure. |
| * Return Value: |
| * Handle to the form fill module, or NULL on failure. |
| * Comments: |
| * This function should be called before any form fill operation. |
| * The FPDF_FORMFILLINFO passed in via |formInfo| must remain valid until |
| * the returned FPDF_FORMHANDLE is closed. |
| */ |
| FPDF_EXPORT FPDF_FORMHANDLE FPDF_CALLCONV |
| FPDFDOC_InitFormFillEnvironment(FPDF_DOCUMENT document, |
| FPDF_FORMFILLINFO* formInfo); |
| |
| /* |
| * Function: FPDFDOC_ExitFormFillEnvironment |
| * Take ownership of |hHandle| and exit form fill environment. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * Return Value: |
| * None. |
| * Comments: |
| * This function is a no-op when |hHandle| is null. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV |
| FPDFDOC_ExitFormFillEnvironment(FPDF_FORMHANDLE hHandle); |
| |
| /* |
| * Function: FORM_OnAfterLoadPage |
| * This method is required for implementing all the form related |
| * functions. Should be invoked after user successfully loaded a |
| * PDF page, and FPDFDOC_InitFormFillEnvironment() has been invoked. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * Return Value: |
| * None. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV FORM_OnAfterLoadPage(FPDF_PAGE page, |
| FPDF_FORMHANDLE hHandle); |
| |
| /* |
| * Function: FORM_OnBeforeClosePage |
| * This method is required for implementing all the form related |
| * functions. Should be invoked before user closes the PDF page. |
| * Parameters: |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * Return Value: |
| * None. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV FORM_OnBeforeClosePage(FPDF_PAGE page, |
| FPDF_FORMHANDLE hHandle); |
| |
| /* |
| * Function: FORM_DoDocumentJSAction |
| * This method is required for performing document-level JavaScript |
| * actions. It should be invoked after the PDF document has been loaded. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * Return Value: |
| * None. |
| * Comments: |
| * If there is document-level JavaScript action embedded in the |
| * document, this method will execute the JavaScript action. Otherwise, |
| * the method will do nothing. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV |
| FORM_DoDocumentJSAction(FPDF_FORMHANDLE hHandle); |
| |
| /* |
| * Function: FORM_DoDocumentOpenAction |
| * This method is required for performing open-action when the document |
| * is opened. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * Return Value: |
| * None. |
| * Comments: |
| * This method will do nothing if there are no open-actions embedded |
| * in the document. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV |
| FORM_DoDocumentOpenAction(FPDF_FORMHANDLE hHandle); |
| |
| // Additional actions type of document: |
| // WC, before closing document, JavaScript action. |
| // WS, before saving document, JavaScript action. |
| // DS, after saving document, JavaScript action. |
| // WP, before printing document, JavaScript action. |
| // DP, after printing document, JavaScript action. |
| #define FPDFDOC_AACTION_WC 0x10 |
| #define FPDFDOC_AACTION_WS 0x11 |
| #define FPDFDOC_AACTION_DS 0x12 |
| #define FPDFDOC_AACTION_WP 0x13 |
| #define FPDFDOC_AACTION_DP 0x14 |
| |
| /* |
| * Function: FORM_DoDocumentAAction |
| * This method is required for performing the document's |
| * additional-action. |
| * Parameters: |
| * hHandle - Handle to the form fill module. Returned by |
| * FPDFDOC_InitFormFillEnvironment. |
| * aaType - The type of the additional-actions which defined |
| * above. |
| * Return Value: |
| * None. |
| * Comments: |
| * This method will do nothing if there is no document |
| * additional-action corresponding to the specified |aaType|. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV FORM_DoDocumentAAction(FPDF_FORMHANDLE hHandle, |
| int aaType); |
| |
| // Additional-action types of page object: |
| // OPEN (/O) -- An action to be performed when the page is opened |
| // CLOSE (/C) -- An action to be performed when the page is closed |
| #define FPDFPAGE_AACTION_OPEN 0 |
| #define FPDFPAGE_AACTION_CLOSE 1 |
| |
| /* |
| * Function: FORM_DoPageAAction |
| * This method is required for performing the page object's |
| * additional-action when opened or closed. |
| * Parameters: |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * aaType - The type of the page object's additional-actions |
| * which defined above. |
| * Return Value: |
| * None. |
| * Comments: |
| * This method will do nothing if no additional-action corresponding |
| * to the specified |aaType| exists. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV FORM_DoPageAAction(FPDF_PAGE page, |
| FPDF_FORMHANDLE hHandle, |
| int aaType); |
| |
| /* |
| * Function: FORM_OnMouseMove |
| * Call this member function when the mouse cursor moves. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * modifier - Indicates whether various virtual keys are down. |
| * page_x - Specifies the x-coordinate of the cursor in PDF user |
| * space. |
| * page_y - Specifies the y-coordinate of the cursor in PDF user |
| * space. |
| * Return Value: |
| * True indicates success; otherwise false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnMouseMove(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Experimental API |
| * Function: FORM_OnMouseWheel |
| * Call this member function when the user scrolls the mouse wheel. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * modifier - Indicates whether various virtual keys are down. |
| * page_coord - Specifies the coordinates of the cursor in PDF user |
| * space. |
| * delta_x - Specifies the amount of wheel movement on the x-axis, |
| * in units of platform-agnostic wheel deltas. Negative |
| * values mean left. |
| * delta_y - Specifies the amount of wheel movement on the y-axis, |
| * in units of platform-agnostic wheel deltas. Negative |
| * values mean down. |
| * Return Value: |
| * True indicates success; otherwise false. |
| * Comments: |
| * For |delta_x| and |delta_y|, the caller must normalize |
| * platform-specific wheel deltas. e.g. On Windows, a delta value of 240 |
| * for a WM_MOUSEWHEEL event normalizes to 2, since Windows defines |
| * WHEEL_DELTA as 120. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnMouseWheel( |
| FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| const FS_POINTF* page_coord, |
| int delta_x, |
| int delta_y); |
| |
| /* |
| * Function: FORM_OnFocus |
| * This function focuses the form annotation at a given point. If the |
| * annotation at the point already has focus, nothing happens. If there |
| * is no annotation at the point, removes form focus. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * modifier - Indicates whether various virtual keys are down. |
| * page_x - Specifies the x-coordinate of the cursor in PDF user |
| * space. |
| * page_y - Specifies the y-coordinate of the cursor in PDF user |
| * space. |
| * Return Value: |
| * True if there is an annotation at the given point and it has focus. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnFocus(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Function: FORM_OnLButtonDown |
| * Call this member function when the user presses the left |
| * mouse button. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * modifier - Indicates whether various virtual keys are down. |
| * page_x - Specifies the x-coordinate of the cursor in PDF user |
| * space. |
| * page_y - Specifies the y-coordinate of the cursor in PDF user |
| * space. |
| * Return Value: |
| * True indicates success; otherwise false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnLButtonDown(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Function: FORM_OnRButtonDown |
| * Same as above, execpt for the right mouse button. |
| * Comments: |
| * At the present time, has no effect except in XFA builds, but is |
| * included for the sake of symmetry. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnRButtonDown(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| double page_x, |
| double page_y); |
| /* |
| * Function: FORM_OnLButtonUp |
| * Call this member function when the user releases the left |
| * mouse button. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * modifier - Indicates whether various virtual keys are down. |
| * page_x - Specifies the x-coordinate of the cursor in device. |
| * page_y - Specifies the y-coordinate of the cursor in device. |
| * Return Value: |
| * True indicates success; otherwise false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnLButtonUp(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Function: FORM_OnRButtonUp |
| * Same as above, execpt for the right mouse button. |
| * Comments: |
| * At the present time, has no effect except in XFA builds, but is |
| * included for the sake of symmetry. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnRButtonUp(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Function: FORM_OnLButtonDoubleClick |
| * Call this member function when the user double clicks the |
| * left mouse button. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * modifier - Indicates whether various virtual keys are down. |
| * page_x - Specifies the x-coordinate of the cursor in PDF user |
| * space. |
| * page_y - Specifies the y-coordinate of the cursor in PDF user |
| * space. |
| * Return Value: |
| * True indicates success; otherwise false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV |
| FORM_OnLButtonDoubleClick(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int modifier, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Function: FORM_OnKeyDown |
| * Call this member function when a nonsystem key is pressed. |
| * Parameters: |
| * hHandle - Handle to the form fill module, aseturned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * nKeyCode - The virtual-key code of the given key (see |
| * fpdf_fwlevent.h for virtual key codes). |
| * modifier - Mask of key flags (see fpdf_fwlevent.h for key |
| * flag values). |
| * Return Value: |
| * True indicates success; otherwise false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnKeyDown(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int nKeyCode, |
| int modifier); |
| |
| /* |
| * Function: FORM_OnKeyUp |
| * Call this member function when a nonsystem key is released. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * nKeyCode - The virtual-key code of the given key (see |
| * fpdf_fwlevent.h for virtual key codes). |
| * modifier - Mask of key flags (see fpdf_fwlevent.h for key |
| * flag values). |
| * Return Value: |
| * True indicates success; otherwise false. |
| * Comments: |
| * Currently unimplemented and always returns false. PDFium reserves this |
| * API and may implement it in the future on an as-needed basis. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnKeyUp(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int nKeyCode, |
| int modifier); |
| |
| /* |
| * Function: FORM_OnChar |
| * Call this member function when a keystroke translates to a |
| * nonsystem character. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * nChar - The character code value itself. |
| * modifier - Mask of key flags (see fpdf_fwlevent.h for key |
| * flag values). |
| * Return Value: |
| * True indicates success; otherwise false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_OnChar(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int nChar, |
| int modifier); |
| |
| /* |
| * Experimental API |
| * Function: FORM_GetFocusedText |
| * Call this function to obtain the text within the current focused |
| * field, if any. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * buffer - Buffer for holding the form text, encoded in |
| * UTF-16LE. If NULL, |buffer| is not modified. |
| * buflen - Length of |buffer| in bytes. If |buflen| is less |
| * than the length of the form text string, |buffer| is |
| * not modified. |
| * Return Value: |
| * Length in bytes for the text in the focused field. |
| */ |
| FPDF_EXPORT unsigned long FPDF_CALLCONV |
| FORM_GetFocusedText(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| void* buffer, |
| unsigned long buflen); |
| |
| /* |
| * Function: FORM_GetSelectedText |
| * Call this function to obtain selected text within a form text |
| * field or form combobox text field. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * buffer - Buffer for holding the selected text, encoded in |
| * UTF-16LE. If NULL, |buffer| is not modified. |
| * buflen - Length of |buffer| in bytes. If |buflen| is less |
| * than the length of the selected text string, |
| * |buffer| is not modified. |
| * Return Value: |
| * Length in bytes of selected text in form text field or form combobox |
| * text field. |
| */ |
| FPDF_EXPORT unsigned long FPDF_CALLCONV |
| FORM_GetSelectedText(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| void* buffer, |
| unsigned long buflen); |
| |
| /* |
| * Experimental API |
| * Function: FORM_ReplaceAndKeepSelection |
| * Call this function to replace the selected text in a form |
| * text field or user-editable form combobox text field with another |
| * text string (which can be empty or non-empty). If there is no |
| * selected text, this function will append the replacement text after |
| * the current caret position. After the insertion, the inserted text |
| * will be selected. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as Returned by FPDF_LoadPage(). |
| * wsText - The text to be inserted, in UTF-16LE format. |
| * Return Value: |
| * None. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV |
| FORM_ReplaceAndKeepSelection(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| FPDF_WIDESTRING wsText); |
| |
| /* |
| * Function: FORM_ReplaceSelection |
| * Call this function to replace the selected text in a form |
| * text field or user-editable form combobox text field with another |
| * text string (which can be empty or non-empty). If there is no |
| * selected text, this function will append the replacement text after |
| * the current caret position. After the insertion, the selection range |
| * will be set to empty. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as Returned by FPDF_LoadPage(). |
| * wsText - The text to be inserted, in UTF-16LE format. |
| * Return Value: |
| * None. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV FORM_ReplaceSelection(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| FPDF_WIDESTRING wsText); |
| |
| /* |
| * Experimental API |
| * Function: FORM_SelectAllText |
| * Call this function to select all the text within the currently focused |
| * form text field or form combobox text field. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * Return Value: |
| * Whether the operation succeeded or not. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV |
| FORM_SelectAllText(FPDF_FORMHANDLE hHandle, FPDF_PAGE page); |
| |
| /* |
| * Function: FORM_CanUndo |
| * Find out if it is possible for the current focused widget in a given |
| * form to perform an undo operation. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * Return Value: |
| * True if it is possible to undo. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_CanUndo(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page); |
| |
| /* |
| * Function: FORM_CanRedo |
| * Find out if it is possible for the current focused widget in a given |
| * form to perform a redo operation. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * Return Value: |
| * True if it is possible to redo. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_CanRedo(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page); |
| |
| /* |
| * Function: FORM_Undo |
| * Make the current focussed widget perform an undo operation. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * Return Value: |
| * True if the undo operation succeeded. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_Undo(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page); |
| |
| /* |
| * Function: FORM_Redo |
| * Make the current focussed widget perform a redo operation. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * Return Value: |
| * True if the redo operation succeeded. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FORM_Redo(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page); |
| |
| /* |
| * Function: FORM_ForceToKillFocus. |
| * Call this member function to force to kill the focus of the form |
| * field which has focus. If it would kill the focus of a form field, |
| * save the value of form field if was changed by theuser. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * Return Value: |
| * True indicates success; otherwise false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV |
| FORM_ForceToKillFocus(FPDF_FORMHANDLE hHandle); |
| |
| /* |
| * Experimental API. |
| * Function: FORM_GetFocusedAnnot. |
| * Call this member function to get the currently focused annotation. |
| * Parameters: |
| * handle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page_index - Buffer to hold the index number of the page which |
| * contains the focused annotation. 0 for the first page. |
| * Can't be NULL. |
| * annot - Buffer to hold the focused annotation. Can't be NULL. |
| * Return Value: |
| * On success, return true and write to the out parameters. Otherwise return |
| * false and leave the out parameters unmodified. |
| * Comments: |
| * Not currently supported for XFA forms - will report no focused |
| * annotation. |
| * Must call FPDFPage_CloseAnnot() when the annotation returned in |annot| |
| * by this function is no longer needed. |
| * This will return true and set |page_index| to -1 and |annot| to NULL, if |
| * there is no focused annotation. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV |
| FORM_GetFocusedAnnot(FPDF_FORMHANDLE handle, |
| int* page_index, |
| FPDF_ANNOTATION* annot); |
| |
| /* |
| * Experimental API. |
| * Function: FORM_SetFocusedAnnot. |
| * Call this member function to set the currently focused annotation. |
| * Parameters: |
| * handle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * annot - Handle to an annotation. |
| * Return Value: |
| * True indicates success; otherwise false. |
| * Comments: |
| * |annot| can't be NULL. To kill focus, use FORM_ForceToKillFocus() |
| * instead. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV |
| FORM_SetFocusedAnnot(FPDF_FORMHANDLE handle, FPDF_ANNOTATION annot); |
| |
| // Form Field Types |
| // The names of the defines are stable, but the specific values associated with |
| // them are not, so do not hardcode their values. |
| #define FPDF_FORMFIELD_UNKNOWN 0 // Unknown. |
| #define FPDF_FORMFIELD_PUSHBUTTON 1 // push button type. |
| #define FPDF_FORMFIELD_CHECKBOX 2 // check box type. |
| #define FPDF_FORMFIELD_RADIOBUTTON 3 // radio button type. |
| #define FPDF_FORMFIELD_COMBOBOX 4 // combo box type. |
| #define FPDF_FORMFIELD_LISTBOX 5 // list box type. |
| #define FPDF_FORMFIELD_TEXTFIELD 6 // text field type. |
| #define FPDF_FORMFIELD_SIGNATURE 7 // text field type. |
| #ifdef PDF_ENABLE_XFA |
| #define FPDF_FORMFIELD_XFA 8 // Generic XFA type. |
| #define FPDF_FORMFIELD_XFA_CHECKBOX 9 // XFA check box type. |
| #define FPDF_FORMFIELD_XFA_COMBOBOX 10 // XFA combo box type. |
| #define FPDF_FORMFIELD_XFA_IMAGEFIELD 11 // XFA image field type. |
| #define FPDF_FORMFIELD_XFA_LISTBOX 12 // XFA list box type. |
| #define FPDF_FORMFIELD_XFA_PUSHBUTTON 13 // XFA push button type. |
| #define FPDF_FORMFIELD_XFA_SIGNATURE 14 // XFA signture field type. |
| #define FPDF_FORMFIELD_XFA_TEXTFIELD 15 // XFA text field type. |
| #endif // PDF_ENABLE_XFA |
| |
| #ifdef PDF_ENABLE_XFA |
| #define FPDF_FORMFIELD_COUNT 16 |
| #else // PDF_ENABLE_XFA |
| #define FPDF_FORMFIELD_COUNT 8 |
| #endif // PDF_ENABLE_XFA |
| |
| #ifdef PDF_ENABLE_XFA |
| #define IS_XFA_FORMFIELD(type) \ |
| (((type) == FPDF_FORMFIELD_XFA) || \ |
| ((type) == FPDF_FORMFIELD_XFA_CHECKBOX) || \ |
| ((type) == FPDF_FORMFIELD_XFA_COMBOBOX) || \ |
| ((type) == FPDF_FORMFIELD_XFA_IMAGEFIELD) || \ |
| ((type) == FPDF_FORMFIELD_XFA_LISTBOX) || \ |
| ((type) == FPDF_FORMFIELD_XFA_PUSHBUTTON) || \ |
| ((type) == FPDF_FORMFIELD_XFA_SIGNATURE) || \ |
| ((type) == FPDF_FORMFIELD_XFA_TEXTFIELD)) |
| #endif // PDF_ENABLE_XFA |
| |
| /* |
| * Function: FPDFPage_HasFormFieldAtPoint |
| * Get the form field type by point. |
| * Parameters: |
| * hHandle - Handle to the form fill module. Returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page. Returned by FPDF_LoadPage(). |
| * page_x - X position in PDF "user space". |
| * page_y - Y position in PDF "user space". |
| * Return Value: |
| * Return the type of the form field; -1 indicates no field. |
| * See field types above. |
| */ |
| FPDF_EXPORT int FPDF_CALLCONV |
| FPDFPage_HasFormFieldAtPoint(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Function: FPDFPage_FormFieldZOrderAtPoint |
| * Get the form field z-order by point. |
| * Parameters: |
| * hHandle - Handle to the form fill module. Returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * page - Handle to the page. Returned by FPDF_LoadPage(). |
| * page_x - X position in PDF "user space". |
| * page_y - Y position in PDF "user space". |
| * Return Value: |
| * Return the z-order of the form field; -1 indicates no field. |
| * Higher numbers are closer to the front. |
| */ |
| FPDF_EXPORT int FPDF_CALLCONV |
| FPDFPage_FormFieldZOrderAtPoint(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| double page_x, |
| double page_y); |
| |
| /* |
| * Function: FPDF_SetFormFieldHighlightColor |
| * Set the highlight color of the specified (or all) form fields |
| * in the document. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * doc - Handle to the document, as returned by |
| * FPDF_LoadDocument(). |
| * fieldType - A 32-bit integer indicating the type of a form |
| * field (defined above). |
| * color - The highlight color of the form field. Constructed by |
| * 0xxxrrggbb. |
| * Return Value: |
| * None. |
| * Comments: |
| * When the parameter fieldType is set to FPDF_FORMFIELD_UNKNOWN, the |
| * highlight color will be applied to all the form fields in the |
| * document. |
| * Please refresh the client window to show the highlight immediately |
| * if necessary. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV |
| FPDF_SetFormFieldHighlightColor(FPDF_FORMHANDLE hHandle, |
| int fieldType, |
| unsigned long color); |
| |
| /* |
| * Function: FPDF_SetFormFieldHighlightAlpha |
| * Set the transparency of the form field highlight color in the |
| * document. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * doc - Handle to the document, as returaned by |
| * FPDF_LoadDocument(). |
| * alpha - The transparency of the form field highlight color, |
| * between 0-255. |
| * Return Value: |
| * None. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV |
| FPDF_SetFormFieldHighlightAlpha(FPDF_FORMHANDLE hHandle, unsigned char alpha); |
| |
| /* |
| * Function: FPDF_RemoveFormFieldHighlight |
| * Remove the form field highlight color in the document. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * Return Value: |
| * None. |
| * Comments: |
| * Please refresh the client window to remove the highlight immediately |
| * if necessary. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV |
| FPDF_RemoveFormFieldHighlight(FPDF_FORMHANDLE hHandle); |
| |
| /* |
| * Function: FPDF_FFLDraw |
| * Render FormFields and popup window on a page to a device independent |
| * bitmap. |
| * Parameters: |
| * hHandle - Handle to the form fill module, as returned by |
| * FPDFDOC_InitFormFillEnvironment(). |
| * bitmap - Handle to the device independent bitmap (as the |
| * output buffer). Bitmap handles can be created by |
| * FPDFBitmap_Create(). |
| * page - Handle to the page, as returned by FPDF_LoadPage(). |
| * start_x - Left pixel position of the display area in the |
| * device coordinates. |
| * start_y - Top pixel position of the display area in the device |
| * coordinates. |
| * size_x - Horizontal size (in pixels) for displaying the page. |
| * size_y - Vertical size (in pixels) for displaying the page. |
| * rotate - Page orientation: 0 (normal), 1 (rotated 90 degrees |
| * clockwise), 2 (rotated 180 degrees), 3 (rotated 90 |
| * degrees counter-clockwise). |
| * flags - 0 for normal display, or combination of flags |
| * defined above. |
| * Return Value: |
| * None. |
| * Comments: |
| * This function is designed to render annotations that are |
| * user-interactive, which are widget annotations (for FormFields) and |
| * popup annotations. |
| * With the FPDF_ANNOT flag, this function will render a popup annotation |
| * when users mouse-hover on a non-widget annotation. Regardless of |
| * FPDF_ANNOT flag, this function will always render widget annotations |
| * for FormFields. |
| * In order to implement the FormFill functions, implementation should |
| * call this function after rendering functions, such as |
| * FPDF_RenderPageBitmap() or FPDF_RenderPageBitmap_Start(), have |
| * finished rendering the page contents. |
| */ |
| FPDF_EXPORT void FPDF_CALLCONV FPDF_FFLDraw(FPDF_FORMHANDLE hHandle, |
| FPDF_BITMAP bitmap, |
| FPDF_PAGE page, |
| int start_x, |
| int start_y, |
| int size_x, |
| int size_y, |
| int rotate, |
| int flags); |
| |
| #if defined(_SKIA_SUPPORT_) |
| FPDF_EXPORT void FPDF_CALLCONV FPDF_FFLRecord(FPDF_FORMHANDLE hHandle, |
| FPDF_RECORDER recorder, |
| FPDF_PAGE page, |
| int start_x, |
| int start_y, |
| int size_x, |
| int size_y, |
| int rotate, |
| int flags); |
| #endif |
| |
| /* |
| * Experimental API |
| * Function: FPDF_GetFormType |
| * Returns the type of form contained in the PDF document. |
| * Parameters: |
| * document - Handle to document. |
| * Return Value: |
| * Integer value representing one of the FORMTYPE_ values. |
| * Comments: |
| * If |document| is NULL, then the return value is FORMTYPE_NONE. |
| */ |
| FPDF_EXPORT int FPDF_CALLCONV FPDF_GetFormType(FPDF_DOCUMENT document); |
| |
| /* |
| * Experimental API |
| * Function: FORM_SetIndexSelected |
| * Selects/deselects the value at the given |index| of the focused |
| * annotation. |
| * Parameters: |
| * hHandle - Handle to the form fill module. Returned by |
| * FPDFDOC_InitFormFillEnvironment. |
| * page - Handle to the page. Returned by FPDF_LoadPage |
| * index - 0-based index of value to be set as |
| * selected/unselected |
| * selected - true to select, false to deselect |
| * Return Value: |
| * TRUE if the operation succeeded. |
| * FALSE if the operation failed or widget is not a supported type. |
| * Comments: |
| * Intended for use with listbox/combobox widget types. Comboboxes |
| * have at most a single value selected at a time which cannot be |
| * deselected. Deselect on a combobox is a no-op that returns false. |
| * Default implementation is a no-op that will return false for |
| * other types. |
| * Not currently supported for XFA forms - will return false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV |
| FORM_SetIndexSelected(FPDF_FORMHANDLE hHandle, |
| FPDF_PAGE page, |
| int index, |
| FPDF_BOOL selected); |
| |
| /* |
| * Experimental API |
| * Function: FORM_IsIndexSelected |
| * Returns whether or not the value at |index| of the focused |
| * annotation is currently selected. |
| * Parameters: |
| * hHandle - Handle to the form fill module. Returned by |
| * FPDFDOC_InitFormFillEnvironment. |
| * page - Handle to the page. Returned by FPDF_LoadPage |
| * index - 0-based Index of value to check |
| * Return Value: |
| * TRUE if value at |index| is currently selected. |
| * FALSE if value at |index| is not selected or widget is not a |
| * supported type. |
| * Comments: |
| * Intended for use with listbox/combobox widget types. Default |
| * implementation is a no-op that will return false for other types. |
| * Not currently supported for XFA forms - will return false. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV |
| FORM_IsIndexSelected(FPDF_FORMHANDLE hHandle, FPDF_PAGE page, int index); |
| |
| /* |
| * Function: FPDF_LoadXFA |
| * If the document consists of XFA fields, call this method to |
| * attempt to load XFA fields. |
| * Parameters: |
| * document - Handle to document from FPDF_LoadDocument(). |
| * Return Value: |
| * TRUE upon success, otherwise FALSE. If XFA support is not built |
| * into PDFium, performs no action and always returns FALSE. |
| */ |
| FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FPDF_LoadXFA(FPDF_DOCUMENT document); |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif // PUBLIC_FPDF_FORMFILL_H_ |