麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 編程 > JavaScript > 正文

基于SVG的web頁(yè)面圖形繪制API介紹及編程演示

2019-11-20 22:36:13
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
一:什么是SVG
SVG是1999由W3C發(fā)布的2D圖形描述語(yǔ)言,純基于XML格式的標(biāo)記語(yǔ)言,SVG的
全稱(chēng)是可擴(kuò)展的矢量圖形跟傳統(tǒng)的Raster方式的圖形(JPG, PNG, GIF等)有很大的差
別。SVG是2D圖形開(kāi)發(fā)平臺(tái),包括兩個(gè)部分,一個(gè)是基于XML語(yǔ)言的數(shù)據(jù)描述,另
外一部分是可編程的API,其關(guān)鍵特性支持圖形,文本,梯度填充,畫(huà)筆風(fēng)格,圖形
特效濾鏡如高斯模糊,會(huì)在稍后的代碼中演示。同時(shí)還支持各種鼠標(biāo)事件與DOM部
分API。幾乎所有的主流瀏覽器都支持SVG圖形格式的現(xiàn)實(shí)與繪制,IE9+以上也開(kāi)始
支持SVG,在低版本的IE中需要插件支持。
更多了解SVG訪問(wèn)這里:http://www.w3.org/Graphics/SVG/About.html

二:JavaScript中SVG API編程演示
創(chuàng)建與獲取SVG對(duì)象
復(fù)制代碼 代碼如下:

// 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中創(chuàng)建一個(gè)矩形圖形:
復(fù)制代碼 代碼如下:

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中實(shí)現(xiàn)文本繪制:
復(fù)制代碼 代碼如下:

// 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對(duì)象上實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊事件處理與MouseUp事件處理:
復(fù)制代碼 代碼如下:

// mouse event handling
c1.addEventListener("click",changeColor,false);
c2.addEventListener("mouseup", changeColor,false);

通過(guò)SVG 圖形濾鏡實(shí)現(xiàn)高斯模糊:
復(fù)制代碼 代碼如下:

<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>

運(yùn)行效果:
 
源代碼,可以copy直接運(yùn)行
JavaScript部分
復(fù)制代碼 代碼如下:

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部分:
復(fù)制代碼 代碼如下:

<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>
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 一边吃奶一边插下面 | 一级做a爱视频 | 天天草天天干天天 | 久久亚洲精品国产一区 | 久久99精品久久 | 欧美日韩在线播放一区 | 欧洲黄视频 | 亚洲精品v天堂中文字幕 | 午夜国产成人 | 亚洲性爰 | 成人黄色短视频在线观看 | 成年人视频在线免费播放 | 精品一区二区三区免费 | 密室逃脱第一季免费观看完整在线 | 久久久精彩 | 99麻豆久久久国产精品免费 | 亚洲精品日韩色噜噜久久五月 | 国产自91精品一区二区 | av手机免费在线观看 | 老子午夜影院 | 一级黄色毛片播放 | 亚洲成人国产综合 | 深夜小视频在线观看 | 黑人一区二区三区四区五区 | 久久91久久久久麻豆精品 | 国产精品亚洲综合一区二区三区 | 国产资源在线免费观看 | 亚洲一区在线免费视频 | 成人18免费观看 | 欧美特黄特色视频 | 一级α片免费看刺激高潮视频 | 欧洲成人一区 | 国产乱一区二区三区视频 | 视频一区二区三区视频 | 欧美精品a∨在线观看不卡 午夜精品影院 | 亚洲福利视频52 | hd日本xxxx | 久久久日韩av免费观看下载 | 99久久电影 | 91久久久久久久一区二区 | 中文在线日韩 |