Skip to content

Latest commit

 

History

History
108 lines (89 loc) · 2.95 KB

README.md

File metadata and controls

108 lines (89 loc) · 2.95 KB

uPlot

R htmlwidget for µPlot JavaScript library. μPlot is a fast, memory-efficient Canvas 2D-based chart for plotting time series, lines, areas, ohlc & bars.

Lifecycle: experimental R-CMD-check

Installation

You can install the development version of uPlot from GitHub with:

# install.packages("remotes")
remotes::install_github("dreamRs/uPlot-r")

Example

Here's a time series in half-hourly steps over 11 years, representing a total of 1,710,612 points (9 series of 190,068).

library(uPlot)
uPlot(
  data = eco2mix[, c(1, 3:11)],
  options = list(
    title = "Electricity production by sources in France (2012 - 2022)"
  )
) %>% 
  uColors(
    "bioenergies" = "#156956",
    "fuel" = "#80549f",
    "coal" = "#a68832",
    "solar" = "#d66b0d",
    "gas" = "#f20809",
    "wind" = "#72cbb7",
    "hydraulic" = "#2672b0",
    "nuclear" = "#e4a701",
    "pumping" = "#0e4269"
  )

uPlot example

Area ranges examples :

uPlot(
  data = temperatures,
  options = list(
    title = "Temperatures in 2022 with range from 2018 to 2021",
    axes = list(
      list(),
      list(
        label = "Temperature in degree celsius",
        values = htmlwidgets::JS("function(u, vals) {return vals.map(v => v + '°C');}")
      )
    )
  )
) %>% 
  uBands("low", "high", fill = "#8485854D") %>% 
  uSeries("temperature", label = "Temperature (°C)", stroke = "red", width = 2) %>% 
  uSeries("low", label = "Low", stroke = "#848585", dash = c(8, 2)) %>% 
  uSeries("high", label = "High", stroke = "#848585", dash = c(8, 2)) %>% 
  uSeries("average", label = "Average", show = FALSE, stroke = "#111")

temperature 1 example

uPlot(
  data = temperatures[, c(1, 2, 5)],
  options = list(
    title = "Temperatures in 2022 compared to average from previous years",
    axes = list(
      list(),
      list(
        label = "Temperature in degree celsius",
        values = htmlwidgets::JS("function(u, vals) {return vals.map(v => v + '°C');}")
      )
    )
  )
) %>% 
  uBands("temperature", "average", fill = "#F681804D") %>%
  uBands("average", "temperature", fill = "#2F64FF4D") %>% 
  uSeries(
    name = "temperature",
    label = "Temperature 2022", 
    stroke = "red", 
    width = 2,
    value = htmlwidgets::JS("function(u, v) {return v + '°C';}")
  ) %>% 
  uSeries(
    name = "average",
    label = "Average 2018-2021",
    stroke = "black",
    width = 2,
    value = htmlwidgets::JS("function(u, v) {return v + '°C';}")
  )

temperature 2 example