Reputation:
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:
Upvotes: 67
Views: 236446
Reputation: 9384
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.
Upvotes: 6
Reputation: 841
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.
Upvotes: 1
Reputation: 21
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.
Upvotes: 2
Reputation: 1964
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:
Upvotes: 102
Reputation: 6608
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.
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.
Upvotes: 31