首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CSS线性梯度看起来不像Photoshop,它能被修复吗?

CSS线性梯度看起来不像Photoshop,它能被修复吗?
EN

Stack Overflow用户
提问于 2015-03-06 05:21:54
回答 2查看 1.4K关注 0票数 6

当使用CSS黑色到透明线性梯度时,我注意到它不会逐渐消失为透明,相反,它会使灰色区域逗留更长,并且只在接近尾端时才会变得透明,并且有一个明显的限制。

注意到这一点后,我决定使用一个具有确切性质的photoshop梯度,它看起来更好,渐变从黑色变为透明,平滑和线性。

下面是一个示例,显示左侧的CSS线性梯度和右边的Photoshop生成的渐变,它们都是用完全相同的属性创建的:

代码语言:javascript
复制
#css, #ps{
  height:100px;
  width:50%;
  }
#css{
  float:left;
  background:linear-gradient(black, transparent);
  }
#ps{
  float:right;
  background:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAABkCAMAAABw8qpSAAABLFBMVEUCAgIDAwMEBQUGBgYICAgJCQkLCwsNDQ0PDw8RERETExMVFRUXFxcZGRkbGxsdHh4gICAiIiIkJSUnJycpKiosLCwvLy8xMjI0NDQ3Nzc5Ojo8PDw/Pz9CQkJFRUVISEhLS0tOTk5RUVFUVFRXV1daWlpdXV1gYGBjY2NmZmZpamptbW1wcHBzc3N2dnZ5eXl8fX2AgICDg4OGhoaJiYmMjIyQkJCTk5OWlpaZmZmcnJyfn5+ioqKlpqaoqamrrKyvr6+ysrK0tbW3uLi6urq9vb3AwMDDw8PGxsbJycnLy8vOzs7R0dHT09PW1tbY2Njb29vd3d3g4ODi4uLk5OTm5ubp6enr6+vt7e3v7+/x8fHy8vL09PT29vb4+Pj5+fn7+/v8/Pz+/v4AAAE6GCMnAAAAY3RSTlP+/Pv5+Pb08vHv7evp5uTi4N3b2NbT0c7LyMbDwL26t7SxrquopaKfnJmWk4+MiYaDgHx5dnNwbGlmY2BdWldUUU5LSEVCPzw5NzQxLiwpJyQiHx0bGRYUEhAODQsJBwYEAwEIFXNRAAAAEElEQVQIHWNJZpnLwjj0IQCJ8QLzQI0QnQAAAABJRU5ErkJggg==");
}
代码语言:javascript
复制
<div id="css"></div>
<div id="ps"></div>

正如您所看到的,差异是明显可见的。是否有可能将Photoshop的实际线性梯度复制到CSS中,或者我唯一的选择是使用base64 64/png技巧来实现实际的线性梯度?因为目前css的线性梯度除了线性外,实际上从我所看到的情况来看,它创建了一个easeInOut梯度而不是线性梯度。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-03-06 15:24:36

正如GRC所说,您可以设置多个中点值,以使梯度适应您的确切需要。

一个很好的起点是彩紫,在这里您可以导入一个图像文件并获得一个自动结果。

对于你的形象,结果是:

代码语言:javascript
复制
.test {
    height: 100px;
    background: #020202; /* Old browsers */
    background: -moz-linear-gradient(top,  #020202 0%, #1f1f1f 9%, #434343 18%, #989898 38%, #b2b2b2 45%, #d1d1d1 56%, #e9e9e9 67%, #f2f2f2 73%, #f9f9f9 80%, #fdfdfd 87%, #fefefe 100%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#020202), color-stop(9%,#1f1f1f), color-stop(18%,#434343), color-stop(38%,#989898), color-stop(45%,#b2b2b2), color-stop(56%,#d1d1d1), color-stop(67%,#e9e9e9), color-stop(73%,#f2f2f2), color-stop(80%,#f9f9f9), color-stop(87%,#fdfdfd), color-stop(100%,#fefefe)); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top,  #020202 0%,#1f1f1f 9%,#434343 18%,#989898 38%,#b2b2b2 45%,#d1d1d1 56%,#e9e9e9 67%,#f2f2f2 73%,#f9f9f9 80%,#fdfdfd 87%,#fefefe 100%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(top,  #020202 0%,#1f1f1f 9%,#434343 18%,#989898 38%,#b2b2b2 45%,#d1d1d1 56%,#e9e9e9 67%,#f2f2f2 73%,#f9f9f9 80%,#fdfdfd 87%,#fefefe 100%); /* Opera 11.10+ */
    background: -ms-linear-gradient(top,  #020202 0%,#1f1f1f 9%,#434343 18%,#989898 38%,#b2b2b2 45%,#d1d1d1 56%,#e9e9e9 67%,#f2f2f2 73%,#f9f9f9 80%,#fdfdfd 87%,#fefefe 100%); /* IE10+ */
    background: linear-gradient(to bottom,  #020202 0%,#1f1f1f 9%,#434343 18%,#989898 38%,#b2b2b2 45%,#d1d1d1 56%,#e9e9e9 67%,#f2f2f2 73%,#f9f9f9 80%,#fdfdfd 87%,#fefefe 100%); /* W3C */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#020202', endColorstr='#fefefe',GradientType=0 ); /* IE6-9 */
}
代码语言:javascript
复制
<div class="test"></div>

问题是,这个工具只提供rgb值,您需要手动将这些值转换为rgba,并使用alpha值。

票数 3
EN

Stack Overflow用户

发布于 2015-03-06 05:35:44

你可以这样做:

代码语言:javascript
复制
background:linear-gradient(black, transparent, transparent);

代码语言:javascript
复制
background:linear-gradient(black 10%, transparent);

10%的空间被黑色占据。

希望这能有所帮助。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28892801

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档