
Security News
AGENTS.md Gains Traction as an Open Format for AI Coding Agents
AGENTS.md is a fast-growing open format giving AI coding agents a shared, predictable way to understand project setup, style, and workflows.
svg-inplace-rasterize
Advanced tools
Rasterize parts of an SVG to keep it animatable while reducing size and improving render time.
Rasterize parts of an SVG to keep it animatable while reducing size and improving render time.
npm i svg-inplace-rasterize # add -g to make cli available
svg-inplace-rasterize --input test/files/wiki-example.svg --output tmp/out.svg -m 3 --format webp
const { InplaceRasterizer } = require('svg-inplace-rasterize');
const rasterizer = new InplaceRasterizer();
const stream = fs.createReadStream('file.svg');
const svg = await rasterizer.rasterize(stream, {
multiplier: 3,
filter: $ => $('g'), // Cheerio object
format: 'webp'
});
fs.writeFile('out.svg', svg);
This library takes some elements in a SVG file, rasterizes them using LibRsvg, and replaces the original elements with <image>
tags with data uris.
It uses Sharp to create WebP images from the PNG output of LibRsvg.
You can select which elements to rasterize by using the filter option. This library uses Cheerio, which has the same API as jQuery.
The CLI uses this function by default, which selects all elements with an id that have no children with ids:
function($) {
const x = $('*[id]:not([id$="!"])').toArray();
return x.filter(el => !$(el).children('*[id]:not([id$="!"])').length);
}
librsvg
If librsvg
has to be built from scratch, libffi must be installed on your system, and in your PKG_CONFIG_PATH
.
export PKG_CONFIG_PATH="/usr/local/Cellar/libffi/3.2.1/lib/pkgconfig:${PKG_CONFIG_PATH}"
transform
s on elements that are rasterized, nor on their parents.transform
(very common on Inkscape files)Applies to leaf-with-id
and leaf-with-id-illustrator
:
@
: do not rasterize&
: force rasterize!
: act as if no idFAQs
Rasterize parts of an SVG to keep it animatable while reducing size and improving render time.
The npm package svg-inplace-rasterize receives a total of 1 weekly downloads. As such, svg-inplace-rasterize popularity was classified as not popular.
We found that svg-inplace-rasterize demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
AGENTS.md is a fast-growing open format giving AI coding agents a shared, predictable way to understand project setup, style, and workflows.
Security News
/Research
Malicious npm package impersonates Nodemailer and drains wallets by hijacking crypto transactions across multiple blockchains.
Security News
This episode explores the hard problem of reachability analysis, from static analysis limits to handling dynamic languages and massive dependency trees.