学习SVG系列(4):SVG滤镜效果
注意: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滤镜效果的更多相关文章
- 学习SVG系列(5):SVG渐变
SVG渐变 渐变是一种从一种颜色到另一种颜色的平滑过渡,可以把多个颜色的过渡应用到同一个元素. 渐变有两种: Linear Redial 线性渐变-<linearGradient> lin ...
- 学习SVG系列(3):SVG Stroke属性
SVG stroke 属性 1.stroke 2.stroke-width 3.stroke-linecap 4.stroke-dasharray 5.stroke-opacity 6.stroke- ...
- 学习SVG系列(1):SVG基础
什么是SVG? 1.指可伸缩矢量图形 2.用来定义用于网络的基于矢量的图形 3.使用XML格式定义图形 4.图像在放大或改变尺寸的情况下其图形不会有所损失 5.万维网联盟的标准, 用于描述二维矢量图形 ...
- SVG系列教程:SVG简介与嵌入HTML页面的方式
地址:http://www.w3cplus.com/html5/svg-introduction-and-embedded-html-page.html 随着技术向前的推进,SVG相关的讨论也越渐频繁 ...
- HTML5 学习03——内联 SVG
什么是SVG? SVG 指可伸缩矢量图形 (Scalable Vector Graphics) SVG 用于定义用于网络的基于矢量的图形 SVG 使用 XML 格式定义图形 SVG 图像在放大或改变尺 ...
- MongoDB学习笔记系列
回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...
- 【翻译svg教程 】svg 的坐标系统
http://tutorials.jenkov.com/svg/svg-coordinate-system.html svg的坐标系统(和大多数计算机绘图的坐标系统)和数学中绘图系统有点不一样 数学/ ...
- Nagios学习实践系列——基本安装篇
开篇介绍 最近由于工作需要,学习研究了一下Nagios的安装.配置.使用,关于Nagios的介绍,可以参考我上篇随笔Nagios学习实践系列——产品介绍篇 实验环境 操作系统:Red Hat Ente ...
- Nagios学习实践系列——配置研究[监控当前服务器]
其实上篇Nagios学习实践系列——基本安装篇只是安装了Nagios基本组件,虽然能够打开主页,但是如果不配置相关配置文件文件,那么左边菜单很多页面都打不开,相当于只是一个空壳子.接下来,我们来学习研 ...
随机推荐
- jQuery滚动数字
<ul class="dateList"> <li class="one"> <p class="titleName&q ...
- VPN安装后报错:Reason442 & Error56
VPN安装后一直报错,同样的32位安装包别人安装是正常,自己安装就不正常了,考虑到是自己电脑配置的问题. 经过一番努力,解决了问题,下面就本次解决过程做一个小小的总结. (1)确保VPN Servic ...
- 微信内嵌浏览器sessionid丢失问题,nginx ip_hash将所有请求转发到一台机器
现象微信中打开网页,图形验证码填写后,经常提示错误,即使填写正确也会提示错误,并且是间歇性出现. 系统前期,用户使用主要集中在pc浏览器中,一直没有出现这样的问题.近期有部分用户是在微信中访问的,才出 ...
- H5如何实现一行三列布局
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF ...
- css属性的书写
书写顺序: 注释方式: /* 块状注释文字 * 块状注释文字 * 块状注释文字 */ .m-list{width:500px;} .m-list li{height:20px;line-height: ...
- Python面向对象高级之类的特殊成员
上文介绍了Python的类成员以及成员修饰符,从而了解到类中有字段.方法和属性三大类成员,并且成员名前如果有两个下划线,则表示该成员是私有成员,私有成员只能由类内部调用.无论人或事物往往都有不按套路出 ...
- 10.6 CCPC northeast
1001 Minimum's Revenge 点的编号从 1 到 n ,u v 的边权是 LCM(u,v) ,求这个图的最下生成树 搞成一颗以 1 为 根 的菊花树 ---------------- ...
- IT技术学习指导之Linux系统入门的4个阶段(纯干货带图)
IT技术学习指导之Linux系统入门的4个阶段(纯干货带图) 全世界60%的人都在使用Linux.几乎没有人没有受到Linux系统的"恩惠",我们享受的大量服务(包括网页服务.聊天 ...
- javascript如何用户的判断操作系统
<script> alert(window.navigator.userAgent); if(window.navigator.userAgent.indexOf("Window ...
- JS Math.max() 函数
Math.max(a,b,...,x,y) -- 返回数个数字中较大的值 max是maximum的缩写,中文"最大量"的意思 max函数语法Math.max(a,b,...,x,y ...