data:image/s3,"s3://crabby-images/773e0/773e0931c5901f7dcb3c8f84a0a666a2edbd58aa" alt="{emayili} Styling Figures"
By default <img>
tags are wrapped in a tight <p></p>
embrace by {knitr}
. In general this works really well. However, I want to have more control over image formatting for {emayili}
.
Adding a Hook
I’d like to have the <img>
tags wrapped by <figure></figure>
. It’d also be useful to have the option of inserting a <figcaption>
. To support these requirements I added a {knitr}
hook which adds in these tags. It responds to the following chunk parameters (all optional):
out.width
— the figure widthfig.cap
— figure captionfig.alt
— figure alternative text andfig.class
— class attached to the<figure>
tag.
Example
First we’ll try out the figure caption with the following .Rmd
file.
---
output: html_document
---
```r
plot(pressure)
```
Rendering this file, attaching to an envelope
object and sending it with {emayili}
yields the message below.
data:image/s3,"s3://crabby-images/6767a/6767a4c704ea3cdd7007a525f07c5576f5b71e46" alt="Adding a figure caption to an email message composed from R Markdown."
Nothing too exciting, just a caption neatly displayed below the plot.
Next let’s try attaching a class to the <figure>
tag. We’ll use the CSS file figures.css
. This file needs to be specified with the css_files
argument to render()
.
body {
margin: 30px 0px;
}
figure {
margin-bottom: 20px;
}
figure.center {
text-align: center;
}
figcaption {
color: white;
text-align: left;
background-color: #9fa4a7;
padding: 10px 20px;
}
figcaption::before {
content: "Figure: ";
}
In the .Rmd
file we use the fig.class
parameter to apply the center
class to the <figure>
.
---
output: html_document
---
```r
plot(pressure)
```
And this is what the rendered message looks like.
data:image/s3,"s3://crabby-images/a7a55/a7a55a9f93900907e8e41c9a1804b51710804d1f" alt="Using CSS to centre a figure in en email message composed in R Markdown."
The <img>
is now centered in the <figure>
.
Finally we’ll bring it all together by styling a figure caption.
---
output: html_document
---
```r
plot(pressure)
```
And the result in your inbox.
data:image/s3,"s3://crabby-images/9e1e3/9e1e39076c86de860dd1351ecefe95a0c8ca96e6" alt="An email containing a message with styled figure caption."
Since many automated reports use figures, the ability to style those figures should be very useful.