SVG 阴影
<feOffset>
<feOffset>
是 SVG 滤镜中的一个元素,用于在图像上创建一个偏移效果,可以用来创建阴影、轮廓和其他视觉效果。它的作用是将输入图像的每个像素沿着指定的水平和垂直方向移动一定的距离,然后将结果图像作为滤镜效果的输出。
基本语法
<feOffset dx="x-offset" dy="y-offset" />
dx
属性定义了阴影在水平方向上的偏移量。dy
属性定义了阴影在垂直方向上的偏移量。
以下代码定义了一个偏移滤镜,然后将其应用于一个红色填充的矩形,使矩形呈现出带有偏移效果的阴影,阴影在水平方向和垂直方向上分别偏移了 5 个像素。
实例
<!-- 定义偏移滤镜 -->
<filter id="offset_filter">
<feOffset dx="5" dy="5" />
</filter>
<!-- 应用偏移滤镜的矩形 -->
<rect x="50" y="50" width="100" height="80" fill="red" filter="url(#offset_filter)" />
</svg>
<feDropShadow>
SVG 阴影效果可以通过 <feDropShadow>
元素实现,它可以为 SVG 图形元素添加阴影效果,使其看起来更加立体和真实。
基本语法
<feDropShadow dx="offset-x" dy="offset-y" stdDeviation="blur-radius" flood-color="color" flood-opacity="opacity" />
dx
属性定义了阴影在水平方向上的偏移量。dy
属性定义了阴影在垂直方向上的偏移量。stdDeviation
属性定义了阴影的模糊半径,通常用于控制阴影的模糊程度。flood-color
属性定义了阴影的颜色,默认为黑色。flood-opacity
属性定义了阴影的不透明度,默认为1(完全不透明)。
以下代码定义了一个阴影滤镜,然后将其应用于一个红色填充的矩形,使矩形呈现出带有灰色阴影的效果,阴影在水平方向和垂直方向上分别偏移了 5 个像素,模糊半径为 5 个像素,阴影的颜色为灰色,不透明度为 0.5。
实例
<!-- 定义阴影滤镜 -->
<filter id="shadow_filter">
<feDropShadow dx="5" dy="5" stdDeviation="5" flood-color="gray" flood-opacity="0.5" />
</filter>
<!-- 应用阴影滤镜的矩形 -->
<rect x="50" y="50" width="100" height="80" fill="red" filter="url(#shadow_filter)" />
</svg>
实例 1
<feOffset> 元素是用于创建阴影效果。我们的想法是采取一个SVG图形(图像或元素)并移动它在 xy 平面上一点儿。
第一个例子偏移一个矩形(带 <feOffset>),然后混合偏移图像顶部(含 <feBlend>):
下面是 SVG 代码:
实例
<defs>
<filter id="f1" x="0" y="0" width="200%" height="200%">
<feOffset result="offOut" in="SourceGraphic" dx="20" dy="20" />
<feBlend in="SourceGraphic" in2="offOut" mode="normal" />
</filter>
</defs>
<rect width="90" height="90" stroke="green" stroke-width="3"
fill="yellow" filter="url(#f1)" />
</svg>
尝试一下 »
点击查看: 查看 SVG 文件。
代码解析:
- <filter>元素id属性定义一个滤镜的唯一名称
- <rect>元素的滤镜属性用来把元素链接到"f1"滤镜
实例 2
现在,偏移图像可以变的模糊(含 <feGaussianBlur>):
下面是SVG代码:
实例
<defs>
<filter id="f1" x="0" y="0" width="200%" height="200%">
<feOffset result="offOut" in="SourceGraphic" dx="20" dy="20" />
<feGaussianBlur result="blurOut" in="offOut" stdDeviation="10" />
<feBlend in="SourceGraphic" in2="blurOut" mode="normal" />
</filter>
</defs>
<rect width="90" height="90" stroke="green" stroke-width="3"
fill="yellow" filter="url(#f1)" />
</svg>
尝试一下 »
点击查看: 查看 SVG 文件。
代码解析:
- <feGaussianBlur> 元素的 stdDeviation 属性定义了模糊量
实例 3
现在,制作一个黑色的阴影:
下面是 SVG 代码:
实例
<defs>
<filter id="f1" x="0" y="0" width="200%" height="200%">
<feOffset result="offOut" in="SourceAlpha" dx="20" dy="20" />
<feGaussianBlur result="blurOut" in="offOut" stdDeviation="10" />
<feBlend in="SourceGraphic" in2="blurOut" mode="normal" />
</filter>
</defs>
<rect width="90" height="90" stroke="green" stroke-width="3"
fill="yellow" filter="url(#f1)" />
</svg>
尝试一下 »
点击查看: 查看 SVG 文件。
代码解析:
- <feOffset> 元素的属性改为 "SourceAlpha" 在 Alpha 通道使用残影,而不是整个 RGBA 像素。
实例 4
现在为阴影涂上一层颜色:
下面是 SVG 代码:
实例
<defs>
<filter id="f1" x="0" y="0" width="200%" height="200%">
<feOffset result="offOut" in="SourceGraphic" dx="20" dy="20" />
<feColorMatrix result="matrixOut" in="offOut" type="matrix"
values="0.2 0 0 0 0 0 0.2 0 0 0 0 0 0.2 0 0 0 0 0 1 0" />
<feGaussianBlur result="blurOut" in="matrixOut" stdDeviation="10" />
<feBlend in="SourceGraphic" in2="blurOut" mode="normal" />
</filter>
</defs>
<rect width="90" height="90" stroke="green" stroke-width="3"
fill="yellow" filter="url(#f1)" />
</svg>
尝试一下 »
点击查看: 查看 SVG 文件。
代码解析:
- <feColorMatrix> 过滤器是用来转换偏移的图像使之更接近黑色的颜色。 '0.2' 矩阵的三个值都获取乘以红色,绿色和蓝色通道。降低其值带来的颜色至黑色(黑色为0)
注意事项
<feOffset>
元素可以与其他滤镜效果组合使用,例如模糊、颜色矩阵等。偏移效果的偏移量
dx
和dy
可以为正值(表示向右或向下偏移)或负值(表示向左或向上偏移)。<feOffset>
元素通常用于创建阴影效果,结合其他滤镜效果可以实现更加复杂的视觉效果。
通过使用 <feOffset>
元素,你可以为SVG图形元素创建偏移效果,使其呈现出更加生动和立体的外观。
smilenow
257***[email protected]
参考地址
变换矩阵的定义和说明
feColorMatrix 的 matrix 是一个 4*5 的矩阵。前面 4 列是颜色通道的比例系数,最后一列是常量偏移。
上面公式中的 rr 表示 red to red 系数,以此类推。c1~c4 表示常量偏移。
第一个 4*5 矩阵为变换矩阵,第二个单列矩阵为待变换对象的像素值。右侧单列矩阵为矩阵 1 和 2 的点积结果。
这个变换矩阵看起来比较复杂,在实践上常使用一个简化的对角矩阵,即除了 rr/gg/bb/aa 取值非零外,其余行列取值为 0,这就退化成了简单的各颜色通道的独立调整。
feColorMatrix的语法:
上述feColorMatrix过滤器的类型值为matrix,除此之外,还有saturate(饱和度)和hueRotate(色相旋转),取值比较简单,这里不做说明。
显然当变换矩阵为单位对角矩阵时,变换结果和原值相等。
我们可以尝试调整比例系数,比如把rr的值设置为0,即去除图像中的red颜色通道含量:
尝试一下 »
smilenow
257***[email protected]
参考地址