基于SVG的web页面图形绘制API介绍
转自:http://blog.csdn.net/jia20003/article/details/9185449
一:什么是SVG
SVG是1999由W3C发布的2D图形描述语言,纯基于XML格式的标记语言,SVG的
全称是可扩展的矢量图形跟传统的Raster方式的图形(JPG, PNG, GIF等)有很大的差
别。SVG是2D图形开发平台,包括两个部分,一个是基于XML语言的数据描述,另
外一部分是可编程的API,其关键特性支持图形,文本,梯度填充,画笔风格,图形
特效滤镜如高斯模糊,会在稍后的代码中演示。同时还支持各种鼠标事件与DOM部
分API。几乎所有的主流浏览器都支持SVG图形格式的现实与绘制,IE9+以上也开始
支持SVG,在低版本的IE中需要插件支持。
更多了解SVG访问这里:http://www.w3.org/Graphics/SVG/About.html
二:JavaScript中SVG API编程演示
创建与获取SVG对象
// create svg object
var mySvg = document.createElementNS("http://www.w3.org/2000/svg","svg");
mySvg.setAttribute("version","1.2");// IE9+ support SVG 1.1 version
mySvg.setAttribute("baseProfile","tiny");
container.appendChild(mySvg);
在SVG中创建一个矩形图形:
var c1 = document.createElementNS("http://www.w3.org/2000/svg","rect");
c1.setAttribute("x","20");
c1.setAttribute("y","20");
c1.setAttribute("width","150");
c1.setAttribute("height","150");
c1.setAttribute("fill","rgb(0,0,255)");
c1.setAttribute("stroke","rgb(0,0,0)");
c1.setAttribute("stroke-width","4");
mySvg.appendChild(c1);
在SVG中实现文本绘制:
// SVG draw text
var stext = document.createElementNS("http://www.w3.org/2000/svg","text");
stext.setAttribute("x","700");
stext.setAttribute("y","100");
stext.setAttribute("font-size","18px");
stext.setAttribute("fill","#FF0000");
var textString = document.createTextNode("Hello SVG");
stext.appendChild(textString);
mySvg.appendChild(stext);
在SVG对象上实现鼠标点击事件处理与MouseUp事件处理:
// mouse event handling
c1.addEventListener("click",changeColor,false);
c2.addEventListener("mouseup", changeColor,false);
通过SVG 图形滤镜实现高斯模糊:
- <div id="blur-image-demo">
- <div id="left" style="width:20%;"><img src="woniu.png" alt="Original image" width="325" height="471"></div>
- <div id="right" style="width:80%;">
- <svg xmlns="http://www.w3.org/2000/svg" version="1.1">
- <defs>
- <filter id="f1" x="0" y="0">
- <feGaussianBlur in="SourceGraphic" stdDeviation="5" />
- </filter>
- </defs>
- <image x="0" y="0" width="325" height="471" xlink:href="woniu.png" filter="url(#f1)"/>
- </svg>
- </div>
- </div>
运行效果:
源代码,可以copy直接运行
JavaScript部分
- window.onload = function() {
- // get DIV
- var container = document.getElementById("svgContainer");
- // create svg object
- var mySvg = document.createElementNS("http://www.w3.org/2000/svg", "svg");
- mySvg.setAttribute("version", "1.2");// IE9+ support SVG 1.1 version
- mySvg.setAttribute("baseProfile", "tiny");
- container.appendChild(mySvg);
- // create svg shape - rectangle
- var c1 = document.createElementNS("http://www.w3.org/2000/svg", "rect");
- c1.setAttribute("x", "20");
- c1.setAttribute("y", "20");
- c1.setAttribute("width", "150");
- c1.setAttribute("height", "150");
- c1.setAttribute("fill", "rgb(0,0,255)");
- c1.setAttribute("stroke", "rgb(0,0,0)");
- c1.setAttribute("stroke-width", "4");
- mySvg.appendChild(c1);
- // create svg shape - circle
- var c2 = document.createElementNS("http://www.w3.org/2000/svg", "circle");
- c2.setAttribute("cx", "250");
- c2.setAttribute("cy", "100");
- c2.setAttribute("r", "60");
- c2.setAttribute("fill", "#996699");
- c2.setAttribute("stroke", "#AA99FF");
- c2.setAttribute("stroke-width", "7");
- mySvg.appendChild(c2);
- // create svg shape - ellipse
- var c3 = document.createElementNS("http://www.w3.org/2000/svg", "ellipse");
- c3.setAttribute("cx", "450");
- c3.setAttribute("cy", "100");
- c3.setAttribute("rx", "100");
- c3.setAttribute("ry", "50");
- c3.setAttribute("fill", "#FF0000");
- c3.setAttribute("stroke", "purple");
- c3.setAttribute("stroke-width", "3");
- mySvg.appendChild(c3);
- // create svg shape - draw lines
- for(var i=0; i<10; i++)
- {
- var sline = document.createElementNS("http://www.w3.org/2000/svg", "line");
- var x1 = 580 + i*10;
- console.log(x1);
- sline.setAttribute("x1", x1.toString());
- sline.setAttribute("y1", "10");
- sline.setAttribute("x2", x1.toString());
- sline.setAttribute("y2", "180");
- sline.setAttribute("stroke", "rgb(0,255,0)");
- sline.setAttribute("stroke-width", "2");
- mySvg.appendChild(sline);
- }
- // SVG draw text
- var stext = document.createElementNS("http://www.w3.org/2000/svg", "text");
- stext.setAttribute("x", "700");
- stext.setAttribute("y", "100");
- stext.setAttribute("font-size", "18px");
- stext.setAttribute("fill", "#FF0000");
- var textString = document.createTextNode("Hello SVG");
- stext.appendChild(textString);
- mySvg.appendChild(stext);
- // mouse event handling
- c1.addEventListener("click", changeColor, false);
- c2.addEventListener("mouseup", changeColor, false);
- };
- function changeColor(evt) {
- var target = evt.target;
- target.setAttributeNS(null, "fill", "green");
- }
HTML部分:
- <html>
- <head>
- <title>Gloomyfish SVG Demo</title>
- <style>
- #svgContainer {
- width:800px;
- height:200px;
- background-color:#EEEEEE;
- }
- #left { float: left;}
- #right { float: right;}
- </style>
- </head>
- <body>
- <div id="svgContainer"></div>
- <div id="blur-image-demo">
- <div id="left" style="width:20%;"><img src="woniu.png" alt="Original image" width="325" height="471"></div>
- <div id="right" style="width:80%;">
- <svg xmlns="http://www.w3.org/2000/svg" version="1.1">
- <defs>
- <filter id="f1" x="0" y="0">
- <feGaussianBlur in="SourceGraphic" stdDeviation="5" />
- </filter>
- </defs>
- <image x="0" y="0" width="325" height="471" xlink:href="woniu.png" filter="url(#f1)"/>
- </svg>
- </div>
- </div>
- </body>
- </html>
转载请务必注明出处
基于SVG的web页面图形绘制API介绍的更多相关文章
- 基于视觉的Web页面分页算法VIPS的实现源代码下载
基于视觉的Web页面分页算法VIPS的实现源代码下载 - tingya的专栏 - 博客频道 - CSDN.NET 基于视觉的Web页面分页算法VIPS的实现源代码下载 分类: 技术杂烩 2006-04 ...
- 基于svg.js实现对图形的拖拽、选择和编辑操作
本文主要记录如何使用 svg.js 实现对图形的拖拽,选择,图像渲染及各类形状的绘制操作. 1.关于SVG SVG 是可缩放的矢量图形,使用XML格式定义图像,可以生成对应的DOM节点,便于对单个图形 ...
- SVG 2D入门2 - 图形绘制
基本形状 SVG提供了很多的基本形状,这些元素可以直接使用,这一点比canvas好多了.废话不说了,直接看例子,这个最直接: <svg width="200" heigh ...
- d3.js 之SVG:矢量化图形绘制
SVG Scalable Vector Graphics 是一个成熟的W3C标准,被设计用来在web和移动平台 上展示可交互的图形.和HTML类似,SVG也支持CSS和JavaScript.尽管可以使 ...
- JAVA WEB学习笔记(三):简单的基于Tomcat的Web页面
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- QQ音乐Android客户端Web页面通用性能优化实践
QQ音乐 Android 客户端的 Web 页面日均 PV 达到千万量级,然而页面的打开耗时与 Native 页面相距甚远,需要系统性优化.本文将介绍 QQ 音乐 Android 客户端在进行 Web ...
- 基于图形检测API(shape detection API)的人脸检测
原文:https://paul.kinlan.me/face-detection/ 在 Google 开发者峰会中,谷歌成员 Miguel Casas-Sanchez 跟我说:"嘿 Paul ...
- 创建基于OData的Web API - Knowledge Builder API, Part I:Business Scenario
在.NET Core 刚刚1.0 RC的时候,我就给OData团队创建过Issue让他们支持ASP.NET Core,然而没有任何有意义的答复. Roadmap for ASP.NET Core 1. ...
- 基于Metronic的Bootstrap开发框架经验总结(9)--实现Web页面内容的打印预览和保存操作
在前面介绍了很多篇相关的<Bootstrap开发框架>的系列文章,这些内容基本上覆盖到了我这个Bootstrap框架的各个主要方面的内容,总体来说基本达到了一个稳定的状态,随着时间的推移可 ...
随机推荐
- 如何禁用IE10的明文显示密码和快速清除功能
IE10针对 <input>及<input type="password"> 分别提供了快速清除钮(X图标)以及密码文字显示钮(小眼睛图标)的功能: 快速清 ...
- 【apache】yum 安装Apache(Centos 6.5)
一.首先在系统上面查询一下是否已经安装了apache [Apache在linux系统里的名字是httpd] rpm -qa httpd 如果有返回的信息,则会显示已经安装的软件.如果没有则 ...
- BSD Apache GPL LGPL MIT
当Adobe.Microsoft.Sun等一系列巨头开始表现出对”开源”的青睐时,”开源”的时代即将到来! 最初来自:sinoprise.com/read.php?tid-662-page-e-fpa ...
- js6类和对象
// 第一种:对象 var person = {};// 或者var obj = new Object(); person.name = "king"; person.age = ...
- 0525Scrum项目7.0
一.Spring1回顾: 在这第一个冲刺中,我们主要是完成了主界面的建立,过程虽然有些曲折,大家有时候找的素材.图片都有一些冲突,但是最后我们还是求同存异,努力地做好界面! 在这一个冲刺中,我们虽然算 ...
- asp.net页面跳转sessionid会变
今天发现在一个Asp.net站点中, 同一次登录, 不停刷新页面或者页面跳转, 此时后台Session的SessionID总是变化的. 创建一个页面,添加一个button,后台代码非常简单,如下 ...
- iOS开发UI篇—无限轮播(新闻数据展示)
iOS开发UI篇—无限轮播(新闻数据展示) 一.实现效果 二.实现步骤 1.前期准备 (1)导入数据转模型的第三方框架MJExtension (2)向项目中添加保存有“新闻”数据的pli ...
- mybaits入门
1.回顾jdbc开发 orm概述 orm是一种解决持久层对象关系映射的规则,而不是一种具体技术.jdbc/dbutils/springdao,hibernate/springorm,mybaits同属 ...
- KnockOut.js入门示例详解
KnockOut框架简称KO,是微软将应用于WPF/Silverlight的MVVM模式在Web上的尝试,这是一个非常有用的JavaScript框架. KO的核心就是绑定,包括数据绑定和行为绑定: K ...
- python操作excel表格详解(xlrd/xlwt)
http://www.2cto.com/kf/201501/373655.html http://blog.csdn.net/b_h_l/article/details/17001395 利用pyth ...