2
1
mirror of https://github.com/qpdf/qpdf.git synced 2024-11-10 15:20:54 +00:00
qpdf/examples/pdf-set-form-values.cc

95 lines
3.3 KiB
C++
Raw Normal View History

2018-06-21 19:54:02 +00:00
#include <qpdf/QPDF.hh>
#include <qpdf/QPDFAcroFormDocumentHelper.hh>
#include <qpdf/QPDFPageDocumentHelper.hh>
2018-06-21 19:54:02 +00:00
#include <qpdf/QPDFWriter.hh>
#include <qpdf/QUtil.hh>
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
2018-06-21 19:54:02 +00:00
static char const* whoami = 0;
void
usage()
2018-06-21 19:54:02 +00:00
{
std::cerr << "Usage: " << whoami << " infile.pdf outfile.pdf value"
<< std::endl
<< "Set the value of all text fields to a specified value"
2018-06-21 19:54:02 +00:00
<< std::endl;
exit(2);
}
int
main(int argc, char* argv[])
2018-06-21 19:54:02 +00:00
{
whoami = QUtil::getWhoami(argv[0]);
if (argc != 4) {
2018-06-21 19:54:02 +00:00
usage();
}
char const* infilename = argv[1];
char const* outfilename = argv[2];
char const* value = argv[3];
// This is a contrived example that just goes through a file page
// by page and sets the value of any text fields it finds to a
// fixed value as given on the command line. The purpose here is
// to illustrate use of the helper classes around interactive
// forms.
try {
QPDF qpdf;
qpdf.processFile(infilename);
2018-06-21 19:54:02 +00:00
// We will iterate through form fields by starting at the page
// level and looking at each field for each page. We could
// also called QPDFAcroFormDocumentHelper::getFormFields to
// iterate at the field level, but doing it as below
// illustrates how we can map from annotations to fields.
QPDFAcroFormDocumentHelper afdh(qpdf);
QPDFPageDocumentHelper pdh(qpdf);
std::vector<QPDFPageObjectHelper> pages = pdh.getAllPages();
for (auto const& page: pages) {
2018-06-21 19:54:02 +00:00
// Get all widget annotations for each page. Widget
// annotations are the ones that contain the details of
// what's in a form field.
std::vector<QPDFAnnotationObjectHelper> annotations =
afdh.getWidgetAnnotationsForPage(page);
for (auto& annot: annotations) {
2018-06-21 19:54:02 +00:00
// For each annotation, find its associated field. If
// it's a text field, set its value.
2018-06-21 19:54:02 +00:00
QPDFFormFieldObjectHelper ffh =
afdh.getFieldForAnnotation(annot);
if (ffh.getFieldType() == "/Tx") {
// Set the value. Passing false as the second
// value prevents qpdf from setting
// /NeedAppearances to true (but will not turn it
// off if it's already on), so we call
// generateAppearance after setting the value. You
// may or may not want to do this depending on
// whether the appearance streams generated by
// qpdf are good enough for your purposes. For
// additional details, please see comments in
// QPDFFormFieldObjectHelper.hh for this method.
ffh.setV(value, false);
ffh.generateAppearance(annot);
2018-06-21 19:54:02 +00:00
}
}
}
// Write out a new file
QPDFWriter w(qpdf, outfilename);
2018-06-21 19:54:02 +00:00
w.setStaticID(true); // for testing only
w.write();
} catch (std::exception& e) {
std::cerr << whoami << " processing file " << infilename << ": "
<< e.what() << std::endl;
exit(2);
2018-06-21 19:54:02 +00:00
}
return 0;
}