R Markdown: How do I make text float around figures?

后端 未结 3 2073
刺人心
刺人心 2020-12-16 05:59

I made a flowchart with R which I included in my R Markdown file.

How it looks like right now:

The code:

```{r flowchart-data, echo = FALSE,         


        
相关标签:
3条回答
  • 2020-12-16 06:03

    As far as I know you can embed HTML code within a markdown document, so if you're knitting to HTML, you can do something like this:

    Wrap the cell with a div tag with the style of alignment you want (no need to align the cell anymore), and as for the caption you can add a transparent box at the bottom with the caption as the text inside

    <div style="float:right">
    ```{r flowchart-data, echo = FALSE, message = FALSE, fig.width = 7, fig.height = 6}
    library(grid)
    library(Gmisc)
    
    grid.newpage()
    # set some parameters to use repeatedly
    leftx <- .2
    midx <- .5
    rightx <- .8
    
    myBoxGrob <- function(text, ...) {
      boxGrob(label = text, bjust = "top", box_gp = gpar(fill = "lightgrey"), ...)
    }
    
    # create boxes
    
    (Pharmazie <- myBoxGrob("Verbrauchsdaten von der\n Spitalpharmazie  (Excel-Tabelle)", x=leftx, y=1, width = 0.36))
    (Finanzen <- myBoxGrob("Belegzahlen vom Ressort\n Finanzen (Excel-Tabelle)", x=rightx, y=1, width = 0.36))
    (A <- myBoxGrob("Import der Daten aus Excel ins\n Microsoft Access (Datenbanksoftware)", x=midx, y=0.83, width = 0.45))
    (B <- myBoxGrob("Zusammenführen der Informationen\n und erstellen neuer, berechneter Tabellen", x=midx, y=.66, width = 0.45))
    (C <- myBoxGrob("Export der neu erstellten Tabellen\n in Form von Excel-Tabellen", x=midx, y=.49, width = 0.45))
    (D <- myBoxGrob("Import der neuen Tabellen in R", x=midx, y=.32,  width = 0.45))
    (E <- myBoxGrob("Berechnung und grafische Darstellung\n der Grafiken und Tabellen", x=midx, y=.19, width = 0.45))
    (caption <- boxGrob(label = 'Ablauf der Datenverarbeitung',  x=midx, y=.02, box_gp = gpar(alpha=0)))
    
    connectGrob(Pharmazie, A, "L")
    connectGrob(Finanzen, A, "L")
    connectGrob(A, B, "N")
    connectGrob(B, C, "N")
    connectGrob(C, D, "N")
    connectGrob(D, E, "N")
    
    ```
    </div>
    And this is the text that would go to the left of the chart.
    
    0 讨论(0)
  • 2020-12-16 06:21

    I struggled a lot with this as well, but for html-output. There is an argument to the r chunk that solved the problem for me:

    out.extra='style="float:right; padding:10px"'

    0 讨论(0)
  • 2020-12-16 06:22

    There is a chunk option called fig.env with which one can switch from the figure to the marginfigure environment. Unfortunetly, the list of possible environments does not include wrapfigure. Therefore we will alter the plot chunk:

    defOut <- knitr::knit_hooks$get("plot")  # save the default plot hook 
    knitr::knit_hooks$set(plot = function(x, options) {  # set new plot hook ...
      x <- defOut(x, options)  # first apply the default hook
      if(!is.null(options$wrapfigure)) {  # then, if option wrapfigure is given ...
        # create the new opening string for the wrapfigure environment ...
        wf <- sprintf("\\begin{wrapfigure}{%s}{%g\\textwidth}", options$wrapfigure[[1]], options$wrapfigure[[2]])
        x  <- gsub("\\begin{figure}", wf, x, fixed = T)  # and replace the default one with it.
        x  <- gsub("{figure}", "{wrapfigure}", x, fixed = T)  # also replace the environment ending
      }
      return(x)
    })
    

    The comments should clarify what we are actually doing here. Notice, that the expected value of wrapfigure is a list of two elements. The first one tells LaTeX to move the figure to either side of the page. The second element tells LaTeX the width of the wrapped figure. To move a figure with a width of 0.7\\textwidth to the right you set wrapfigure = list("R", 0.7) (as you might have guessed, L moves it to the left). All we have to do now is to include the wrapfig package in the YAML and set this chunk option. Here is a reproducible example:

    ---
    header-includes:
      - \usepackage{wrapfig}
      - \usepackage{lipsum}
    output: 
      pdf_document:
        keep_tex: true
    ---
    
    ```{r, include = F}
    defOut <- knitr::knit_hooks$get("plot")  # save the default plot hook 
    knitr::knit_hooks$set(plot = function(x, options) {  # set new plot hook ...
      x <- defOut(x, options)  # first apply the default hook
      if(!is.null(options$wrapfigure)) {  # then, if option wrapfigure is given ...
        # create the new opening string for the wrapfigure environment ...
        wf <- sprintf("\\begin{wrapfigure}{%s}{%g\\textwidth}", options$wrapfigure[[1]], options$wrapfigure[[2]])
        x  <- gsub("\\begin{figure}", wf, x, fixed = T)  # and replace the default one with it.
        x  <- gsub("{figure}", "{wrapfigure}", x, fixed = T)  # also replace the environment ending
      }
      return(x)
    })
    ```
    
    
    Vivamus vehicula leo a justo. Quisque nec augue. Morbi mauris wisi, aliquet vitae, dignissim eget, sollicitudin molestie, ligula. In dictum enim sit amet risus. Curabitur vitae velit eu diam rhoncus hendrerit. Vivamus ut elit. Praesent mattis ipsum quis turpis. Curabitur rhoncus neque eu dui. Etiam vitae magna. Nam ullamcorper. Praesent interdum bibendum magna. Quisque auctor aliquam dolor. Morbi eu lorem et est porttitor fermentum. Nunc egestas arcu at tortor varius viverra. Fusce eu nulla ut nulla interdum consectetuer. Vestibulum gravida. 
    
    ```{r echo = F, warning = F, message = F, fig.width=7, fig.height = 6, out.width = ".7\\textwidth", fig.cap = "My Flowchart", fig.align="right", wrapfigure = list("R", .7)}
    plot(mpg ~ hp, data = mtcars)
    ```
    
    Morbi mattis libero sed est. Vivamus vehicula leo a justo. Quisque nec augue. Morbi mauris wisi, aliquet vitae, dignissim eget, sollicitudin molestie, ligula. In dictum enim sit amet risus. Curabitur vitae velit eu diam rhoncus hendrerit. Vivamus ut elit. Praesent mattis ipsum quis turpis. Curabitur rhoncus neque eu dui. Etiam vitae magna. Nam ullamcorper. Praesent interdum bibendum magna. Quisque auctor aliquam dolor. Morbi eu lorem et est porttitor fermentum. Nunc egestas arcu at tortor varius viverra. Fusce eu nulla ut nulla interdum consectetuer. Vestibulum gravida. Morbi mattis libero sed est.
    

    Notice, that this solution most probably only works with a chunk creating a single plot. It should be possible to extent that to a chunk containing several figures.

    0 讨论(0)
提交回复
热议问题