While using a CSS black to transparent linear-gradient I noticed that it doesn’t gradually fade to transparent, instead it makes the grey area linger longer and only near the end it becomes transparent with a noticeable limit.
After noticing this I decided to use a photoshop gradient with the exact properties and it looked better, the gradient was changing from black to transparent smoothly and linearly.
The following contains an example showing a CSS linear-gradient on the left and Photoshop generated gradient on the right – Both were created with the exact same properties:
#css, #ps{
height:100px;
width:50%;
}
#css{
float:left;
background:linear-gradient(black, transparent);
}
#ps{
float:right;
background:url("");
}
<div id="css"></div>
<div id="ps"></div>
As you can see the difference is clearly visible. Is it possible to replicate Photoshop’s real linear-gradient into CSS’s or my only option is to use base64/png tricks to achieve an actual linear gradient?
Because currently css’s linear-gradient is everything but linear, in fact from what I can see it creates an easeInOut-gradient instead of linear.
2
Answers
You can do following:
or
10% of space is taken by black.
Hope this helps.
As GRC says, you can set multiple midpoints values to adapt the gradient to your exact needs
A good starting point is colorzilla, where you can import an image file and get an automated result.
For your image, the result is:
The problem is that this tool gives only rgb values, you will need to manually convert those to rgba, and play with the alpha values.