Some test text!
Android / Guides / Save a document
Use PDFNet saving APIs from PDFDoc
class to save PDF documents on local storage. The PDFDoc
can be obtained from PDFViewCtrl
using PDFViewCtrl.getDoc()
.
To save the current PDF document to a new file on internal storage use save:
void saveDocument(PDFViewCtrl pdfViewCtrl, final String filePath, final SDFDoc.SaveMode[] saveModes) throws Exception {
final PDFDoc pdfDoc = pdfViewCtrl.getDoc();
pdfViewCtrl.docLock(true, new PDFViewCtrl.LockRunnable() {
@Override
public void run() throws Exception {
pdfDoc.save(filePath, saveModes, null);
}
});
}
To save the document on external storage specified by a URI, you can create a Filter
and use save(Filter, SaveMode[]):
void saveDocument(final PDFViewCtrl pdfViewCtrl, final Uri uri, final SDFDoc.SaveMode[] saveModes) throws Exception {
pdfViewCtrl.docLock(true, new PDFViewCtrl.LockRunnable() {
@Override
public void run() throws Exception {
SecondaryFileFilter filter = null;
try {
filter = new SecondaryFileFilter(pdfViewCtrl.getContext(), uri);
PDFDoc pdfDoc = pdfViewCtrl.getDoc();
pdfDoc.save(filter, saveModes);
} finally {
if (filter != null) {
filter.close();
}
}
}
});
}
If you want to save changes on an opened PDF document you can save incrementally which is faster:
void saveIncrementally(final PDFViewCtrl pdfViewCtrl) throws Exception {
pdfViewCtrl.docLock(true, new PDFViewCtrl.LockRunnable() {
@Override
public void run() throws Exception {
pdfViewCtrl.getDoc().save();
}
});
}
There are a few ways to save a PDF document on permanent storage such as saving with removal of unused objects, incremental saving, and saving in linearized format. See complete list in API details for SaveMode.
The REMOVE_UNUSED
mode saves disk storage space by rearranging the PDF document and removing unused objects. As a result, the output file can be significantly smaller. However, the saving process itself may take longer compared to incremental mode.
Use the INCREMENTAL
mode if you are particularly concerned about the time it takes to save the file. If you use this mode, any changes to the document, even the deletion of annotations, will be appended to the end of the PDF file. Note that it is not possible to incrementally save the document if the underlying file has an XRef table that had to be repaired when the file was opened (see https://groups.google.com/forum/#!msg/pdfnet-sdk/GZwt_U16ipw/zhq43GQnNlYJ).
The LINEARIZED
mode is to be preferentially used in file streaming situations, such as when you want to upload a PDF document. A linearized PDF file is a PDF file that is structured in a way that allows the first page of the PDF file to be displayed in a user's device before the entire file is downloaded from the Web server. If you're developing a system that creates large PDF files for delivery to client, you should try to make sure that your system can generate linearized PDF files. Your users might become frustrated and impatient if your system creates large PDF files that are not linearized, because it could take 30 seconds or even longer for a user's device to display a large PDF file that is not linearized. PDF linearization is also know as 'fast web view'.
Trial setup questions? Ask experts on Discord
Need other help? Contact Support
Pricing or product questions? Contact Sales