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