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