注意: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. zoj 1788 Quad Trees

    zoj 1788 先输入初始化MAP ,然后要根据MAP 建立一个四分树,自下而上建立,先建立完整的一棵树,然后根据四个相邻的格 值相同则进行合并,(这又是递归的伟大),逐次向上递归 四分树建立完后, ...

  2. 公告栏放honehoneclock和喂小老鼠flash

    如果你想要放flash在公告栏,像很火的honehoneclock,就要向管理员发邮件申请js权限啦啦啦~~~~~~~Email地址:博客园 <contact@cnblogs.com> 申 ...

  3. 使用C++11的一点总结

          C++11已不是新鲜技术,但对于我来说,工作中用得还不够多(前东家长时间使用gcc3.4.5,虽然去年升了4.8.2,但旧模块维护还是3.4.5居多:新东家用的是4.4.6,不能完整支持C ...

  4. easyui datagrid 逻辑分页

    function getGroupUsers(groupPath) { $('#tbGroupUsersList').datagrid({ width: 800, height: 100, nowra ...

  5. Scala HandBook

    目录[-] 1.   Scala有多cool 1.1.     速度! 1.2.     易用的数据结构 1.3.     OOP+FP 1.4.     动态+静态 1.5.     DSL 1.6 ...

  6. RP4412开发板烧写Ubuntu12.04失败原因分析解决

    Ubuntu烧写失败可能是卡的问题 问:用RP4412开发板,卡烧了光盘中的fastboot失败,现在如何补救呢? 答:INAND格式化,利用usb来升级啊. 也有文档,看升级文档. 问:这个是怎么回 ...

  7. PHP语言基础简单整理

    1.开始结束标记<? ... ?> 2.定义变量:$变量名 例: $str="锦清笋";不需要指明数据类型 3.输出语句:(1)echo "hello wor ...

  8. Android中日期函数Calendar的一些用法和注意事项

    1.月份获取时加1 Canlendar.MONTH + 1 因为使用的是罗马历,Calendar.MONTH返回的数值不是一年中月份的值,而是当前月份距离第一个月份的差值 如:当前月份为9月份,距离1 ...

  9. DIV的不能包住子集解决办法

    在div的样式中加上:overflow:hidden,或者float:left或right

  10. 为Informix数据库开启事务

    1.首先在Informix数据库安装根目录的etc文件夹下找到名为ONCONFIG.on_xxxx的配置文件: 2.打开ONCONFIG.on_xxxx文件,在第409行的位置找到TAPEDEV \\ ...