Transparent JPG (With SVG)
Let’s say you have a photographic image that really should be a JPG or WebP, for the best file size and quality. But what if I need transparency too? Don’t I need PNG for that? Won’t that make for either huge file sizes (PNG-24) or weird quality (PNG-8)? Let’s look at another way that ends up best-of-both-worlds.
data:image/s3,"s3://crabby-images/dc114/dc114f2ac2336f07eff9df299fab493bcb830819" alt=""
The goal is to clip myself out of the image, removing the background. My technique for that is usually to use Photoshop and cut a clipping path manually with the Pen tool.
data:image/s3,"s3://crabby-images/4e4b2/4e4b2eb8c2cebcab05820eaed41ad4355e0d995d" alt=""
Now I can select the inverse of that clipping path to easily remove the background.
Attempting to save this as a 1200px wide image as PNG-24 out of Photoshop ends up as about a 1MB image!
data:image/s3,"s3://crabby-images/59a26/59a26f4a987ecd8907219fa5b105cb58f5dd691e" alt=""
We could cut that by 75% using PNG-8, but then we 1) get that weird Giffy look (less photographic) and 2) have to pick a matte color for the edges because we aren’t getting nice alpha transparency here, just binary transparency.
data:image/s3,"s3://crabby-images/6d3b6/6d3b616a63af02e550c073d35efb6a6540a81319" alt=""
Gosh what if we could just use JPG? The quality and file size is way better.
data:image/s3,"s3://crabby-images/a28b9/a28b94fd1d700e0eab9e3aedc230f75d667c72c3" alt=""
No transparency though.
But wait! Can’t we just clip this thing out? We have clip-path now. Well… yeah. We do have clip-path. It can’t take a path()
, though, and what we’ve created for vector points in Photoshop is path data. It could take a polygon()
though, if we made all the lines straight. That’s probably not ideal (I’m curvy!). Or we could make a element in some inline SVG and use
clip-path: url(#id_of_clipPath);
, which does support a inside.
There is masking as well, which is another possibility.
Let’s look at a third possibility though: put everything into . That made some logical sense to me, so all this stays together and scales together.
The trick is to make two things:
- The JPG
- The clipping
The JPG is easy enough. Output that right from Photoshop. Optimize.
Now we can set up the SVG. SVG is happy to take a raster graphic. SVG is known for vector graphics, but it’s a very flexible image format.
<svg>
<image xlink:href="/images/chris.jpg" x="0" y="0">
<svg>
To get the path, we export the path we created with the Pen tool over to Illustrator.
data:image/s3,"s3://crabby-images/6d33c/6d33c39496290325568729267e3440ef7ac6bf32" alt=""
Now we have the path over there, and it’s easy to export as SVG:
data:image/s3,"s3://crabby-images/58ceb/58cebc95f1a7693cbdce1a1b3023fed9b4cfaa8c" alt=""
Now we have the path data we need:
data:image/s3,"s3://crabby-images/c75a9/c75a9c135785eb71ce4a142135f6f8bca4d62929" alt=""
Let’s use that within a
in the SVG we’ve started. Then also apply that clip path to the
:
<svg viewBox="0 0 921.17 1409.71">
<defs>
<clipPath id="chris-clip">
<path d=" ... " />
</clipPath>
</defs>
<image xlink:href="/images/chris.jpg" clip-path="url(#chris-clip)" x="0" y="0">
<svg>
Tada!
A transparent JPG, essentially.
Transparent JPG (With SVG) is a post from CSS-Tricks