Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imazen/imageflow-node
An Image manipulation Library for Nodejs. Based on https://github.com/imazen/imageflow
https://github.com/imazen/imageflow-node
image-processing imageflow linux macos napi nodejs rust server windows
Last synced: 2 months ago
JSON representation
An Image manipulation Library for Nodejs. Based on https://github.com/imazen/imageflow
- Host: GitHub
- URL: https://github.com/imazen/imageflow-node
- Owner: imazen
- License: agpl-3.0
- Created: 2020-04-29T16:04:33.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2023-01-20T22:40:28.000Z (about 2 years ago)
- Last Synced: 2024-10-03T16:03:58.069Z (4 months ago)
- Topics: image-processing, imageflow, linux, macos, napi, nodejs, rust, server, windows
- Language: TypeScript
- Homepage: https://imazen.github.io/imageflow-node
- Size: 2.44 MB
- Stars: 88
- Watchers: 4
- Forks: 4
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Node bindings for [Imageflow](https://github.com/imazen/imageflow)
[![Macos](https://github.com/imazen/imageflow-node/workflows/Test%20Macos/badge.svg)](https://github.com/imazen/imageflow-node/actions?query=workflow%3A%22Test+Macos%22) [![Linux](https://github.com/imazen/imageflow-node/workflows/Test%20Linux/badge.svg)](https://github.com/imazen/imageflow-node/actions?query=workflow%3A%22Test+Linux%22) [![Windows](https://github.com/imazen/imageflow-node/workflows/Test%20Windows/badge.svg)](https://github.com/imazen/imageflow-node/actions?query=workflow%3A%22Test+Windows%22)
Quickly scale or modify images and optimize them for the web.
If the AGPLv3 does not work for you, you can get a [commercial license](https://imageresizing.net/pricing) on a sliding scale. If you have more than 1 server doing image processing your savings should cover the cost.
[API docs are here](https://imazen.github.io/imageflow-node/).
## Installation
```bash
npm install @imazen/imageflow
```## Usage
```js
const {
MozJPEG,
Steps,
FromURL,
FromFile,
FromStream,
FromBuffer,
} = require('@imazen/imageflow')
const fs = require('fs')let step = new Steps(new FromURL('https://jpeg.org/images/jpeg2000-home.jpg'))
.constrainWithin(500, 500)
.branch((step) =>
step
.constrainWithin(400, 400)
.branch((step) =>
step
.constrainWithin(200, 200)
.rotate90()
.colorFilterGrayscaleFlat()
.encode(new FromFile('./branch_2.jpg'), new MozJPEG(80))
)
.copyRectangle(
(canvas) =>
canvas.decode(
new FromStream(fs.createReadStream('./test.jpg'))
),
{ x: 0, y: 0, w: 100, h: 100 },
10,
10
)
.encode(new FromFile('./branch.jpg'), new MozJPEG(80))
)
.constrainWithin(100, 100)
.rotate180()
step.encode(new FromBuffer(null, 'key'), new MozJPEG(80))
.execute()
.then(console.log)
.catch(console.log)
```### Examples
1. Reading a file from disk. `FromFile` provide an easy method for reading and writing images to disk.
```js
const { MozJPEG, Steps, FromFile } = require('@imazen/imageflow')const output = await new Step(new FromFile('path/to/file'))
.rotate180()
.encode(new FromFile('./path/to/output/file'))
.execute()
```2. Reading from a stream. `FromStream` can read and write to a stream.
```js
const { MozJPEG, Steps, FromStream } = require('@imazen/imageflow')const output = await new Step(new FromStream(req))
.constrainWithin(400, 400)
.encode(new FromStream(res))
.execute()
res.end()
```3. Reading from a url. `FromURL` can make a GET request to download and POST request to upload the image.
```js
const { MozJPEG, Steps, FromURL } = require('@imazen/imageflow')const output = await new Step(new FromURL('url to image'))
.colorFilterGrayscaleFlat()
.encode(new FromURL('url to image upload'))
.execute()
```4. Providing buffer. `FromBuffer` can read and provide the output buffer. To read the output a key should be provided, which used later to access buffer in the output.
```js
const { MozJPEG, Steps, FromBuffer } = require('@imazen/imageflow')const output = await new Step(new FromBuffer(getSomeBuffer()))
.colorFilterGrayscaleFlat()
.encode(new FromBuffer(null, 'key'))
.execute()
console.log(output.key)
```5. Performing Batch operations. `branch`, `decode`, and `encode` are used together to perform batch operation. This example shows how to create varying size images from a single image.
```js
const { MozJPEG, Steps, FromStream, FromFile } = require('@imazen/imageflow')const test = new Steps(new FromStream(req))
.constrainWithin(800, 800)
.branch((step) => step.encode(new FromFile('large.jpg'), new MozJPEG()))
.branch((step) =>
step
.constrainWithin(400, 400)
.branch((step) =>
step
.constrainWithin(200, 200)
.branch((step) =>
step
.constrainWithin(100, 100)
.encode(new FromFile('tiny.jpg'), new MozJPEG())
)
.encode(new FromFile('small.jpg'), new MozJPEG())
)
.encode(new FromFile('medium.jpg'), new MozJPEG())
)
.execute()
```6. Example with complex graph of operations
```js
const {
MozJPEG,
Steps,
FromURL,
FromFile,
FromStream,
FromBuffer,
} = require('@imazen/imageflow')
const fs = require('fs')let step = new Steps(new FromURL('https://jpeg.org/images/jpeg2000-home.jpg'))
.constraintWithin(500, 500)
.branch((step) =>
step
.constraintWithin(400, 400)
.branch((step) =>
step
.constraintWithin(200, 200)
.rotate90()
.colorFilterGrayscaleFlat()
.encode(new FromFile('./branch_2.jpg'), new MozJPEG(80))
)
.copyRectangle(
(canvas) =>
canvas.decode(
new FromStream(fs.createReadStream('./test.jpg'))
),
{ x: 0, y: 0, w: 100, h: 100 },
10,
10
)
.encode(new FromFile('./branch.jpg'), new MozJPEG(80))
)
.constraintWithin(100, 100)
.rotate180()
step.encode(new FromBuffer(null, 'key'), new MozJPEG(80))
.execute()
.then(console.log)
.catch(console.log)
```7. Using query style commands
```js
await new Steps().executeCommand(
'width=100&height=100&mode=max',
new FromBuffer(str),
new FromBuffer(null, 'key')
)
```8. Using Decode Options
```js
const output = await new Step(
new FromBuffer(getSomeBuffer()),
new DecodeOptions()
.ignoreColorProfileError()
.setJPEGDownscaleHint(100, 100)
.setWebpDecoderHints(100, 100)
.discardColorProfile()
)
.colorFilterGrayscaleFlat()
.encode(new FromBuffer(null, 'key'))
.execute()
console.log(output.key)
```## Local Setup
```bash
git clone https://github.com/imazen/imageflow-node
cd imageflow-node
yarn
yarn test
```