Learn R Programming

⚠️There's a newer version (4.12.0) of this package.Take me there.

plotly

An R package for creating interactive web graphics via plotly.js.

Installation

Install from CRAN:

install.packages("plotly")

Or install the latest development version (on GitHub) via devtools:

devtools::install_github("ropensci/plotly")

Getting Started

Web-based ggplot2 graphics

If you use ggplot2, ggplotly() converts your plots to an interactive, web-based version! It also provides sensible tooltips, which assists decoding of values encoded as visual properties in the plot.

library(plotly)
g <- ggplot(faithful, aes(x = eruptions, y = waiting)) +
  stat_density_2d(aes(fill = ..level..), geom = "polygon") + 
  xlim(1, 6) + ylim(40, 100)
ggplotly(g)

If you'd like to see how ggplotly() does in converting different ggplot2 examples, we host a plotly version of the official ggplot2 documentation. We also have some of our own examples here.

plotly's custom R interface

plotly supports some chart types that ggplot2 doesn't (such as 3D surface, point, and line plots). You can create these (or any other plotly) charts using plot_ly().

plot_ly(z = volcano, type = "surface")

For a more concise overview of the plot_ly() interface, see here. You might also find our examples and the figure reference to be helpful.

Hooking onto plotly events

plotly.js exposes a number of 'standard' events that work consistently across plot types. It's easy to hook into these events using the event_data() function in shiny apps, as these examples demonstrate:

  1. 2D events (source)
  2. Linked Clicks (source)
  3. Linked Brush (source)

You can also hook into these events without shiny using htmlwidgets::onRender() (example). This, however, requires JavaScript knowledge and makes it much harder, if not impossible, to coordinate views between htmlwidgets.

Contributing

Please read through our contributing guidelines. Included are directions for opening issues, asking questions, contributing changes to plotly, and our code of conduct.


Copy Link

Version

Install

install.packages('plotly')

Monthly Downloads

308,314

Version

3.5.5

License

MIT + file LICENSE

Issues

Pull Requests

Stars

Forks

Maintainer

Carson Sievert

Last Published

January 24th, 2026

Functions in plotly (3.5.5)

get_plot

Obtain underlying data of plotly object
geom2trace

Convert a "basic" geoms to a plotly.js trace.
bbox

Estimate bounding box of a rotated string
as.widget

Convert a plotly object to an htmlwidget object
add_trace

Add a trace to a plotly visualization
config

Set the default configuration for plotly
gg2list

Convert a ggplot to a list.
embed_notebook

Embed a plotly figure as an iframe into a IPython Notebook
get_figure

Request a figure object
event_data

Access plotly user input event data in shiny
ggplotly

Create plotly graphs using ggplot2 syntax
print.plotly_hash

Print a plotly object
hobbs

Hobbs data
print.plotly_built

Print a 'built' plotly object
plotly_IMAGE

Create/Modify plotly images
plotly

Main interface to plotly
offline

Plotly Offline
%>%

Pipe operator
knit_print.plotly_hash

Print a plotly object in a knitr doc
plotly_POST

Create/Modify plotly graphs
last_plot

Retrive and create the last plotly (or ggplot).
plotly_build

Build a plotly object before viewing it
mic

Mic data
layout

Add and/or modify layout of a plotly
signup

Create a new plotly account.
style

Modify trace(s)
print.figure

Print a plotly figure object
plotly_empty

Create a complete empty plotly graph.
knit_print.figure

Embed a plotly figure as an iframe in a knitr doc
plot_ly

Initiate a plotly visualization
knit_print.plotly_built

Print a 'built' plotly object in a knitr doc
to_basic

Convert a geom to a "basic" geom.
wind

Wind data
subplot

View multiple plots in a single view
plotly-shiny

Shiny bindings for plotly
toRGB

Convert R colours to RGBA hexadecimal colour values