🚀 DAY 5 OF LAUNCH WEEK:Introducing Webhook Events for Alert Changes.Learn more →
Socket
Book a DemoInstallSign in
Socket

svg-image-merge

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

svg-image-merge

When you want an image with both a compressed background and a pixel perfect text on top... Merges a JPEG background and a transparent PNG into a single SVG image

latest
npmnpm
Version
0.1.0
Version published
Maintainers
1
Created
Source

SVG Image Merge

A tool for image optimization freaks.

Let's say you want to add an image on your website, that contains both:

  • a photography that could be compressed as a JPEG (using a PNG would make a huge file)
  • some text or logo you want to be pixel perfect (JPEG compression would add some artefacts)

This tool creates an single image, containing both the optimized background and the pixel perfect text.

Of course, this could be done easily in HTML by positioning a transparent <img> over another <img>. Use this tool if you can't do that, if it needs to fit in a single field of a back-office for exemple.

Here is an example result file:

svg example

How it works

It's very simple. It takes two images on your computer, base64 encodes both of them, then creates an SVG. The structure of the SVG is very simple and looks basically like this:

<svg width="800" height="600">
    <image x="0" y="0" width="800" height="600" xlink:href="data:image/jpg;base64,{{base64-encoded-background}}" />
    <image x="0" y="0" width="800" height="600" xlink:href="data:image/png;base64,{{base64-encoded-top}}" />
</svg>

Once it's done, simply serve the new SVG like any other image in your HTML:

<img src="merged-image.svg" />

Don't forget to check that your server is configured to properly gzip SVG images (content type image/svg+xml).

Installation

npm install -g svg-image-merge

Usage

svg-image-merge <background-file> <top-file> <output-file>

Example

svg-image-merge background.jpg wording.png result.svg

Options

None for the moment

Browser compatibility

Sorry my old IE8 friend, you're not able to understand SVG images...

Author

Gaël Métais. I'm a webperf freelance based in Paris. If you understand french, you can visit my website.

Keywords

image

FAQs

Package last updated on 31 Jul 2015

Did you know?

Socket

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.

Install

Related posts