Recent versions of rmarkdown and pandoc
In more recent versions of rmarkdown, the settings of margins can be done in the YAML header via the top-level element geometry
. What you specify in the geometry
tag will be piped into the LaTeX template that ships with Pandoc via the following LaTeX snippet
$if(geometry)$
\usepackage[$for(geometry)$$geometry$$sep$,$endfor$]{geometry}
$endif$
For example, to specify margins that are 2cm in width one would include
---
title: "Habits"
author: John Doe
date: March 22, 2005
geometry: margin=2cm
output: pdf_document
---
For more complex specifications to be passed to the geometry LaTeX package, string options together as you would with LaTeX:
---
title: "Habits"
author: John Doe
date: March 22, 2005
geometry: "left=3cm,right=3cm,top=2cm,bottom=2cm"
output: pdf_document
---
Original answer
This is a LaTeX question as Pandoc is rendering to PDF via LaTeX - what you linked to represents the default margins on a LaTeX document.
The geometry LaTeX package for example can be used to alter the margins of the page. However you'll need a way to tell Pandoc to use this by including it ins the LaTeX header applied to the converted md file.
How you do this is documented in the Pandoc User Guide. See in particular the --template=FILE
command line argument and the Templates section. Essentially, either find and modify the default template to include the LaTeX instructions you want to use or start your own template from scratch and place it in the appropriate location; see the --data-dir
command line argument.
Another alternative if you are using a recent version of Pandoc is to use the variable argument (set either with -V KEY[=VAL]
or --variable=KEY[:VAL]
). The geometry
package was added to the default LaTeX template in May 2012 (see this discussion). As such, if you wanted to change the page margins, you can use:
pandoc -V geometry:margin=1in -o output.pdf input.md
You can specify multiple variable values too. For instance, if you wanted to create a 4 by 6 inch pdf with half-inch margins, you can use:
pandoc -V geometry:paperwidth=4in -V geometry:paperheight=6in -V geometry:margin=.5in -o output.pdf input.md
Given the almost identical error message, I tried following @scoa's suggestion, but putting that line in the YAML header did not change the error, so for whatever reason, Knitr wasn't looking there to determine the LaTex engine. However, next to the "Knit PDF" button in the control bar is a settings menu that allows you to specify the LaTex ending in the "Advanced" pane. This solved the problem for me. It produces a slight variation on the suggestion above, modifying the YAML header thus:
output:
pdf_document:
latex_engine: xelatex
I can see that @scoa may have assumed the YAML output was already formatted this way, but what I was missing was the colon after 'pdf_document'. Using the settings dialogue created the proper syntax in the header.
RStudio version 0.99.896, knitr version 1.12.3.
Best Answer
So,
pandoc
does not parse the content of latex environments, but you can fool it by redefining the commands in yourheader.tex
file:Thus, here
\begin{landscape}
is redefined to\blandscape
, and\end{landscape}
to\elandscape
. Using those newly defined command in the.Rmd
file seems to work: