没有通用公式,但您必须进行一些操作/计算才能找到渐变的度数以及渐变的background-size/background-position。
让我们从一个简单的例子开始:
这里我们有一个带有180deg(或0deg)的渐变。起点是顶部的50px,终点是底部的100px。考虑到这一点,我们将有以下渐变:
.box {
width: 200px;
height: 100px;
border: 1px solid;
margin: 20px;
background-image: linear-gradient(180deg, white, black);
background-size: 100% calc(100% + 50px + 100px);
background-position: 0 -50px;
background-repeat: no-repeat;
}
<div class="box"></div>
如您所见,总大小将为100% + 150px,我们将有一个-50px 的位置偏移量。考虑到100px,我们也可以有一个偏移量,它将是100% + 100px:
.box {
width:200px;
height:100px;
border:1px solid;
margin:20px;
background-image:linear-gradient(180deg,white,black);
background-size:100% calc(100% + 50px + 100px);
background-position:0 calc(100% + 100px);
background-repeat:no-repeat;
}
<div class="box">
</div>
这是另一个例子:
在这种情况下,点在内部,所以我们只需要调整渐变内部的色标:
.box {
width: 200px;
height: 100px;
border: 1px solid;
margin: 20px;
background-image: linear-gradient(90deg, white 50px, black calc(100% - 50px));
}
<div class="box"></div>
这是我们有外点和内点的混合:
.box {
width: 200px;
height: 100px;
border: 1px solid;
margin: 20px;
background-image: linear-gradient(90deg, white 50px, black);
background-size: calc(100% + 100px) 100%;
background-position: 0 0;
background-repeat: no-repeat;
}
<div class="box"></div>
如您所见,在垂直方向上它有点简单。我们只需要找到渐变的大小、它的位置和渐变内的颜色停止。
当然,当涉及到其他角度值时,它会更加棘手。
这里是一个例子的说明:
您的渐变由橙色线定义。第一步是根据the documentation画出渐变的线,这条线会和你的线平行。画完这条线,就得到了渐变的角度。
之后,我们会对您的线条进行投影,您将拥有 色标。所需的值以绿色显示。
我们的渐变看起来像这样:
background-image:linear-gradient(Xdeg,white Apx,black calc(100% - Bpx));
在这种情况下,我考虑了一个示例,其中我们只有内部点,但如果橙色线的投影会导致外部点(如第一个示例),则它会变得更加复杂,在这种情况下,我们需要考虑增加background-size 在两个方向上,这也有点棘手。
如您所见,我们有一个外部点,由与渐变点的距离B 定义。我们已经建立了一个矩形三角形,以便找到如何增加background-size。
我们的渐变看起来像这样:
background-image:linear-gradient(Xdeg,white Apx,black);
background-size:calc(100% + w) calc(100% + h);
background-position:0 0;
更新
如果您不想使用background-size/background-position,另一种方法是将渐变转换为使用内部点。当然,这种方法只有在点在外面时才有用,并且我们的想法是找到最近的内部点,这将使我们获得相同的梯度。
让我们重温第一个例子。在那个例子中,我们在顶部有第一个点50px,逻辑上最近的内部点是0px(与另一点相同的逻辑)。所以我们只需要找到新点的颜色并使用它们。
.box {
width: 200px;
height: 100px;
border: 1px solid;
margin: 20px;
}
.old {
background-image: linear-gradient(180deg, white, black);
background-size: 100% calc(100% + 50px + 100px);
background-position: 0 -50px;
background-repeat: no-repeat;
}
.new {
background-image:linear-gradient(180deg,rgb(203, 203, 203),rgba(103, 103, 103));
}
<div class="box old"></div>
<div class="box new"></div>
在这个特定的例子中,计算很容易,因为初始渐变的大小是250px,在白色 (255,255,255) 和黑色 (0,0,0) 之间我们有 255 个值(几乎 250)所以我们以某种方式删除了 50 以找到第一种颜色并添加了 100 以找到最后一种颜色。
让我们采用相同的渐变,但使用不同的颜色:紫色 (128,0,128) 和橙色 (255,165,0)。渐变的大小是250px,所以第一个偏移量 (50px) 是大小的 20%,第二个偏移量 (100px) 是 40%的大小。我们使用这些百分比来寻找新的颜色。
对于 红色,我们有 128 和 255,所以区别是 127 和 20% 是 25.4(和 40% 是50.4),因此第一个点为153.4 (128 + 25.4),最后一个点为204.2 (255 - 50.4)。我们对 green 和 blue 进行相同的计算,得到以下梯度:
.box {
width: 200px;
height: 100px;
border: 1px solid;
margin: 20px;
}
.old {
background-image: linear-gradient(180deg, purple, orange);
background-size: 100% calc(100% + 50px + 100px);
background-position: 0 -50px;
background-repeat: no-repeat;
}
.new {
background-image:linear-gradient(180deg,rgb(153, 33, 102),rgba(204, 99, 51));
}
<div class="box old"></div>
<div class="box new"></div>