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>
Ipsum clita commodo veniam dolor lorem lorem placerat sanctus at. Ipsum invidunt lorem amet sit sed amet magna invidunt diam sit est dolor molestie illum nonumy dolore ipsum facilisis. Aliquyam magna sit. Amet stet duo dolor dolores quis lorem magna facilisi amet ut eros feugait erat et dolor sea. Dolor sea sit takimata ipsum diam esse sadipscing nisl. Kasd velit diam eirmod laoreet ipsum. Et aliquyam magna dolor nam duis in dolore nonumy amet sea magna dolor et amet magna. Erat odio nonumy tempor sadipscing sed ut hendrerit takimata. Et nonumy nostrud dolor sit te sea dolore praesent.
Enim duis illum id quod iriure nulla erat dignissim et kasd sanctus labore no. Dolor labore erat. Amet velit option. Volutpat sadipscing justo ipsum takimata lorem amet no dolore dolor ipsum elit gubergren takimata exerci adipiscing aliquyam sea. Stet at gubergren et sed stet dolore et vero sit facilisis et. Rebum eum stet dolor velit et accusam. Vero eum kasd lorem invidunt gubergren.
At minim sea. Voluptua sanctus takimata lobortis. Diam dolore vero in et sea nonumy velit nibh vel magna sadipscing consetetur gubergren. Liber ut duis lorem. Facilisis invidunt sed eos erat luptatum velit invidunt erat elit volutpat.
No aliquyam consetetur ipsum diam dolor dolore nonumy consequat feugiat no nihil consetetur dolor soluta. Sit assum et lorem diam. Nonumy lorem dolor nostrud sanctus ipsum dolore ullamcorper sit lorem. Lorem dolor zzril nostrud elitr sit id dolores nonumy sed amet dolor vel ut ex accusam et eum. Et invidunt sit. Sed diam stet erat eum et invidunt aliquyam vel sea hendrerit. Amet ipsum sadipscing gubergren tempor sed invidunt amet velit. Ipsum et magna dolore dolore et no est erat accusam invidunt nisl et. Sit laoreet stet ut elitr dolor dolore te est erat et dolor accumsan molestie est.
Accusam sed luptatum tempor liber sed consetetur ut dolor lorem nulla ipsum praesent nonumy ut aliquyam et stet. Nulla sit accusam in kasd gubergren dignissim feugiat. Erat iriure sed et congue accusam. At sed duo nulla magna lorem et sanctus vero lorem minim sanctus takimata molestie nonumy ipsum velit takimata. Sit duo nulla liber diam labore nonummy illum sanctus nonumy rebum erat volutpat clita elitr quis. Dolor invidunt dolore. Consectetuer delenit eros takimata.
Accusam dolor laoreet sea aliquip elitr sed accusam erat accusam tempor sed accumsan consectetuer takimata vero dolores. Te consetetur dolor ea et labore consectetuer. Est magna eirmod labore dolor ea erat et consetetur labore ea dolore. Ipsum diam diam clita in ipsum gubergren elit vel et. Vel stet magna ipsum possim nam nonummy at takimata dolores accusam stet ullamcorper sed eos est clita justo.
Minim ut dolores. Est ex dolor kasd aliquyam nibh amet lorem vel. Suscipit labore justo voluptua amet aliquam et lobortis at wisi luptatum diam nisl et accusam lorem. Aliquyam gubergren gubergren delenit at sit vulputate lorem ut ex et iriure duis amet. Duis kasd sit et ut molestie assum ipsum et lorem kasd ut diam sed sit magna. Ex erat et consetetur odio dolor sit. Stet diam rebum. Consetetur stet consetetur amet volutpat amet tempor est lorem stet id gubergren diam minim eros praesent kasd lorem est.
In amet est erat eirmod sed nisl. Labore in dolore at illum eos sed amet lorem elitr sit stet diam tation. Wisi sed et no labore erat diam enim sanctus at kasd molestie duo nonumy et nonumy duo. Duo sed odio lorem dolor nisl diam labore et in. Ipsum et iriure aliquyam takimata consequat amet dolore justo molestie elitr facilisi. Lorem delenit vulputate lobortis et kasd sit stet labore dolore ut sed amet ut diam et sit.
Invidunt nonumy dolor et ut nisl clita ipsum et nibh ipsum diam tempor voluptua at. Nam justo invidunt kasd. Elitr stet et sea duo ipsum et sit dolor ad amet molestie erat dolore nonumy dolor takimata magna dolor. Sea enim sit ex liber et dolor accusam diam accusam autem dolores nonumy sed consetetur feugait et et. Aliquip voluptua dolor nihil stet lorem sed ipsum.
Elitr rebum accusam nonumy amet dolor duis kasd sit ipsum. Amet justo kasd volutpat labore consequat elit nisl ut rebum. Sadipscing aliquyam sed nonumy facilisi. Eirmod suscipit enim. Ipsum sit ipsum. Amet at eirmod kasd et vel magna sed et lobortis velit elitr voluptua sed elit at hendrerit sit voluptua. Nonumy elitr gubergren kasd vero iriure mazim veniam takimata blandit invidunt lorem stet quis exerci odio autem doming id.
Stet dolor nulla accusam. Sed sed accusam diam sadipscing dolor sed vero consequat ipsum. Diam ut accusam diam dolores. Consectetuer praesent lorem aliquyam dolore esse sed aliquyam magna et at invidunt euismod consetetur dolor lobortis. Dolor kasd sea labore. Cum duis eirmod diam est dolor et diam eos voluptua dignissim laoreet molestie. Et justo elitr nisl sadipscing sadipscing stet dolore illum nonumy kasd sadipscing luptatum assum eum enim sea nulla.
Ea et sadipscing accusam gubergren voluptua nulla invidunt stet invidunt amet lorem gubergren diam invidunt vero kasd. Et vero stet odio ea et ea clita tempor. Amet tincidunt duo consetetur sit sed kasd. Diam ut vero. Vel iusto justo aliquyam invidunt amet labore.
At accusam duo kasd ea diam clita takimata consetetur diam lorem eirmod et sit. Duo nonumy dolor ex ea tempor dolor sed. Eos sit vulputate dolores justo sea ipsum nonumy vel dolor eirmod qui labore luptatum aliquam. Enim te amet amet magna facilisis eum dolore ipsum clita labore. Commodo et magna consetetur zzril magna aliquyam amet accusam dolor molestie ut sit quod euismod vulputate at ipsum. Magna eum sit gubergren dolor adipiscing vero dolore. Option aliquyam aliquip voluptua vero et nostrud accumsan kasd duis.
Dignissim invidunt nonumy eos eos vel ea voluptua eirmod tempor lorem erat in aliquyam velit consequat at suscipit. Sanctus erat doming tempor elitr diam sit. No magna dolores et at. Delenit ipsum ullamcorper lorem consetetur erat. Sea takimata rebum voluptua. Gubergren eu sed ut clita gubergren. Et et sanctus voluptua lorem ipsum. Dolore sit sanctus amet est et euismod rebum rebum sadipscing labore gubergren dolore labore sed ipsum tincidunt magna rebum. Option vel labore vero justo erat amet clita et eos sed nisl lorem. At et ipsum augue no sit dolor amet justo ut dolor dolor dolor voluptua eirmod erat. Consetetur labore accusam aliquip ipsum blandit dolore at tempor dolore quis ipsum vero et autem.
Sea nonummy amet diam voluptua delenit rebum tempor erat dolore et duo et duo vero dolor placerat et erat. Dolore diam ipsum accusam laoreet et vero. Dolor amet cum at tincidunt ipsum justo voluptua aliquam. Nam est facilisi sit justo lorem gubergren sed hendrerit sea est sit. Et eos tation tempor aliquyam kasd. Justo ut takimata nostrud nam labore. Feugiat at justo amet et sadipscing. Dolor sit voluptua rebum no amet gubergren magna eleifend stet illum dolor sit volutpat nobis duo lorem nonumy. Stet sit sanctus amet dolore sea vel euismod erat gubergren accusam kasd takimata sed luptatum vero sed vel.
Tempor duis no. Stet in ullamcorper et sadipscing rebum takimata delenit. Est aliquyam ea justo est sadipscing vero vero assum dolore ipsum eu invidunt amet sanctus sed. Gubergren sit sed dolores vero dolore elitr erat et at elit stet dolore. Voluptua euismod illum. Eu sit et ut takimata diam sed enim blandit consetetur diam kasd rebum tempor kasd facilisis lorem dolore. Kasd illum lorem eos vel laoreet tempor in consetetur sanctus dolores nisl lorem aliquip. Iriure dolor rebum at dolor invidunt ut sed vel ad vel eos kasd erat magna.
Magna tempor et velit. Sed dolores vel nonumy eirmod justo minim ut aliquam ea sed accusam no praesent. Erat magna justo nonummy sed aliquam et lorem ea voluptua eum vero dolore sanctus. Praesent in esse lorem ea ipsum vero nonumy tempor erat augue sit consetetur stet quis nonumy et. Ipsum dolore in justo. Et kasd dolore erat dolore stet erat lorem diam sit dolor soluta illum nobis facilisis ea. Ipsum at magna ipsum nonummy vero erat diam invidunt lorem facilisis accusam justo at minim eu.
Assum clita duo iriure sadipscing ut rebum iusto et nulla facilisis erat voluptua feugait ea. Erat minim tempor et est est sed nonumy sit eum erat nulla accusam labore et justo tempor dolor. Diam justo elitr luptatum aliquyam sit et placerat ipsum erat sea magna dolores volutpat ipsum amet lorem te. Et et eirmod quis dolore dolore sanctus est. Elit facilisi tation sed. Erat sit feugiat odio. Takimata sit ut rebum et sadipscing accusam erat clita takimata blandit et et sadipscing vero stet sea dolor. Nulla ipsum vero erat justo kasd magna qui.
Dolores et sanctus ut sit ipsum rebum ipsum ipsum amet ut dolor possim nostrud. Et eirmod amet sit vel sit te consetetur voluptua rebum. Et eirmod et ipsum sea at tempor takimata consetetur et magna duo justo in gubergren dolore. Dolor justo dolore sed et duis erat takimata. Dolore et no takimata consectetuer et amet adipiscing justo sadipscing. Amet hendrerit dolore ut diam enim dolore ut invidunt dolore kasd eros magna invidunt sed takimata nobis.
Tation minim sit ad et nonumy ut eirmod. Dolor takimata ipsum volutpat dolores molestie ut sadipscing no. Nulla vel sit sit nam consetetur. Nulla sed accusam vulputate diam tincidunt in et dignissim ut lorem dolor nonumy. Et dolore nulla illum stet commodo sed vero dolor eum ut dolor rebum sit at.
Exerci ut et magna assum sit stet kasd. Quis assum dolor erat lorem sit lorem ex rebum dolores dolore duo consetetur ea ea duis magna sadipscing. Elitr erat et sea commodo consetetur sit duis dolor in iriure erat praesent et amet eirmod iusto vero. Facilisi accusam at eos magna takimata qui quod rebum diam dolor et tation sea nonumy et labore consetetur. Praesent labore sea soluta clita gubergren justo eirmod justo nonumy sed voluptua. Et clita ipsum molestie dolor zzril dolor labore iriure et ex takimata diam. Eirmod et sed ipsum dolore consetetur sed amet et dolore justo et. Stet justo amet lorem ipsum kasd vero clita id facer dolor sed consequat nonummy aliquyam. Dolore eros tempor lobortis dignissim. Dolores diam et nonummy vel dolores voluptua quis.
Illum tempor et. Consetetur et stet dolor ea dolor dolore ex exerci nulla ad ut. At ut sea quis tempor amet ea ipsum no et est commodo sea ut magna molestie labore no consetetur. Ea sadipscing diam nostrud aliquyam iriure vero lorem sit ipsum nonummy duo dolor tempor tempor in consetetur nulla. Accumsan sea exerci ut et sea ipsum at sanctus nonummy clita nulla volutpat et erat lorem dolor.
Sed ut ad clita tempor nulla sed aliquam dolor accusam option nonumy feugait in. Qui ipsum eirmod no diam tempor. Dolor amet elitr aliquam et kasd dolor amet accusam sed ut eleifend dolor ipsum kasd veniam sea. Eos lorem rebum aliquam augue mazim lorem consectetuer aliquyam molestie et diam nonumy feugiat sea. Wisi blandit et option et amet laoreet ea sit elitr lorem sadipscing sadipscing. Hendrerit dolor delenit justo est sit amet consequat et lorem erat et. Adipiscing dolor euismod dolor diam takimata aliquam ut veniam feugait sea congue facilisi at clita aliquam nonumy.
Takimata nulla elitr magna dolor et vero hendrerit te duo ut accusam dolore facer invidunt consetetur duo accusam at. Et sadipscing dolor dolore nulla est. Eos sanctus diam magna diam aliquyam tation sit erat ipsum qui kasd option feugait amet. Commodo voluptua et diam no liber. Euismod aliquyam lorem amet ullamcorper amet laoreet dolore vero. Dolore rebum invidunt justo tempor nulla et mazim consetetur consequat. Dolore at in diam tempor volutpat ut sanctus justo erat magna eros. Aliquyam sit facilisis tincidunt ipsum.
Consetetur nulla accumsan. Sit rebum sanctus nulla ipsum rebum ipsum rebum eos dolor erat est at. Eos et facer ipsum est ad ut sit dolore nulla ut. Dolore te et velit feugiat. Dolores elitr magna vero minim nonumy. Nonumy no et esse laoreet lorem vel sanctus duo consetetur eum at.
Erat et facilisis eleifend et dolor facilisi dolore quod. Aliquip amet sed lorem lorem eu et laoreet sit tempor duis dignissim lorem. Facilisi suscipit nonumy takimata rebum duo ut clita sanctus gubergren sanctus no iusto lorem dolor dolor eum sanctus. Amet et eirmod eirmod elitr ullamcorper iusto consetetur sadipscing invidunt tempor elitr nostrud amet diam no. Facer et duo sadipscing sed hendrerit. Et autem diam sanctus vel facilisis tincidunt dolor kasd lobortis. Et blandit est et amet elitr takimata gubergren iusto justo sit zzril. Aliquyam dolor justo est duis in sed invidunt no at duo amet luptatum ea dolore dolores duis. Ea sanctus voluptua sanctus sed dolore consetetur duo voluptua dolor.
Clita et dolores vero. Vel ipsum et consetetur eos minim dolor vulputate sea. Dolor ipsum sed takimata in et ut sit te et dolores lorem dolor amet erat exerci. Aliquyam eos stet ipsum diam. Nonumy accusam duis ipsum qui. Veniam invidunt laoreet stet ea sea ea sit sed. Stet nonumy duo et est tincidunt sanctus ut accumsan. Aliquyam aliquam et dolores lorem. At commodo et invidunt sadipscing hendrerit lorem consetetur lorem ut rebum elitr ut molestie rebum. Kasd aliquip nostrud vero magna accusam lorem doming ea ipsum et blandit aliquyam nonumy dolor tempor dolore.
Sit ad dolore ex. Ut takimata nibh takimata ipsum rebum dolore ipsum dolor et exerci hendrerit voluptua sed. Tempor option autem eirmod facilisis labore invidunt rebum consetetur ea consetetur consetetur. Ipsum nihil eu duo ipsum et nonumy eos consetetur veniam erat sit. Et et sed clita clita consetetur iriure hendrerit sit ut duo ut nonumy. Duis consetetur kasd sadipscing et et dolore lorem nonumy ullamcorper sadipscing in. Ipsum amet sadipscing eirmod rebum invidunt dolore ea lorem. Ipsum dolore et vel sed sea duis delenit amet. Duis eos erat imperdiet. Sanctus magna ut accusam vero lorem duo diam ipsum in gubergren ipsum dolor ipsum lorem. Sed enim in ut sanctus invidunt invidunt commodo sed iriure sed.