Less noise texture mixin

If you’d like to add a little bit of texture to your designs adding a subtle amount of noise can work wonders. By using a repeated monochrome noise png as a background image you can add noise to any element no matter what colour by using opacity to blend it in.

The mixin below uses a base64 encoded version in the stylesheet which means you don’t have to worry about including the file on your server, the one trade-off to consider is that the base64 encoded image data weighs in at 2kb and the binary .png version is 1.5kb. I personally prefer the cleanliness of having the mixin self-contained, but each to their own.

The Mixin

We use a parametric mixin which has a sensible default opacity which you can change to suit your design and overridden when you need.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/**
 * Adds a transparent noise texture as a background image to a given element.
 * Texture strength can be controlled with @opacity parameter.
 * By Paul Stanton (www.coffeepowered.co.uk)
 */

.noise(@opacity: .3) {
  &:before {
  bottom:0;
  content:"";
  left:0;
  opacity:@opacity;
  position:absolute;
  right:0;
  top:0;

  background-image:url();
  }
}

### Usage

To apply noise to your element, just invoke the mixin!

1
2
3
4
.my-element{
  position:relative;
  .noise();
}
And override the opacity value if you wish

1
2
3
4
.my-element{
  position:relative;
  .noise(.5);
}

Here’s an example of two elements, one without and one with noise. It’s subtle, but that’s what I need for my projects, you could use a noise image with a higher contrast if you wish.

Thats it! If you use it, drop me a line!

comments powered by Disqus