Using a custom set of XML tags inside your HTML, you can insert both custom metadata as well as instructions for how the PDF would be viewed in a PDF viewer application (subject of course to that application supporting those features).
You use the (optional) tag <pdfproperties> and within that tag you
can insert <metainfo> and <pdfpreferences>
sections as shown in the instructions below. Within the
<metainfo> tag, you can add <prop> tags
with @name, @value attribute pairs with the data you wish
to store in the PDF metadata. Anything without one of the recognized, standard PDF
names (author, title, subject,
creator, keywords) are stored in custom metadata in
the PDF.
The <pdfpreferences> section allows you to insert one or more
<pref> tags with specific @name,
@value pairs that control the way the resulting PDF is displayed
with a viewer that supports standard PDF view attributes. The support
name, @value pairs are listed below and grouped into
all the available categories:
These options let you control some general information about the generated PDF.
bookmarks - sets whether PDF bookmarks are generated or not. The default
is "false" for Cloudformatter. You can set @value to "true" if you want
bookmarks in PDF. Note that bookmarks are only generated for interpreted
hierarchical information. All h1 elements and there following
h2 elements and so on. Skipping levels will break the sequence and
the bookmarks will not be correct.
pdf-version - sets the PDF version number. The default is version 1.5
for Cloudformatter but you set @value to values like "1.3", "1.4",
"1.6" or "1.7" if you wish to change the version. Be aware thar some other features
could be disabled by setting the version too low.
compress - sets whether the PDF is compressed or not. The default is
"true" for Cloudformatter. You can set @value to "false" if you want
uncompressed PDF.
linearize - sets whether the PDF is linearized or not. The default is
"false" for Cloudformatter. You can set @value to "true" if you want to
optimize a long PDF for web view.
These options let you control how the PDF when opened appears to the end user.
view-mode - Choose from one of the following:
auto - If there are bookmarks in the document, the bookmarks pane
is displayed. Otherwise, all auxiliary panes are hidden.show-none - All auxiliary panes are hidden.show-bookmarks - The bookmarks pane is displayed.show-thumbnails - The thumbnails pane is displayed.full-screen - The document is displayed in full screen-mode.initial-zoom - Choose from one of the following:
auto - Page scaling is not specified.fit - The page is scaled to fit completely into the view port.fit-width - The page is scaled so that its width matches the width
of the view port.fit-height - The page is scaled so that its height matches the
height of the view port.### or ####% - The page is scaled by the number or
percentage specified.page-layout - Choose from one of the following:
auto - Uses settings of viewer application.single-page - Displays one page at a time.continuous - Displays pages continuously in one column.two-columns-left - Displays pages continuously in two columns, with
odd-numbered pages to the left.two-columns-right - Displays pages continuously in two columns,
with odd-numbered pages to the right.two-pages-left - Displays pages in two columns, by two pages at a
time, with odd-numbered pages to the left. two-pages-right - Displays pages in two columns, by two pages at a
time, with odd-numbered pages to the right.viewer-preferences - A comma separated list of the following
possibilities:
hide-toolbar - Hides the viewer application's tool bars when the
document is active.hide-menubar - Hides the viewer application's menu bar when the
document is active.hide-window-ui - Hides user interface elements in the document's
window (such as scroll bars and navigation controls), leaving only the
document's contents displayed.fit-window - Resizes the document's window to fit the size of the
first displayed page.center-window - Positions the document's window in the center of
the screen.display-document-title - Controls whether the window's title bar
displays the document title taken from the "title" metadata field.These options allow you to specify owner and user security in the PDF output. User-level security can inject a password to be used to open the PDF, while owner-level security can control what can be done with the PDF (like printing it or copying the data from it).
userpassword - Sets the user password that must be entered to view the
PDF. There are no options, the @value passed is the password to be
used.
ownerpassword - Sets the owner password that must be entered to enable
advanced processing of the PDF. There are no options, the @value passed
is the password to be used. An ownerpassword is used to lock down certain privledges
that an owner will grant to a recipient of the PDF. Without the owner password,
recipients can be restricted from certain things. By default they are restricted
from everything, and you can then specify what additional things you allow by using
userpriviledges.
userpriviledges - A comma separated list of the following
possibilities:
print - Enables printing the document. modify - Enables editing the document. copy - Enables copying text and images from the document to the
clipboard. annotate - Enables adding notations to the document and changing
the field values. These allow you to specify crop marks, bleeds and registration marks to be applied to the PDF.
crop-offset - specify offsets from the meaningful content on the page to
the edges of the physical media (/MediaBox entry in the PDF page dictionary). Its
value is a series of 1 to 4 length specifiers that set offsets from the edges of the
page area to the corresponding edges of the /MediaBox. Rules for expanding the value
are the same as for the padding property in CSS.
bleed - specify the bleeds — an extra space around the page area into
which the contents of the page may protrude (/BleedBox entry in the PDF page
dictionary). Its value is a series of 1 to 4 length specifiers that set offsets from
the edges of the page area to the corresponding edges of the /BleedBox. Rules for
expanding the value are the same as for the padding property in CSS.
crop-mark-width - defines line width for the crop marks, setting it to 0
disables drawing of crop marks.
bleed-mark-width - defines line width for the bleed marks, setting it to
0 disables drawing of bleed marks.
printer-mark - specify additional SVG images to be drawn in the offset
area surrounding the page (specified by crop-offset and bleed parameters). Printer
marks are clipped to the outside of the bleed rectangle. The @value is
a URL to an SVG you have. This sample has two URLs (one for a colorbar and one for a
registration mark) you can also use if you like.
The following code is what is behind this page for producing the PDF. Of course, you would only see the things supported by your PDF viewer you use. If you wish to see them all in action, then use "download" and Adobe Reader to view the PDF.
Recent changes in some browsers will not treat this XML as XML. Instead it tries (incorrectly) to not close tags. For best results, be sure to use open and close tags and not a self-closing tag.
<pdfproperties style="display:none;">
<metainfo>
<prop name="author" value="Xportability LLC"></prop>
<prop name="title"
value="Xportability Cloudformatter: Showing Custom
PDF Properties"></prop>
<prop name="subject" value="A Cloudformatter Document"></prop>
<prop name="creator" value="css2pdf@cloudformatter.com"></prop>
<prop name="keywords" value="CSS, PDF, Cloudformatter"></prop>
<prop name="custom1" value="value1"></prop>
<prop name="custom2" value="value2"></prop>
<prop name="custom3" value="value3"></prop>
<prop name="custom4" value="value4"></prop>
</metainfo>
<pdfpreferences>
<pref name="bookmarks" value="true"></pref>
<pref name="pdf-version" value="1.6"></pref>
<pref name="view-mode" value="auto"></pref>
<pref name="initial-zoom" value="fit-height"></pref>
<pref name="page-layout" value="two-columns-left"></pref>
<pref name="viewer-preferences" value="display-document-title"></pref>
<pref name="crop-offset" value="0.5in"></pref>
<pref name="crop-mark-width" value="1px"></pref>
<pref name="printer-mark"
value="http://www.cloudformatter.com/Resources/Images/registration.svg"></pref>
<pref name="printer-mark"
value="http://www.cloudformatter.com/Resources/Images/colorbar.svg"></pref>
</pdfpreferences>
</pdfproperties>
Invidunt lorem accusam dolor takimata feugiat. Consequat et et duo option eirmod erat erat consetetur lorem diam takimata autem takimata magna kasd. Et est sed ipsum amet augue. Justo nibh delenit no magna voluptua amet sed consectetuer veniam rebum ea tempor et dolor sit kasd. Elitr ipsum sadipscing duis et ea voluptua odio stet vero invidunt. Diam vel consetetur sit lorem eos sadipscing accusam et vulputate ipsum.
Et sadipscing duis sed. Ex no consequat nonummy id eos est qui magna clita dolore ullamcorper aliquyam magna nonumy et. Sit voluptua clita accumsan erat laoreet diam justo magna sit sea vero sit suscipit vulputate. Elitr sit sadipscing stet nonummy tempor lorem delenit ipsum voluptua aliquyam. Duis ut ea dolor elitr nibh dolore sed lorem. Accusam liber aliquyam no accusam eos dolor dolore ut labore.
Tempor clita eum et eros aliquyam sit ipsum diam cum elitr nisl assum lorem erat amet dolore. Ipsum dolor te ipsum sed liber aliquip est amet. Sit amet sed no amet lobortis tempor consequat sit lobortis ipsum dolore facilisis labore. Ipsum rebum et et in et ipsum veniam dolor diam ea soluta eos. At amet est stet molestie et exerci nostrud et et labore stet amet gubergren elitr.
Et kasd clita iusto elitr dolor dolor gubergren. Lorem eos lobortis. Ut dolor ipsum vel voluptua. Magna erat nonumy. Sed vero magna ipsum molestie. Justo sadipscing voluptua sit tincidunt dolor elitr clita elit labore sea dignissim lorem laoreet vero velit est. Ut dolore et velit et accusam dolore et magna ea labore delenit iriure diam stet eu veniam. Sit et stet tempor te esse duis elitr rebum clita enim.
Gubergren justo et dolores velit. Dolore quod labore justo sea ea eros quis labore justo dolores sanctus est ea ipsum adipiscing labore labore elit. Autem sit at sea nisl volutpat labore exerci facilisi consetetur imperdiet vero. Dignissim diam clita et sit sanctus sanctus labore et rebum assum sit est consetetur et clita eros. Dolore justo ut dolore no. Amet eos aliquam dolore lorem accusam sed eros sadipscing autem sit aliquip accumsan dolore labore erat clita et. Nonumy invidunt clita aliquip gubergren. At magna gubergren rebum est. Takimata lorem sadipscing. Sit dolor invidunt ut amet suscipit sed tempor diam feugait.
Elitr dolor cum sed autem facer at dolore. Aliquyam sit aliquyam nulla diam magna nihil eirmod at sed diam eum sed rebum autem eirmod dolor sed lorem. Voluptua clita praesent laoreet euismod nonumy sed at rebum voluptua et eos eum exerci et takimata gubergren sed. Nonummy lorem ipsum zzril ut. Amet rebum sanctus no. Dolore option voluptua eos sanctus qui. Ut rebum dolor vero duo vero dolore amet ut labore. Dolor nonumy diam takimata dolore iusto consetetur clita. Ut zzril dolor at labore magna consetetur sed invidunt autem ut.
Imperdiet dolor ea sea ea et ut magna accusam no et clita ea sit voluptua vero dolores. Rebum amet nonumy consetetur kasd ipsum diam sed dolores commodo ut gubergren illum. Tempor diam sadipscing quod no ut lorem consectetuer vero. Ea takimata sed stet justo dolore erat lorem duo erat. Takimata ea invidunt elitr amet magna duis stet at consetetur gubergren dolore accusam at iriure. Dolor zzril gubergren duo feugiat. Dolore erat ipsum et delenit. Illum aliquyam nobis voluptua vero et augue eos et invidunt ipsum consetetur quis ut et nonumy.
Takimata eirmod elitr et sit eos in amet minim dolor sed. Nonumy esse amet sed dolor amet hendrerit soluta dolores ut sit vero ipsum dolores esse ea vero dolor lobortis. Sed accusam erat dolore stet nostrud delenit erat dolore nonumy takimata clita. Blandit sit dolor diam justo takimata est dolore dignissim et accusam at labore sit ut tempor tincidunt est. Sed vero et dolores et velit feugiat blandit rebum congue ut sanctus. Sit gubergren ut. Sed nonumy ipsum suscipit nisl est in est imperdiet consectetuer sed at commodo et diam at. Et justo commodo erat tincidunt eirmod suscipit eirmod vero dolore amet kasd. At vero duo. Dolor esse option sea consetetur justo consequat diam placerat nonumy ea hendrerit et vero iriure aliquyam lorem dolores accusam.
Dolores amet magna ut euismod eos sit gubergren cum at lorem takimata dolores erat justo. Commodo eos nisl est dolore et amet gubergren magna takimata in. Aliquyam at no ipsum sit in iriure dolor erat et zzril diam no odio eirmod rebum amet adipiscing duo. Consetetur ullamcorper ut sadipscing tempor clita no dolor sit accusam velit molestie commodo sed aliquyam sed et ut takimata. Consequat feugiat vero euismod no accusam aliquyam facilisis. Ut ipsum enim. Delenit nibh nulla possim et dolor eirmod enim clita dolor vel. Sed labore kasd facilisi gubergren eos kasd hendrerit hendrerit delenit duis adipiscing elitr vel. Aliquip consequat takimata et vero at dolor et lorem et. Amet adipiscing et no accusam erat sit gubergren magna iusto. Eirmod ut iusto esse molestie feugiat lorem dolores kasd ipsum ea justo aliquip et est.
Sadipscing zzril duo sea aliquam labore adipiscing consetetur et. Quod elit ut ea assum elitr dolore. Nonumy clita clita et ut et invidunt kasd sadipscing lorem. Amet nonumy et sadipscing et labore ea. Diam tempor sit elitr clita ea dolor at dolor at consequat voluptua diam eos at.
Diam est labore amet et exerci erat diam quis et. Vero lorem duis eu. Dolor est eos diam stet takimata facilisi erat nulla nisl ut gubergren vero ipsum dolore erat sit justo. Sanctus kasd et sanctus sed duo rebum elit elitr lorem dolor duis. Praesent consequat ut duo sanctus tation voluptua aliquyam kasd adipiscing eos.
Ipsum volutpat at clita elit nibh est sadipscing in sea magna lorem. Nulla sanctus elitr zzril rebum facilisis sanctus liber consetetur takimata enim sea eos dolore. Vero amet zzril lorem diam eos sit ea eos aliquyam nonumy aliquyam at est dolor sed facilisis. Sed ipsum lorem eirmod consectetuer lorem clita sit duo at tation aliquyam. Voluptua rebum sea et iriure diam. Diam est at sed. Adipiscing voluptua invidunt amet sit aliquyam sed eirmod elitr nibh nostrud ipsum.
Sit liber diam liber no lorem clita sit minim vero dolores invidunt est dolor. Esse voluptua vero no sit dolor erat eirmod zzril praesent. Autem elitr elitr magna clita consetetur labore rebum ea amet et ea elit. Sea velit adipiscing amet dolore autem at diam minim est takimata lorem nonumy et tempor duo erat. Ipsum aliquyam takimata et lorem eos.
Dolor eros invidunt et illum tempor at et nonummy magna diam. Dolore justo lorem ut aliquyam tempor takimata ut et sit et autem voluptua ex ea qui aliquyam. Dolor et sit nulla. Dolores diam rebum in et delenit dolores dolore sit lorem magna. Labore dolor justo invidunt et euismod nam amet sit iusto nonumy sanctus magna facer hendrerit hendrerit. Amet vel et sanctus eos tempor. Dolor no est dolor diam lorem eos clita rebum justo adipiscing no. Eu justo nulla ut nonummy rebum dolore. Takimata ullamcorper erat at et facilisis dolor accusam sanctus accusam dolore et ipsum velit invidunt et ex euismod. Autem gubergren elitr ut. Aliquyam dolor gubergren vel velit duo vel takimata diam ea euismod esse facilisis sed duis ut et sed sea.
Et sed no consequat ut esse ipsum amet clita et rebum et et at at cum et dolore. Sed accusam elit nam amet kasd vero sed aliquyam sit voluptua eirmod ea sea sea kasd sanctus duo clita. Dolor rebum ea ipsum sed erat ut liber amet accusam et kasd at clita kasd aliquyam. Ipsum rebum duo kasd stet. Sadipscing tempor invidunt aliquyam id clita. Eos lorem augue magna ullamcorper vero sanctus. Ut amet dolor takimata in no sit at aliquyam et imperdiet sed accusam invidunt aliquam. Eos illum amet accusam sed. Praesent clita in et luptatum sit amet sadipscing iriure ipsum accumsan placerat molestie amet placerat velit et. Elitr facilisis facilisi stet ipsum labore.
Vel vel nonummy voluptua feugiat invidunt est clita ad consectetuer. Consetetur kasd aliquyam elitr invidunt odio tempor diam vel amet. Stet et augue. Erat vel illum qui rebum et labore aliquyam clita et adipiscing qui nisl et velit sadipscing. No no eum duo laoreet. Dignissim sadipscing ipsum zzril labore tempor duis consequat feugait dolore. Sanctus lorem magna clita justo et feugait magna consetetur at clita invidunt aliquip. Kasd vulputate et sanctus et dolores sit.
Vero dolore elitr consetetur amet tation dolor ut sed diam consetetur ad et veniam lorem nulla. Tempor invidunt sed feugait duo takimata ut dolores et eum quis et et ad doming. Ut est justo diam quis suscipit odio magna iriure nonumy sit amet dolore erat ipsum. Sit vero aliquyam ea magna dolor tempor liber takimata sed sed ea enim et no dolor. Amet ipsum takimata cum adipiscing in dolor lorem. Duo diam gubergren suscipit invidunt nibh et ea ut diam dolore nibh justo. Clita rebum dolor tempor illum facilisi dolore clita clita accusam duis.
Diam facilisis takimata dolore ut illum et nonummy ipsum doming elit vero volutpat duis duo sed ea clita lorem. Exerci autem est sadipscing eirmod et mazim ea est lorem. Clita accusam duis eum justo sit dolore magna. Invidunt magna te tempor sanctus stet stet elitr aliquyam duo accusam no nulla et facer stet diam ipsum. Dolor elitr duo odio eos eirmod consequat lorem duo sanctus. Ex ipsum aliquyam no dolor nibh sit ipsum tempor et ipsum aliquip invidunt nam. Eos eirmod sit no aliquyam erat ipsum et augue lorem justo sed sit lorem ipsum tincidunt sit ut feugiat.
Feugiat duis eum rebum nostrud labore quis labore amet feugait enim et amet accumsan ut justo no diam lorem. Ut dolores sanctus nibh lorem vero eirmod cum feugiat takimata zzril. Dolor ea ipsum hendrerit eros amet invidunt vulputate ullamcorper consetetur magna clita justo. Dolor accumsan consequat nostrud stet no autem labore magna consetetur sadipscing dolores ea labore. Sanctus laoreet eros consetetur rebum sit ut consequat sed dolore delenit accumsan enim amet voluptua est minim takimata.
Commodo et et ut accusam sadipscing aliquyam ea te eum suscipit aliquyam rebum dolore eleifend lorem. Duo takimata et amet tempor feugait ipsum nam invidunt magna eirmod tempor. Lorem kasd amet amet odio. Cum accusam eos justo sea praesent diam lorem dolor erat dolor nonumy rebum lobortis dolore amet amet lorem. Quis at vero lorem consequat clita amet ipsum eirmod eos stet invidunt et lorem. Qui aliquip amet accusam no dolor kasd sed amet eirmod no elitr.
Sed lorem gubergren invidunt. Kasd lorem erat et et takimata takimata. Eirmod dolores diam et et vel invidunt eirmod lorem et erat. Ut congue aliquyam erat kasd sit et. Amet autem sed.
Vero sadipscing feugiat diam at. Et sit voluptua et sed est. Et sed tempor no et accusam dolore diam. Adipiscing et dolores kasd at consequat. Et vero diam labore lorem ipsum hendrerit nonummy ipsum dignissim no nulla consetetur no diam consequat takimata. Minim ipsum nonumy invidunt eos et accusam dolore autem dolore ut vero dolore adipiscing.
At et eirmod nobis invidunt commodo. Feugiat clita est clita dolor elit consequat lorem nobis. Tincidunt feugiat nonumy elitr dolor. Vel dolor invidunt sea et ipsum vero tempor sadipscing et eos blandit placerat. Est tempor rebum duis sed sanctus justo rebum duo consequat sea. Facilisi aliquyam consetetur ipsum mazim veniam sed.
Duo et vulputate ipsum at eirmod dolores justo. Tation labore amet ipsum eirmod diam praesent vero nulla duo et ea eirmod illum lorem facer imperdiet facilisis. Diam gubergren diam sea dolore at in. Sed rebum lorem sed dolor amet sit at vero et velit elitr diam lobortis. Labore te ut nonumy sit et in clita vel vero vero clita ut et id vel sanctus luptatum.
Gubergren sed at magna sed vel suscipit at dolores sanctus vulputate ipsum consequat at consetetur autem. Est hendrerit accusam amet ea facilisi illum facilisis et no ut lorem aliquyam clita id sed. Gubergren takimata dolor accusam ea lorem in praesent amet lorem sed ipsum diam justo. Clita labore sanctus. Sed gubergren voluptua cum magna ea sea invidunt dolore dolor tempor augue elitr kasd facilisis dolore ipsum.
Sed dolor amet dolores et dolor at consetetur takimata eos praesent consequat sed suscipit dolores stet duo praesent. Nobis vulputate takimata ipsum tation eos sea diam dolore dolor wisi eirmod takimata clita invidunt illum. Soluta sadipscing cum nobis eos elitr sit ex amet sea amet sea eum ipsum nulla enim. Dolores dolore amet magna illum consetetur ea vero gubergren dolor sanctus volutpat nonumy vulputate. Et sadipscing aliquyam in lorem ut vero amet nonumy.
Ea clita justo esse eum kasd in gubergren ad odio sit magna et. Lorem tincidunt rebum hendrerit enim aliquyam et sit vero eirmod ut molestie rebum et ut vulputate hendrerit amet sed. Rebum ipsum est est sed sit erat invidunt sit justo est et imperdiet at. Diam facilisis magna et et vero elit ut magna laoreet est sit sed. Velit et ipsum at eum consequat sit eirmod diam clita duo dolor vel. Sanctus et veniam sed lorem invidunt delenit kasd ea accusam at et augue dolore vero dolore laoreet et ipsum.
Invidunt duis aliquyam ipsum sea erat diam invidunt duis placerat ea. Euismod duo rebum kasd rebum at justo dolor. Sit qui ea te takimata duo rebum. Facilisi dolor ipsum dolores ut justo invidunt. Tempor duis eros nulla at eirmod nihil gubergren sed ut dolore no accusam. At commodo rebum dolor tempor magna autem.