注意:Internet Explorer和Safari不支持SVG滤镜

<defs>、<filter>

所有互联网的SVG滤镜定义在<defs>元素中,<filter>标签用来定义SVG滤镜,<filter>标签使用必须的ID属性来定义向图形应用到那个滤镜中

SVG模糊效果

<feGaussianBlur>

feGaunssianBlur元素是用于创建模糊效果

SVG代码:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
  <defs>
    <filter id="f1"
x="0" y="0">
     
<feGaussianBlur in="SourceGraphic" stdDeviation="15"
/>
    </filter>
  </defs>
  <rect width="90"
height="90" stroke="green" stroke-width="3"
  fill="yellow"
filter="url(#f1)" />
</svg>

代码解析:

<filter>元素id属性定义一个滤镜的唯一名称

<feCaussianBlur>元素定义模糊效果

in="SourceGraphic"这个部分定义了由整个图像创建效果

stdDeviation属性定义模糊量

<rect>元素的滤镜属性用来把元素链接到“f1”滤镜

SVG阴影

<feOffset>

feOffset元素用于创建阴影效果

实例1

偏移一个矩形(带<feOffset>),然后混合偏移图像顶部(含<feBlend>)

SVG代码:

<svg xmlns="http://www.w3.org/2000/svg"
version="1.1">
  <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>

实例2

偏移图像可以变的模糊(含<feGaussianBlur>)

SVG代码:

<svg
xmlns="http://www.w3.org/2000/svg" version="1.1">
  <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>

代码解析

元素的stdDeviation属性定义了模糊量

实例3

制作一个黑色的阴影

SVG代码:

<svg
xmlns="http://www.w3.org/2000/svg" version="1.1">
  <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>

代码解析:

feOffset元素的属性改为"SourceAlpha"在Alpha通道使用残影,而不是整个RGBA像素

实例4

为阴影涂上一层颜色

SVG代码:

<svg
xmlns="http://www.w3.org/2000/svg" version="1.1">
  <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系列(4):SVG滤镜效果的更多相关文章

  1. 学习SVG系列(5):SVG渐变

    SVG渐变 渐变是一种从一种颜色到另一种颜色的平滑过渡,可以把多个颜色的过渡应用到同一个元素. 渐变有两种: Linear Redial 线性渐变-<linearGradient> lin ...

  2. 学习SVG系列(3):SVG Stroke属性

    SVG stroke 属性 1.stroke 2.stroke-width 3.stroke-linecap 4.stroke-dasharray 5.stroke-opacity 6.stroke- ...

  3. 学习SVG系列(1):SVG基础

    什么是SVG? 1.指可伸缩矢量图形 2.用来定义用于网络的基于矢量的图形 3.使用XML格式定义图形 4.图像在放大或改变尺寸的情况下其图形不会有所损失 5.万维网联盟的标准, 用于描述二维矢量图形 ...

  4. SVG系列教程:SVG简介与嵌入HTML页面的方式

    地址:http://www.w3cplus.com/html5/svg-introduction-and-embedded-html-page.html 随着技术向前的推进,SVG相关的讨论也越渐频繁 ...

  5. HTML5 学习03——内联 SVG

    什么是SVG? SVG 指可伸缩矢量图形 (Scalable Vector Graphics) SVG 用于定义用于网络的基于矢量的图形 SVG 使用 XML 格式定义图形 SVG 图像在放大或改变尺 ...

  6. MongoDB学习笔记系列

    回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...

  7. 【翻译svg教程 】svg 的坐标系统

    http://tutorials.jenkov.com/svg/svg-coordinate-system.html svg的坐标系统(和大多数计算机绘图的坐标系统)和数学中绘图系统有点不一样 数学/ ...

  8. Nagios学习实践系列——基本安装篇

    开篇介绍 最近由于工作需要,学习研究了一下Nagios的安装.配置.使用,关于Nagios的介绍,可以参考我上篇随笔Nagios学习实践系列——产品介绍篇 实验环境 操作系统:Red Hat Ente ...

  9. Nagios学习实践系列——配置研究[监控当前服务器]

    其实上篇Nagios学习实践系列——基本安装篇只是安装了Nagios基本组件,虽然能够打开主页,但是如果不配置相关配置文件文件,那么左边菜单很多页面都打不开,相当于只是一个空壳子.接下来,我们来学习研 ...

随机推荐

  1. VC++使用Pro*CC++

    几种数据库访问技术的比较 由上所述, Visual C++ 通过以上方法都可以访问Oracle 数据 库, 但是上述方法各有优缺点.ODBC 出现得比较早, 几乎支持所 有的关系型数据库, 而且有MF ...

  2. 从客户端(Content="<p>测试</p>")中检测到有潜在危险的 Request.Form 值

    .NetFrameWork 4.0 Validaterequest="false"不起作用 要恢复到2.0的ASP.NET请求验证功能的行为,要在以下设置 Web.config中 ...

  3. DataFormatString 转

    数据绑定之DataFormatString 设定BoundField的DataFormatString,通常有以下几种 DataFormatString= "{0:C}" 货币,货 ...

  4. 51nod 1244 莫比乌斯函数之和

    题目链接:51nod 1244 莫比乌斯函数之和 题解参考syh学长的博客:http://www.cnblogs.com/AOQNRMGYXLMV/p/4932537.html %%% 关于这一类求积 ...

  5. 超级文件搜索器(SuperSearch)

    写了个工具,各个分享渠道上传太难了,在这里分享给大家吧! 中文名称:超级文件搜索器 英文名称:  SuperSearch 适用对象:硬盘里文件达到数万至数千万级的用户 运行环境:WindowXP,Wi ...

  6. Git bash使用中...

    理解Head指向分支及标签tag Head指向当前分支(如master),可以把每次提交完成的修改看成一个圈,在修改上可以开另一分支为接下来的修改做准备,未修改前新建的分支与当前分支可看成绕修改圈转: ...

  7. ionic实现上拉到底内容提示

    <!--html代码--> <ion-content has-bouncing = true on-drag-up="scrollDragUp()"> &l ...

  8. css3过渡

    语法格式: transition:属性名 完成时间 速度曲线 何时开始 transition:width 2s ease-in 3s: width 2s 整个过渡效果持续的时间 ease-in 指定了 ...

  9. Linux 关机命令

    正确的关机流程是:sync –> shutdown/reboot/halt/poweroff sync 将数据由内存同步到硬盘中. shutdown 关机指令.例如你可以运行如下命令关机: sh ...

  10. UDP传输

    @@@基于UDP的客服端代码 public class Service { // 服务器 public static void main(String[] args) { DatagramPacket ...