blob: eabba20eed65700136dd0cc9d640fd911ba871ae [file] [log] [blame]
Hao Zhuf1873a42019-01-07 15:57:01 -05001#' Render the table as an format-independent image and use it in rmarkdown
2#'
3#' @description This function generates a temporary png file using `save_kable`
4#' and then try to put it in an rmarkdown document using
5#' `knitr::include_graphics`.
6#'
7#' @param x kable input. Either HTML or LaTeX
8#' @param width Image width in inches. (1 inch = 2.54 cm)
9#' @param height Image height in inches. (1 inch = 2.54 cm)
Hao Zhub361fb52019-01-15 12:24:10 -060010#' @param file By default, as_image saves to an temp file, which works for
11#' normal rmarkdown. However if you are using things like xaringan, which can't
12#' be a standalone html, you can specify this file be the path you need, eg.
13#' "img/something.png"
14#'
Hao Zhuf1873a42019-01-07 15:57:01 -050015#' @param ... Additional arguments passed to save_kable.
16#'
17#'
18#' @export
19as_image <- function(x, width = NULL, height = NULL,
20 ...) {
21 if (is.null(width) + is.null(height) == 0) {
22 message("Both width and height were defined. Use width only by default. ")
23 height <- NULL
24 }
25
26 temp_png <- tempfile(fileext = ".png")
27 temp_img <- save_kable(x = x, file = temp_png, ...)
28
29 img_dpi <- 300
30
31 if (is.null(width) + is.null(height) <= 1 & is.null(attr(temp_img, "info"))) {
32 warning("You need to install magick in order to use width/height in ",
33 "as_image. ")
34 } else {
35 if (!is.null(width)) {
36 img_dpi <- attr(temp_img, "info")$width / width
37 }
38 if (!is.null(height)) {
39 img_dpi <- attr(temp_img, "info")$height / height
40 }
41 }
42
43 include_graphics(temp_png, dpi = img_dpi)
Hao Zhuf1873a42019-01-07 15:57:01 -050044}
45
46