64

I'm currently struggling with setting an image background for my site that will load fast enough.

I have used data url image and even optomized images but it's taking to long when loading the page since the backgournd-image is still very large.

Is it possible with CSS to create a textured background color like the one in the picture below?

I tried and couldn't match this:

enter image description here

Gass
  • 7,536
  • 3
  • 37
  • 41
  • 1
    Use a tiled background image, it's the only way to get something that detailed. Definitely *don't* use a `data:` URI. It looks like that particular pattern can be safely repeated at a pretty small size if you just change the texture a bit to be tileable. – Ry- Aug 05 '12 at 04:46
  • You can easily [achieve this using SVG and CSS](https://stackoverflow.com/a/49108254) in about 400 bytes. As a bonus, you can add a gradient for almost no extra cost. – Clint Pachl Mar 05 '18 at 10:43

5 Answers5

100

with latest CSS3 technology, it is possible to create textured background. Check this out: http://lea.verou.me/css3patterns/#

but it still limited on so many aspect. And browser support is also not so ready.

your best bet is using small texture image and make repeat to that background. you could get some nice ready to use texture image here:

http://subtlepatterns.com

Kamal
  • 1,922
  • 2
  • 23
  • 37
  • 1
    @albert, Nod 32 blocked **patternify.com** and says The web page is on the list of websites with potentially dangerous content. – Shaiju T Sep 15 '16 at 09:36
  • @stom huh...don't get malware warning when i go to it...who is Nod 32, and where is this list? – albert Sep 15 '16 at 16:52
  • 1
    @albert , it seems the issue is with Nod 32 anti virus , it is showing false positive alert because some [spelling](https://forum.eset.com/topic/3875-reason-for-potentially-dangerous-content-warning/) in the website – Shaiju T Sep 17 '16 at 07:41
30

You should try slicing the image if possible into a smaller piece which could be repeated. I have sliced that image to a 101x101px image.

BG Tile

CSS:

body{
  background-image: url(SO_texture_bg.jpg);
  background-repeat:repeat;
}

But in some cases, we wouldn't be able to slice the image to a smaller one. In that case, I would use the whole image. But you could also use the CSS3 methods like what Mustafa Kamal had mentioned.

Wish you good luck.

Akhilesh B Chandran
  • 6,523
  • 7
  • 28
  • 55
  • Just curious, is there a reason you chose 101 pixels? It seems like a nonstandard size, and I'm wondering if there's a reason for this. – Christopher Shroba Apr 04 '17 at 19:36
  • 1
    @ChristopherShroba, sorry for the late reply! Didn't saw your comment. I used 101px square size because when I inspected the image, I can see that the repeating portion in the image is a square box (5rows and 5cols). Our aim is to create a tile image, that looks perfectly blended. So I cropped that portion. And when tested using the background repeat, it looked okay! So always carefully look at the image, and try to figure out which portion can be cropped to create the perfect tiles. I don't think we should bother much about the "sizes". Hope it helps :) – Akhilesh B Chandran Mar 12 '18 at 09:08
4

It's also possible to add texture using only CSS with repeating-linear-gradient()

Try the following example:

div {
    margin:10px;
    width:200px;
    height:200px;
    background-color: #67686b;
}

.pattern1{
    background-image: repeating-linear-gradient(36deg, rgba(255,255,255, 0.1), rgba(255,255,255, 0.1) 1px, transparent 0px, transparent 2px);
}

.pattern2 {
    background-image: repeating-linear-gradient(-45deg, rgba(255,255,255, 0.1), rgba(255,255,255, 0.1) 1px, transparent 1px, transparent 6px);
    background-size: 4px 4px;
}
<section style='display:flex'>
  <div class='pattern1'></div>
  <div class='pattern2'></div>
</section>

Bonus: in this link you can find different types of patterns which you can customize to fit your needs.

Gass
  • 7,536
  • 3
  • 37
  • 41
2

If you search for an image base-64 converter, you can embed some small image texture files as code into your @import url('') section of code. It will look like a lot of code; but at least all your data is now stored locally - rather than having to call a separate resource to load the image.

Example link: http://www.base64-image.de/

When I take a file from my own inventory of a simple icon in PNG format, and convert it to base-64, it looks like this in my CSS:

url('')

With your texture images, you'll want to employ a similar process.

IvanRider
  • 21
  • 2
1

Use an image editor to cut out a portion of the background, then apply CSS's background-repeat property to make the small image fill the area where it is used.

In some cases, background-repeat creates seams where the image repeats. A solution is to use an image editor as follows: starting with the background image, copy the image, flip (mirror, not rotate) the copy left-to-right, and paste it to the right edge of the original, overlapping 1 pixel. Crop to remove 1 pixel from the right edge of the combined image. Now repeat for the vertical: copy the combined image, flip the copy top-to-bottom, paste it to the bottom of the combined, overlapping one pixel. Crop to remove 1 pixel from the bottom. The resulting image should be seam-free.

Perette
  • 821
  • 8
  • 17