View multiple plots in a single view

View multiple plots in a single view

subplot(..., nrows = 1, widths = NULL, heights = NULL, margin = 0.02,
  shareX = FALSE, shareY = FALSE, titleX = shareX, titleY = shareY,
  which_layout = "merge")

One of the following

  • any number of plotly/ggplot2 objects.

  • a list of plotly/ggplot2 objects.

  • a tibble with one list-column of plotly/ggplot2 objects.


number of rows for laying out plots in a grid-like structure. Only used if no domain is already specified.


relative width of each column on a 0-1 scale. By default all columns have an equal relative width.


relative height of each row on a 0-1 scale. By default all rows have an equal relative height.


either a single value or four values (all between 0 and 1). If four values are provided, the first is used as the left margin, the second is used as the right margin, the third is used as the top margin, and the fourth is used as the bottom margin. If a single value is provided, it will be used as all four margins.


should the x-axis be shared amongst the subplots?


should the y-axis be shared amongst the subplots?


should x-axis titles be retained?


should y-axis titles be retained?


adopt the layout of which plot? If the default value of "merge" is used, layout options found later in the sequence of plots will override options found earlier in the sequence. This argument also accepts a numeric vector specifying which plots to consider when merging.


A plotly object

  • subplot
library(plotly) # NOT RUN { # pass any number of plotly objects to subplot() p1 <- plot_ly(economics, x = ~date, y = ~uempmed) p2 <- plot_ly(economics, x = ~date, y = ~unemploy) subplot(p1, p2, p1, p2, nrows = 2, margin = 0.05) # or pass a list library(purrr) economics_long %>% split(.$variable) %>% map(~ plot_ly(., x = ~date, y = ~value)) %>% subplot(nrows = NROW(.), shareX = TRUE) # or pass a tibble with a list-column of plotly objects economics_long %>% group_by(variable) %>% do(p = plot_ly(., x = ~date, y = ~value)) %>% subplot(nrows = NROW(.), shareX = TRUE) # learn more at # }
Documentation reproduced from package plotly, version 4.5.2, License: MIT + file LICENSE

Community examples

Looks like there are no examples yet.