rect-cover (demo)
Computes a transform between two rectangles the same way as
background-size: cover.
Simulating background-size: cover is very useful for canvas animations, drawing sprites in games, and rendering videos. This module is used as part of our video rendering pipeline at Automagical.
npm install --save rect-coverCheck out the demo to understand what this module does.
const rectCover = require('rect-cover')
const {
scale,
translate
} = rectCover({ width: 500, height: 500 }, { width: 1280, height: 720 })
// CSS transforms apply the rightmost operation first.
// Note that this assumes a transform-origin of `top left`.
const transform = `translate(${translate.x}px, ${translate.y}px) scale(${scale})`Returns a 2D affine transform defined by { scale: Number, translate: { x: Number, y: Number } } such that the given image will fully cover the viewport while maintaining its original aspect ratio.
Note that you'll want to apply the scale transform first followed by the translate.
Type: { width: Number, height: Number }
The viewport you want to draw the image into.
Type: { width: Number, height: Number }
The dimensions of the image to be drawn.
- rect-contain is this module's sister, implementing
background-size: contain. - rect-crop if you need to mimic rect-cover with a
zoomratio andcenterpoint (eg, for kenburns effects) - css background-size
MIT © Travis Fischer
Support my OSS work by following me on twitter