-
Notifications
You must be signed in to change notification settings - Fork 85
/
README.Rmd
473 lines (324 loc) · 15.5 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
---
title: "R Markdown Format for reveal.js Presentations"
output: github_document
---
<!-- badges: start -->
[![CRAN status](https://www.r-pkg.org/badges/version/revealjs)](https://CRAN.R-project.org/package=revealjs)
[![R-CMD-check](https://github.com/rstudio/revealjs/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/rstudio/revealjs/actions/workflows/R-CMD-check.yaml)
[![reveal.js](https://img.shields.io/badge/reveal.js-`r revealjs:::revealjs_version()`-yellow)](https://github.com/rstudio/revealjs/tree/main/inst/reveal.js-`r revealjs:::revealjs_version()`)
<!-- badges: end -->
## Overview
This repository provides an [R Markdown](http://rmarkdown.rstudio.com) custom format for [reveal.js](https://revealjs.com/) HTML presentations. The packages includes _reveal.js_ library in version `r revealjs:::revealjs_version()`
You can use this format in R Markdown documents by installing this package as follows:
``` r
install.packages("revealjs")
```
To create a [reveal.js](https://revealjs.com/) presentation from R Markdown you specify the `revealjs_presentation` output format in the front-matter of your document. You can create a slide show broken up into sections by using the `#` and `##` heading tags (you can also create a new slide without a header using a horizontal rule (`----`). For example here's a simple slide show:
``` markdown
---
title: "Habits"
author: John Doe
date: March 22, 2005
output: revealjs::revealjs_presentation
---
# In the morning
## Getting up
- Turn off alarm
- Get out of bed
## Breakfast
- Eat eggs
- Drink coffee
# In the evening
## Dinner
- Eat spaghetti
- Drink wine
## Going to sleep
- Get in bed
- Count sheep
```
## Rendering
Depending on your use case, there are 3 ways you can render the presentation.
1. RStudio
2. R console
3. Terminal (e.g., bash)
### RStudio
When creating the presentation in RStudio, there will be a `Knit` button right below the source tabs. By default, it will render the current document and place the rendered `HTML` file in the same directory as the source file, with the same name.
### R Console
The `Knit` button is actually calling the `rmarkdown::render()` function. So, to render the document within the R console:
``` r
rmarkdown::render('my_reveal_presentation.Rmd')
```
There are many other output tweaks you can use by directly calling `render`. You can read up on the [documentation](https://pkgs.rstudio.com/rmarkdown/reference/render.html) for more details.
### Command Line
When you need the presentation to be rendered from the command line:
``` bash
Rscript -e "rmarkdown::render('my_reveal_presentation.Rmd')"
```
## Display Modes
The following single character keyboard shortcuts enable alternate display modes:
- `'f'` enable fullscreen mode
- `'o'` enable overview mode
- `'b'` enable pause mode with a black screen hiding slide content
- `'?'` enable help mode to show keyboard shortcut cheatsheet
- `'s'` enable presentation mode with speaker notes when the Notes plugin is activated
- `'m'` enable menu mode when the 'menu' plugin is activated
Pressing `Esc` exits all of these modes.
## Incremental Bullets
You can render bullets incrementally by adding the `incremental` option:
``` yaml
---
output:
revealjs::revealjs_presentation:
incremental: true
---
```
If you want to render bullets incrementally for some slides but not others you can use this syntax:
``` markdown
::: incremental
- Eat spaghetti
- Drink wine
:::
```
or
``` markdown
::: nonincremental
- Eat spaghetti
- Drink wine
:::
```
## Incremental Revealing
You can also add pauses between content on a slide using `. . .`
``` markdown
# Slide header
Content shown first
. . .
Content shown next on the same slide
```
Using Fragments explicitly is also possible
``` markdown
# Slide header
Content shown first
::: fragment
Content shown next on the same slide
:::
```
## Appearance and Style
There are several options that control the appearance of revealjs presentations:
- `theme` specifies the theme to use for the presentation (available themes are `r knitr::combine_words(setdiff(revealjs:::revealjs_themes(), "default"), before = '"', and = " or ")`
- `highlight` specifies the syntax highlighting style. Supported styles include `r knitr::combine_words(rmarkdown:::highlighters(), before = '"', and = " or ")`. Pass null to prevent syntax highlighting.
- `center` specifies whether you want to vertically center content on slides (this defaults to false).
For example:
``` yaml
output:
revealjs::revealjs_presentation:
theme: sky
highlight: pygments
center: true
```
[Revealjs documentation about themes](https://revealjs.com/themes/)
## Slide Transitions
You can use the `transition` and `background_transition` options to specify the global default slide transition style:
- `transition` specifies the visual effect when moving between slides. Available transitions are `r (trans <- knitr::combine_words(setdiff(revealjs:::revealjs_transitions(), "default"), before = '"', and = " or "))`.
- `background_transition` specifies the background transition effect when moving between full page slides. Available transitions are `r trans`
For example:
``` yaml
output:
revealjs::revealjs_presentation:
transition: fade
background_transition: slide
```
You can override the global transition for a specific slide by using the data-transition attribute, for example:
``` markdown
## Use a zoom transition {data-transition="zoom"}
## Use a faster speed {data-transition-speed="fast"}
```
You can also use different in and out transitions for the same slide, for example:
``` markdown
## Fade in, Slide out {data-transition="slide-in fade-out"}
## Slide in, Fade out {data-transition="fade-in slide-out"}
```
This works also for background transition
``` markdown
## Use a zoomed background transition {data-background-transition="zoom"}
```
[Revealjs documentation about transitions](https://revealjs.com/transitions/)
## Slide Backgrounds
Slides are contained within a limited portion of the screen by default to allow them to fit any display and scale uniformly. You can apply full page backgrounds outside of the slide area by adding a data-background attribute to your slide header element. Four different types of backgrounds are supported: color, image, video and iframe. Below are a few examples.
``` markdown
## CSS color background {data-background-color=#ff0000}
## Full size image background {data-background-image="background.jpeg"}
## Video background {data-background-video="background.mp4"}
## Embed a web page as a background {data-background-iframe="https://example.com"}
```
Backgrounds transition using a fade animation by default. This can be changed to a linear sliding transition by specifying the `background-transition: slide`. Alternatively you can set `data-background-transition` on any slide with a background to override that specific transition.
[Revealjs documentation about backgrounds](https://revealjs.com/backgrounds/)
## 2-D Presentations
You can use the `slide_level` option to specify which level of heading will be used to denote individual slides. If `slide_level` is 2 (the default), a two-dimensional layout will be produced, with level 1 headers building horizontally and level 2 headers building vertically. For example:
``` markdown
# Horizontal Slide 1
## Vertical Slide 1
## Vertical Slide 2
# Horizontal Slide 2
```
With this layout horizontal navigation will proceed directly from "Horizontal Slide 1" to "Horizontal Slide 2", with vertical navigation to "Vertical Slide 1", etc. presented as an option on "Horizontal Slide 1". Global reveal option [`navigationMode`](https://revealjs.com/vertical-slides/#navigation-mode) can be tweaked to change this behavior.
## Reveal Options
Reveal.js has many additional options to configure it's behavior. You can specify any of these options using `reveal_options`, for example:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
self_contained: false
reveal_options:
slideNumber: true
previewLinks: true
---
```
You can find documentation on the various available Reveal.js options here: <https://revealjs.com/config/>.
## Figure Options
There are a number of options that affect the output of figures within reveal.js presentations:
- `fig_width` and `fig_height` can be used to control the default figure width and height (7x5 is used by default)
- `fig_retina` Specifies the scaling to perform for retina displays (defaults to 2, which currently works for all widely used retina displays). Note that this only takes effect if you are using knitr >= 1.5.21. Set to `null` to prevent retina scaling.
- `fig_caption` controls whether figures are rendered with captions
For example:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
fig_width: 7
fig_height: 6
fig_caption: true
---
```
## MathJax Equations
By default [MathJax](http://www.mathjax.org/) scripts are included in reveal.js presentations for rendering LaTeX and MathML equations. You can use the `mathjax` option to control how MathJax is included:
- Specify "default" to use an https URL from the official MathJax CDN.
- Specify "local" to use a local version of MathJax (which is copied into the output directory). Note that when using "local" you also need to set the `self_contained` option to false.
- Specify an alternate URL to load MathJax from another location.
- Specify null to exclude MathJax entirely.
For example, to use a local copy of MathJax:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
mathjax: local
self_contained: false
---
```
To use a self-hosted copy of MathJax:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
mathjax: "http://example.com/mathjax/MathJax.js?config=TeX-AMS-MML_HTMLorMML"
---
```
To exclude MathJax entirely:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
mathjax: null
---
```
## Document Dependencies
By default R Markdown produces standalone HTML files with no external dependencies, using data: URIs to incorporate the contents of linked scripts, stylesheets, images, and videos. This means you can share or publish the file just like you share Office documents or PDFs. If you'd rather keep dependencies in external files you can specify `self_contained: false`. For example:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
self_contained: false
---
```
Note that even for self contained documents MathJax is still loaded externally (this is necessary because of it's size). If you want to serve MathJax locally then you should specify `mathjax: local` and `self_contained: false`.
One common reason keep dependencies external is for serving R Markdown documents from a website (external dependencies can be cached separately by browsers leading to faster page load times). In the case of serving multiple R Markdown documents you may also want to consolidate dependent library files (e.g. Bootstrap, MathJax, etc.) into a single directory shared by multiple documents. You can use the `lib_dir` option to do this, for example:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
self_contained: false
lib_dir: libs
---
```
## Reveal Plugins
You can enable various reveal.js plugins using the `reveal_plugins` option. Plugins currently supported include:
| Plugin | Description |
|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| [notes](https://revealjs.com/speaker-view/) | Present per-slide notes in a separate browser window. Open Note view pressing `S`. |
| [zoom](http://lab.hakim.se/zoom-js/) | Zoom in and out of selected content with `Alt+Click.` |
| [search](https://github.com/hakimel/reveal.js/blob/master/plugin/search/search.js) | Find a text string anywhere in the slides and show the next occurrence to the user. Open search box using `CTRL + SHIFT + F`. |
| [chalkboard](https://github.com/rajgoel/reveal.js-plugins/tree/master/chalkboard) | Include handwritten notes within a presentation. Press `c` to write on slides, Press `b` to open a whiteboard or chalkboard to write. |
| [menu](https://github.com/denehyg/reveal.js-menu) | Include a navigation menu within a presentation. Press `m` to open the menu. |
Note that the use of plugins requires that the `self_contained` option be set to false. For example, this presentation includes both the "notes" and "search" plugins:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
self_contained: false
reveal_plugins: ["notes", "search"]
---
```
You can specify additional options for the `chalkboard` and `menu` plugins using `reveal_options`, for example:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
self_contained: false
reveal_plugins: ["chalkboard", "menu"]
reveal_options:
chalkboard:
theme: whiteboard
toggleNotesButton: false
menu:
side: right
---
```
No other plugins can be added in `revealjs_presentation()`. You can open feature request for new plugins or you would need to use a custom template to write your own HTML format including custom plugins.
## Advanced Customization
### Includes
You can do more advanced customization of output by including additional HTML content or by replacing the core pandoc template entirely. To include content in the document header or before/after the document body you use the `includes` option as follows:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
includes:
in_header: header.html
before_body: doc_prefix.html
after_body: doc_suffix.html
---
```
### Pandoc Arguments
If there are pandoc features you want to use that lack equivalents in the YAML options described above you can still use them by passing custom `pandoc_args`. For example:
``` yaml
---
title: "Habits"
output:
revealjs::revealjs_presentation:
pandoc_args: [
"--title-prefix", "Foo",
"--id-prefix", "Bar"
]
---
```
Documentation on all available pandoc arguments can be found in the [pandoc user guide](https://pandoc.org/MANUAL.html#options).
## Shared Options
If you want to specify a set of default options to be shared by multiple documents within a directory you can include a file named `_output.yaml` within the directory. Note that no YAML delimiters or enclosing output object are used in this file. For example:
**\_output.yaml**
``` yaml
revealjs::revealjs_presentation:
theme: sky
transition: fade
highlight: pygments
```
All documents located in the same directory as `_output.yaml` will inherit it's options. Options defined explicitly within documents will override those specified in the shared options file.
## Code of Conduct
Please note that the revealjs project is released with a [Contributor Code of Conduct](https://pkgs.rstudio.com/revealjs/CODE_OF_CONDUCT.html). By contributing to this project, you agree to abide by its terms.