Skip to content

Latest commit

 

History

History
65 lines (56 loc) · 4.07 KB

README.md

File metadata and controls

65 lines (56 loc) · 4.07 KB


How do I apply backdrop-filter:blur to a text element?

As far as I know there's no way to directly apply the backdrop-filter:blur to a text element.


First solution: The Slowest One (Broken by Chrome update)

  1. Create a container
  2. Apply a background to it (or to its ::before pseudo-element)
  3. Use the filter:blur so that the container's background is blurred
  4. Apply a svg mask onto the svg element and then apply the same background to the container (or to its ::before pseudo-element)

This way we have the blurried background on top that gets masked and the non-blurry version under it.

NOTE: applying the background to the container's ::before pseudo element will allow you to modify the background without touching the svg mask (usefull if you need to flip the background to create more contrast but you can't modify the original image).


Second solution: The Fastest One

  1. Create a container
  2. Apply a background to it
  3. Create a svg element which will represent our "text"
  4. Apply the backdrop-filter:blur to the svg element
  5. Apply the svg-mask to the svg element

This way we have the effect we would have if the backdrop-filter: blur could be applied to text.
This one is the one which performs the best because it's the only method that doesn't require the svg element to duplicate the background (which would have to be repainted at every frame because of the background-attachment:fixed attribute).

You can test the performances by using the testSmoothness() method in the browser console in combination with the browser profiler.

Third solution: The Most Compatible One (Broken by Chrome update)

(requires to have 2 copies of the background, one of which already blurred)

  1. Create a container
  2. Apply a background to it
  3. Create a svg element which will represent out "text"
  4. Apply the blurry version of the background to the svg element
  5. Apply the svg-mask to the svg element

Great! But the contrast is low...

Let's add a shadow then!

Applying the blur effect alone will give us a low contrast-ratio (hard to read text).
To counter this I applied a shadow to the svg:

  1. Create a svg element in the document
  2. Inside the <defs> tag create a filter with the <filter> tag and give it a unique id
  3. Inside the <filter> tag create a <feGaussianBlur> with a stdDeviation of your choice (4 and 5 are good initial numbers)
  4. Still inside the <filter> tag, create a <feComposite> with the out operator and in2 set to SourceGraphics
  5. To shape our shadow we'll use an <image> outside of the <defs> tag
  6. Set the url of the <image>'s filter attribute to the same id you gave to the <filter> tag (see point 2 above)
  7. Set the xlink:href attribute's value to the same one of your svg's path

This is the reference code:

<svg>
  <defs>
    <filter id = "trans-shadow">
      <feGaussianBlur stdDeviation = "5"/>
      <feComposite operator = "out" in2 = "SourceGraphic"/>
    </filter>
  </defs>
  <image filter = "url(#trans-shadow)" x = "0" y = "0" width = "100%" height = "100%" xlink:href = "./SVG.svg" />
</svg>

If the text still isn't easy to read remember that with the Method 2 you can still set an rgba(255,255,255,0.xyz) background-color and that with the all the 3 methods you can add a saturation to the filter/backdrop-filter!

WE'RE DONE! Now our backdropped text looks cool and it's easy to read!

Here you have a live demo: DEMO