vid2img

Crates.iovid2img
lib.rsvid2img
version0.1.1
sourcesrc
created_at2021-03-13 17:23:02.688436
updated_at2022-04-25 11:11:12.908245
descriptionUse video content as collection of images.
homepage
repositoryhttps://github.com/rafaelcaricio/vid2img
max_upload_size
id368363
size3,712,956
Rafael CarĂ­cio (rafaelcaricio)

documentation

README

vid2img - Video to Image

vid2img is a Rust crate that allows the use of a video file as a collection of frame images. This crate exposes a FileSource type that accepts a video file path and the desired size of the frames, then you can convert the instance into a iterator (.into_iter()). On every iteration you will receive a video frame data encoded as PNG.

use std::path::Path;
use vid2img::FileSource;

fn main() {
    let file_path = Path::new("video.mp4");

    let frame_source = FileSource::new(file_path, (200, 200)).unwrap();
    for frame in frame_source.into_iter() {
        if let Ok(Some(png_img_data)) = frame {
            // do something with the image data here ...
        }
    }
}

We use GStreamer for processing the video and capturing the frames. We make use of the official Rust wrapper to the GStreamer API.

Installation

As we use GStreamer, the installation steps for the GStreamer-rs crate must be followed.

We make use of the following GStreamer plugins: uridecodebin, videoconvert, videoscale, capsfilter, pngenc, appsrc.

Usage

To use this library, add the following dependency to Cargo.toml:

[dependencies]
vid2img = "0.1.0"
Commit count: 9

cargo fmt