Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kevingodell/pipe2pam
Parse individual pam images from an ffmpeg pipe when output video codec(-c:v) is set to pam and format(-f) is set to image2pipe. Pam is an image type similar to ppm, pbm, and pgm. It has a small header that is followed by an uncompressed array of pixel data.
https://github.com/kevingodell/pipe2pam
ffmpeg image2pipe nodejs pam
Last synced: 4 months ago
JSON representation
Parse individual pam images from an ffmpeg pipe when output video codec(-c:v) is set to pam and format(-f) is set to image2pipe. Pam is an image type similar to ppm, pbm, and pgm. It has a small header that is followed by an uncompressed array of pixel data.
- Host: GitHub
- URL: https://github.com/kevingodell/pipe2pam
- Owner: kevinGodell
- License: mit
- Created: 2017-03-20T23:23:01.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-08-09T01:36:05.000Z (over 1 year ago)
- Last Synced: 2024-09-19T17:36:39.018Z (5 months ago)
- Topics: ffmpeg, image2pipe, nodejs, pam
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/pipe2pam
- Size: 212 KB
- Stars: 5
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# pipe2pam
###### [![Buy me a coffee](https://img.shields.io/badge/-buy%20me%20a%20coffee-red?logo=buy%20me%20a%20coffee)](https://buymeacoffee.com/kevinGodell) [![Donate via PayPal](https://img.shields.io/badge/Donate-Paypal-blue)](https://www.paypal.com/donate/?business=HTMERJAFHJJEU&no_recurring=0&item_name=support+open+source+software+development¤cy_code=USD) [![build](https://github.com/kevinGodell/pipe2pam/actions/workflows/node.js.yml/badge.svg)](https://github.com/kevinGodell/pipe2pam/actions/workflows/node.js.yml) [![Build status](https://ci.appveyor.com/api/projects/status/v29p3vhykt756hvc/branch/master?svg=true)](https://ci.appveyor.com/project/kevinGodell/pipe2pam/branch/master) [![GitHub issues](https://img.shields.io/github/issues/kevinGodell/pipe2pam.svg)](https://github.com/kevinGodell/pipe2pam/issues) [![GitHub license](https://img.shields.io/badge/license-MIT-blue.svg)](https://raw.githubusercontent.com/kevinGodell/pipe2pam/master/LICENSE) [![npm](https://img.shields.io/npm/dt/pipe2pam.svg?style=flat-square)](https://www.npmjs.com/package/pipe2pam)
Parse individual pam images from an ffmpeg pipe when the output video codec (*-c:v*) is set to **pam** and the format (*-f*) is set to **image2pipe**. The supported pixel formats (*-pix_fmt*) are **rgb24**, **rgba**, **gray**, and **monob**. Pam is an image type similar to ppm, pbm, and pgm. It has a small header that is followed by an uncompressed array of pixel data. This can be used as an alternate way to get pixel data instead of generating jpegs and using canvas. It is currently being used for a video motion detection project.
### installation:
```
npm install pipe2pam --save
```
### usage:
The following [example](https://github.com/kevinGodell/pipe2pam/blob/master/examples/example.js) uses ffmpeg's **testsrc** to simulate a video input and generates 100 downscaled grayscale pam images at a rate of 1 per second. The pam images are piped in from ffmpeg's stdout and output a pam image object. Pipe2Pam dispatches a "data" event, which contains a pam image object. The object contains the entire pam image, plus additional data such as width, height, depth, maxval, tupltype, and an array of pixels. It can also pipe the object to a [pipe reader](https://github.com/kevinGodell/pam-diff) for further use, such as pixel comparison between 2 pam images:
```javascript
const Pipe2Pam = require('pipe2pam');const { spawn } = require('child_process');
let counter = 0;
const params = [
'-loglevel',
'quiet',
'-re',
'-f',
'lavfi',
'-i',
'testsrc=size=1920x1080:rate=15',
'-an',
'-c:v',
'pam',
'-f',
'image2pipe',
'-pix_fmt',
//'rgb24',
//'rgba',
'gray',
//'monob',
'-vf',
'fps=1,scale=iw*1/6:ih*1/6',
'-frames',
'100',
'pipe:1'
];const pipe2pam = new Pipe2Pam();
pipe2pam.on('data', (data) => {
console.log(data);
console.log('received pam', ++counter);
});const ffmpeg = spawn('ffmpeg', params);
ffmpeg.on('error', (error) => {
console.log(error);
});ffmpeg.on('exit', (code, signal) => {
console.log('exit', code, signal);
});ffmpeg.stdout.pipe(pipe2pam);
```
### testing:
Clone the repository
```
git clone https://github.com/kevinGodell/pipe2pam.git
```
Change into the directory
```
cd pipe2pam
```
Initialize with npm
```
npm install
```
Start the tests
```
npm test
```