0.4.0 • Published 8 years ago

image-resizer-middleware v0.4.0

Weekly downloads
2
License
MIT
Repository
github
Last release
8 years ago

Image Resizer

GraphicsMagick powered, multi threaded image resizing middleware.

Installation

npm install --save image-resize-middleware

Usage

const path = require('path')
const express = require('express')
const imageResizer = require('image-resize-middleware')
const port = 3000
const publicDirectory = path.join(__dirname, 'public')

const app = express()

app.use(imageResizer.getMiddleware({
	basePath: path.join(publicDirectory, 'images'),
	thumbnailsPath: path.join(publicDirectory, 'thumbnails'),
}))
app.use(express.static(publicDirectory))

app.listen(
	port,
	() => console.log('Listening on http://localhost:' + port)
)

Every request for an image at /images/<path>/<to>/<image-file> which also contains a width, height, max-width or max-height query parameter will be scaled to the specified value.

For example a request for http://localhost:3000/images/test.png?max-width=50&max-height=50 triggers the creation of a proportionally scaled thumbnail with a maximum bounding box of 50px by 50px. It is saved at $(pwd)/public/thumbnails/test_50x50>.png and responded to the request.

Algorithm

All images to be scaled are added to a queue. The queue is worked off with one worker per core.