xref: /aosp_15_r20/external/pdfium/public/fpdf_ppo.h (revision 3ac0a46f773bac49fa9476ec2b1cf3f8da5ec3a4)
1*3ac0a46fSAndroid Build Coastguard Worker // Copyright 2014 The PDFium Authors
2*3ac0a46fSAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*3ac0a46fSAndroid Build Coastguard Worker // found in the LICENSE file.
4*3ac0a46fSAndroid Build Coastguard Worker 
5*3ac0a46fSAndroid Build Coastguard Worker // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6*3ac0a46fSAndroid Build Coastguard Worker 
7*3ac0a46fSAndroid Build Coastguard Worker #ifndef PUBLIC_FPDF_PPO_H_
8*3ac0a46fSAndroid Build Coastguard Worker #define PUBLIC_FPDF_PPO_H_
9*3ac0a46fSAndroid Build Coastguard Worker 
10*3ac0a46fSAndroid Build Coastguard Worker // NOLINTNEXTLINE(build/include)
11*3ac0a46fSAndroid Build Coastguard Worker #include "fpdfview.h"
12*3ac0a46fSAndroid Build Coastguard Worker 
13*3ac0a46fSAndroid Build Coastguard Worker #ifdef __cplusplus
14*3ac0a46fSAndroid Build Coastguard Worker extern "C" {
15*3ac0a46fSAndroid Build Coastguard Worker #endif
16*3ac0a46fSAndroid Build Coastguard Worker 
17*3ac0a46fSAndroid Build Coastguard Worker // Experimental API.
18*3ac0a46fSAndroid Build Coastguard Worker // Import pages to a FPDF_DOCUMENT.
19*3ac0a46fSAndroid Build Coastguard Worker //
20*3ac0a46fSAndroid Build Coastguard Worker //   dest_doc     - The destination document for the pages.
21*3ac0a46fSAndroid Build Coastguard Worker //   src_doc      - The document to be imported.
22*3ac0a46fSAndroid Build Coastguard Worker //   page_indices - An array of page indices to be imported. The first page is
23*3ac0a46fSAndroid Build Coastguard Worker //                  zero. If |page_indices| is NULL, all pages from |src_doc|
24*3ac0a46fSAndroid Build Coastguard Worker //                  are imported.
25*3ac0a46fSAndroid Build Coastguard Worker //   length       - The length of the |page_indices| array.
26*3ac0a46fSAndroid Build Coastguard Worker //   index        - The page index at which to insert the first imported page
27*3ac0a46fSAndroid Build Coastguard Worker //                  into |dest_doc|. The first page is zero.
28*3ac0a46fSAndroid Build Coastguard Worker //
29*3ac0a46fSAndroid Build Coastguard Worker // Returns TRUE on success. Returns FALSE if any pages in |page_indices| is
30*3ac0a46fSAndroid Build Coastguard Worker // invalid.
31*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV
32*3ac0a46fSAndroid Build Coastguard Worker FPDF_ImportPagesByIndex(FPDF_DOCUMENT dest_doc,
33*3ac0a46fSAndroid Build Coastguard Worker                         FPDF_DOCUMENT src_doc,
34*3ac0a46fSAndroid Build Coastguard Worker                         const int* page_indices,
35*3ac0a46fSAndroid Build Coastguard Worker                         unsigned long length,
36*3ac0a46fSAndroid Build Coastguard Worker                         int index);
37*3ac0a46fSAndroid Build Coastguard Worker 
38*3ac0a46fSAndroid Build Coastguard Worker // Import pages to a FPDF_DOCUMENT.
39*3ac0a46fSAndroid Build Coastguard Worker //
40*3ac0a46fSAndroid Build Coastguard Worker //   dest_doc  - The destination document for the pages.
41*3ac0a46fSAndroid Build Coastguard Worker //   src_doc   - The document to be imported.
42*3ac0a46fSAndroid Build Coastguard Worker //   pagerange - A page range string, Such as "1,3,5-7". The first page is one.
43*3ac0a46fSAndroid Build Coastguard Worker //               If |pagerange| is NULL, all pages from |src_doc| are imported.
44*3ac0a46fSAndroid Build Coastguard Worker //   index     - The page index at which to insert the first imported page into
45*3ac0a46fSAndroid Build Coastguard Worker //               |dest_doc|. The first page is zero.
46*3ac0a46fSAndroid Build Coastguard Worker //
47*3ac0a46fSAndroid Build Coastguard Worker // Returns TRUE on success. Returns FALSE if any pages in |pagerange| is
48*3ac0a46fSAndroid Build Coastguard Worker // invalid or if |pagerange| cannot be read.
49*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV FPDF_ImportPages(FPDF_DOCUMENT dest_doc,
50*3ac0a46fSAndroid Build Coastguard Worker                                                      FPDF_DOCUMENT src_doc,
51*3ac0a46fSAndroid Build Coastguard Worker                                                      FPDF_BYTESTRING pagerange,
52*3ac0a46fSAndroid Build Coastguard Worker                                                      int index);
53*3ac0a46fSAndroid Build Coastguard Worker 
54*3ac0a46fSAndroid Build Coastguard Worker // Experimental API.
55*3ac0a46fSAndroid Build Coastguard Worker // Create a new document from |src_doc|.  The pages of |src_doc| will be
56*3ac0a46fSAndroid Build Coastguard Worker // combined to provide |num_pages_on_x_axis x num_pages_on_y_axis| pages per
57*3ac0a46fSAndroid Build Coastguard Worker // |output_doc| page.
58*3ac0a46fSAndroid Build Coastguard Worker //
59*3ac0a46fSAndroid Build Coastguard Worker //   src_doc             - The document to be imported.
60*3ac0a46fSAndroid Build Coastguard Worker //   output_width        - The output page width in PDF "user space" units.
61*3ac0a46fSAndroid Build Coastguard Worker //   output_height       - The output page height in PDF "user space" units.
62*3ac0a46fSAndroid Build Coastguard Worker //   num_pages_on_x_axis - The number of pages on X Axis.
63*3ac0a46fSAndroid Build Coastguard Worker //   num_pages_on_y_axis - The number of pages on Y Axis.
64*3ac0a46fSAndroid Build Coastguard Worker //
65*3ac0a46fSAndroid Build Coastguard Worker // Return value:
66*3ac0a46fSAndroid Build Coastguard Worker //   A handle to the created document, or NULL on failure.
67*3ac0a46fSAndroid Build Coastguard Worker //
68*3ac0a46fSAndroid Build Coastguard Worker // Comments:
69*3ac0a46fSAndroid Build Coastguard Worker //   number of pages per page = num_pages_on_x_axis * num_pages_on_y_axis
70*3ac0a46fSAndroid Build Coastguard Worker //
71*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_DOCUMENT FPDF_CALLCONV
72*3ac0a46fSAndroid Build Coastguard Worker FPDF_ImportNPagesToOne(FPDF_DOCUMENT src_doc,
73*3ac0a46fSAndroid Build Coastguard Worker                        float output_width,
74*3ac0a46fSAndroid Build Coastguard Worker                        float output_height,
75*3ac0a46fSAndroid Build Coastguard Worker                        size_t num_pages_on_x_axis,
76*3ac0a46fSAndroid Build Coastguard Worker                        size_t num_pages_on_y_axis);
77*3ac0a46fSAndroid Build Coastguard Worker 
78*3ac0a46fSAndroid Build Coastguard Worker // Experimental API.
79*3ac0a46fSAndroid Build Coastguard Worker // Create a template to generate form xobjects from |src_doc|'s page at
80*3ac0a46fSAndroid Build Coastguard Worker // |src_page_index|, for use in |dest_doc|.
81*3ac0a46fSAndroid Build Coastguard Worker //
82*3ac0a46fSAndroid Build Coastguard Worker // Returns a handle on success, or NULL on failure. Caller owns the newly
83*3ac0a46fSAndroid Build Coastguard Worker // created object.
84*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_XOBJECT FPDF_CALLCONV
85*3ac0a46fSAndroid Build Coastguard Worker FPDF_NewXObjectFromPage(FPDF_DOCUMENT dest_doc,
86*3ac0a46fSAndroid Build Coastguard Worker                         FPDF_DOCUMENT src_doc,
87*3ac0a46fSAndroid Build Coastguard Worker                         int src_page_index);
88*3ac0a46fSAndroid Build Coastguard Worker 
89*3ac0a46fSAndroid Build Coastguard Worker // Experimental API.
90*3ac0a46fSAndroid Build Coastguard Worker // Close an FPDF_XOBJECT handle created by FPDF_NewXObjectFromPage().
91*3ac0a46fSAndroid Build Coastguard Worker // FPDF_PAGEOBJECTs created from the FPDF_XOBJECT handle are not affected.
92*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT void FPDF_CALLCONV FPDF_CloseXObject(FPDF_XOBJECT xobject);
93*3ac0a46fSAndroid Build Coastguard Worker 
94*3ac0a46fSAndroid Build Coastguard Worker // Experimental API.
95*3ac0a46fSAndroid Build Coastguard Worker // Create a new form object from an FPDF_XOBJECT object.
96*3ac0a46fSAndroid Build Coastguard Worker //
97*3ac0a46fSAndroid Build Coastguard Worker // Returns a new form object on success, or NULL on failure. Caller owns the
98*3ac0a46fSAndroid Build Coastguard Worker // newly created object.
99*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_PAGEOBJECT FPDF_CALLCONV
100*3ac0a46fSAndroid Build Coastguard Worker FPDF_NewFormObjectFromXObject(FPDF_XOBJECT xobject);
101*3ac0a46fSAndroid Build Coastguard Worker 
102*3ac0a46fSAndroid Build Coastguard Worker // Copy the viewer preferences from |src_doc| into |dest_doc|.
103*3ac0a46fSAndroid Build Coastguard Worker //
104*3ac0a46fSAndroid Build Coastguard Worker //   dest_doc - Document to write the viewer preferences into.
105*3ac0a46fSAndroid Build Coastguard Worker //   src_doc  - Document to read the viewer preferences from.
106*3ac0a46fSAndroid Build Coastguard Worker //
107*3ac0a46fSAndroid Build Coastguard Worker // Returns TRUE on success.
108*3ac0a46fSAndroid Build Coastguard Worker FPDF_EXPORT FPDF_BOOL FPDF_CALLCONV
109*3ac0a46fSAndroid Build Coastguard Worker FPDF_CopyViewerPreferences(FPDF_DOCUMENT dest_doc, FPDF_DOCUMENT src_doc);
110*3ac0a46fSAndroid Build Coastguard Worker 
111*3ac0a46fSAndroid Build Coastguard Worker #ifdef __cplusplus
112*3ac0a46fSAndroid Build Coastguard Worker }  // extern "C"
113*3ac0a46fSAndroid Build Coastguard Worker #endif  // __cplusplus
114*3ac0a46fSAndroid Build Coastguard Worker 
115*3ac0a46fSAndroid Build Coastguard Worker #endif  // PUBLIC_FPDF_PPO_H_
116