4 releases (breaking)

0.4.0 Oct 23, 2024
0.3.0 Oct 21, 2024
0.2.0 Oct 19, 2024
0.1.0 Jul 24, 2021

#58 in Visualization

MIT/Apache

47KB
1.5K SLoC

splot

Plot data to HTML / SVG

  • Simple but powerful API
  • Styling using CSS
  • Usable in WebAssembly

Line Plot

use splot::{Chart, Domain, Edge, Page, Plot};

let data = vec![(13, 74), (111, 37), (125, 52), (190, 66)];
let page = Page::new().chart(
    Chart::new()
        .title("Line Plot")
        .domain(Domain::from(&data[..]).set_x(&[0.0, 200.0]))
        .axis("X Axis", Edge::Bottom)
        .axis("Y Axis", Edge::Right)
        .plot(Plot::line("Series", &data)),
);
println!("{page}");

Scatter Plot

use splot::{Chart, Edge, Page, Plot};

let data_a = vec![(13, 74), (111, 37), (125, 52), (190, 66)];
let data_b = vec![(22, 50), (105, 44), (120, 67), (180, 39)];
let page = Page::new().chart(
    Chart::new()
        .title("Scatter Plot")
        .domain(&data_a[..])
        .axis("X Axis", Edge::Bottom)
        .axis("Y Axis", Edge::Left)
        .axis("", Edge::Right)
        .plot(Plot::scatter("Series A", &data_a).label())
        .plot(Plot::scatter("Series B", &data_b)),
);
print!("{page}");

No runtime deps