SVG 高斯模糊

必须在 <defs> 标签中定义 SVG 滤镜。

高斯模糊(Gaussian Blur)

<filter> 标签用来定义 SVG 滤镜。<filter> 标签使用必需的 id 属性来定义向图形应用哪个滤镜?

<filter> 标签必须嵌套在 <defs> 标签内。<defs> 标签是 definitions 的缩写,它允许对诸如滤镜等特殊元素进行定义。

请把下面的代码拷贝到记事本,然后把文件保存为 "filter1.svg"。把此文件放入您的 web 目录:

  1. <?xml version="1.0" standalone="no"?>
  2. <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN"
  3. "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
  4.  
  5. <svg width="100%" height="100%" version="1.1"
  6. xmlns="http://www.w3.org/2000/svg">
  7.  
  8. <defs>
  9. <filter id="Gaussian_Blur">
  10. <feGaussianBlur in="SourceGraphic" stdDeviation="3" />
  11. </filter>
  12. </defs>
  13.  
  14. <ellipse cx="200" cy="150" rx="70" ry="40"
  15. style="fill:#ff0000;stroke:#000000;
  16. stroke-width:2;filter:url(#Gaussian_Blur)"/>
  17.  
  18. </svg>

代码解释:

  • <filter> 标签的 id 属性可为滤镜定义一个唯一的名称(同一滤镜可被文档中的多个元素使用)
  • filter:url 属性用来把元素链接到滤镜。当链接滤镜 id 时,必须使用 # 字符
  • 滤镜效果是通过 <feGaussianBlur> 标签进行定义的。fe 后缀可用于所有的滤镜
  • <feGaussianBlur> 标签的 stdDeviation 属性可定义模糊的程度
  • in="SourceGraphic" 这个部分定义了由整个图像创建效果

另一个 stdDeviation 值不同的例子

  1. <?xml version="1.0" standalone="no"?>
  2. <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN"
  3. "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
  4.  
  5. <svg width="100%" height="100%" version="1.1"
  6. xmlns="http://www.w3.org/2000/svg">
  7.  
  8. <defs>
  9. <filter id="Gaussian_Blur">
  10. <feGaussianBlur in="SourceGraphic" stdDeviation="20"/>
  11. </filter>
  12. </defs>
  13.  
  14. <ellipse cx="200" cy="150" rx="70" ry="40"
  15. style="fill:#ff0000;stroke:#000000;
  16. stroke-width:2;filter:url(#Gaussian_Blur)"/>
  17.  
  18. </svg>