12 unstable releases (5 breaking)

Uses old Rust 2015

0.5.0 Apr 8, 2018
0.4.0 Jan 4, 2018
0.3.2 Jul 16, 2017
0.3.0 Jun 25, 2017
0.0.2 Jun 21, 2017

#503 in Operating systems

Download history 311/week @ 2024-12-17 183/week @ 2024-12-24 231/week @ 2024-12-31 303/week @ 2025-01-07 497/week @ 2025-01-14 354/week @ 2025-01-21 271/week @ 2025-01-28 475/week @ 2025-02-04 431/week @ 2025-02-11 319/week @ 2025-02-18 422/week @ 2025-02-25 348/week @ 2025-03-04 583/week @ 2025-03-11 405/week @ 2025-03-18 481/week @ 2025-03-25 244/week @ 2025-04-01

1,736 downloads per month
Used in 19 crates (14 directly)

MIT license

50KB
1.5K SLoC

scrap

Scrap records your screen! At least it does if you're on Windows, macOS, or Linux.

Usage

[dependencies]
scrap = "0.5"

Its API is as simple as it gets!

struct Display; /// A screen.
struct Frame; /// An array of the pixels that were on-screen.
struct Capturer; /// A recording instance.

impl Capturer {
    /// Begin recording.
    pub fn new(display: Display) -> io::Result<Capturer>;

    /// Try to get a frame.
    /// Returns WouldBlock if it's not ready yet.
    pub fn frame<'a>(&'a mut self) -> io::Result<Frame<'a>>;

    pub fn width(&self) -> usize;
    pub fn height(&self) -> usize;
}

impl Display {
    /// The primary screen.
    pub fn primary() -> io::Result<Display>;

    /// All the screens.
    pub fn all() -> io::Result<Vec<Display>>;

    pub fn width(&self) -> usize;
    pub fn height(&self) -> usize;
}

impl<'a> ops::Deref for Frame<'a> {
    /// A frame is just an array of bytes.
    type Target = [u8];
}

The Frame Format

  • The frame format is guaranteed to be packed BGRA.
  • The width and height are guaranteed to remain constant.
  • The stride might be greater than the width, and it may also vary between frames.

System Requirements

OS Minimum Requirements
macOS macOS 10.8
Linux XCB + SHM + RandR
Windows DirectX 11.1

Dependencies

~135KB