This content originally appeared on CSS-Tricks and was authored by Chris Coyier
Ahmad Shadeed dug into shape “cutouts” the other day. Imagine a shape with another smaller shape carved out of it. In his typical comprehensive way, Ahmad laid out the situation well—looking at tricky situations that complicate things.
data:image/s3,"s3://crabby-images/124b7/124b7483712bad3faadfe884bfa0ef0c6e6579cd" alt=""
The first thing I’d think of is CSS’ clip-path
, since it has that circle()
syntax that seems like it a good fit, but no!, we need the opposite of what clip-path: circle()
does, as we aren’t drawing a circle to be the clipping path here, but drawing all the way around the shape and then up into that second smaller circle and back out, like a bite out of a cookie. That puts us in clip-path: path()
territory, which mercifully exists, and yet!, doesn’t quite get there because the path()
syntax in CSS only works with fixed-pixel units which is often too limiting in fluid width layouts.
So that puts us at clip-path: url("#my-path");
(referencing an <svg>
path), which is exactly where Ahmad starts this journey. But then he explores other options like a clever use of mask-image
and a direct use of SVG <mask>
and <image>
, which turns out to be the winner.
Ideas like this have a weird way of entering the collective front-end developer consciousness somehow. Jay wrote up a very similar journey of wanting to do a shape cutout. Again, the problem:
Jay Freestone, “Cutouts with CSS Masks”
clip-path
defines a visible region, meaning that if you want all but a tiny chunk of the button to be visible, you need to define apath
orpolygon
which is the inverse of the original. Here’s a demo of what I mean, using Clippy:
In this case, polygon()
has potential because it supports %
units for flexibility (also, don’t miss Ana’s idea where the unit types are mixed within the polygon for a some-fixed-some-fluid concept).
data:image/s3,"s3://crabby-images/39306/393068ff870955407f089ed095bafbaacb2339b7" alt=""
Jay’s conclusion is that SVG has the most benefits of all the options:
[…] my overall impression is that
mask-composite
remains the more flexible solution, since it becomes trivial to use any SVG shape as the mask, not just a triangle or a simple polygon. The likelihood is that you’ll want to simply export an SVG and drop it in. Engineering the inverse result asclip-path
is likely to get pretty hairy quickly.
An Initial Implementation of clip-path: path();
Let’s Create an Image Pop-Out Effect With SVG Clip Path
Clipping, Clipping, and More Clipping!
Using CSS Clip Path to Create Interactive Effects, Part II
Clipping and Masking in CSS
mask
.element { mask: url(mask.png) right bottom / 100px repeat-y; }
Direct Link to Article — Permalink
The post Cutouts appeared first on CSS-Tricks. You can support CSS-Tricks by being an MVP Supporter.
This content originally appeared on CSS-Tricks and was authored by Chris Coyier
data:image/s3,"s3://crabby-images/02712/02712ed05be9b9b1bd4a40eaf998d4769e8409c0" alt=""
Chris Coyier | Sciencx (2021-08-16T20:49:09+00:00) Cutouts. Retrieved from https://www.scien.cx/2021/08/16/cutouts/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.