成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識(shí)庫 > HTML5之SVG 2D入門7—SVG元素的重用與引用

HTML5之SVG 2D入門7—SVG元素的重用與引用

熱門標(biāo)簽:電銷機(jī)器人視頻 搜狗星級(jí)酒店地圖標(biāo)注 平頂山電子地圖標(biāo)注怎么修改 高德地圖標(biāo)注錯(cuò)誤怎么修改 地圖標(biāo)注自己去過的地方 洛陽市伊川縣地圖標(biāo)注中心官網(wǎng) 江蘇高頻外呼系統(tǒng)線路 標(biāo)準(zhǔn)智能外呼系統(tǒng) 會(huì)聲會(huì)影怎樣做地圖標(biāo)注效果
前面介紹了很多的圖形元素,如果很多圖形本身是一樣的,需要每次都去定義一個(gè)新的么?我們能否共用一些圖形呢?這是這節(jié)的重點(diǎn)-SVG元素的重用。

組合-g元素
g元素是一種容器,它組合一組相關(guān)的圖形元素成為一個(gè)整體;這樣,我們就可以對(duì)這個(gè)整體進(jìn)行操作。這個(gè)元素通常可以和desc和title元素配合使用,提供文檔的結(jié)構(gòu)信息。結(jié)構(gòu)良好的文檔通??勺x性和渲染效率都不錯(cuò)??匆粋€(gè)小例子:

復(fù)制代碼
代碼如下:

<svgxmlns="http://www.w3.org/2000/svg"
version="1.1"width="5cm"height="5cm">
<desc>Twogroups,eachoftworectangles</desc>
<gid="group1"fill="red">
<rectx="1cm"y="1cm"width="1cm"height="1cm"/>
<rectx="3cm"y="1cm"width="1cm"height="1cm"/>
</g>
<gid="group2"fill="blue">
<rectx="1cm"y="3cm"width="1cm"height="1cm"/>
<rectx="3cm"y="3cm"width="1cm"height="1cm"/>
</g>
<!--Showoutlineofcanvasusing'rect'element-->
<rectx=".01cm"y=".01cm"width="4.98cm"height="4.98cm"
fill="none"stroke="blue"stroke-width=".02cm"/>
</svg>

注意幾點(diǎn)
1.xmlns="http://www.w3.org/2000/svg"表明了整個(gè)svg元素默認(rèn)的命名空間是svg。這個(gè)在無歧義的時(shí)候可以省略。這里由于svg文檔是一個(gè)XML文檔,XML命名空間的相關(guān)規(guī)則這里都是適用的。例如可以給svg顯示的指定命名空間,給命名空間提供別名等。
2.g元素是可以嵌套的。
3.組合起來的圖形元素就和單個(gè)的元素一樣,可以給id值,這樣,需要的時(shí)候(例如動(dòng)畫和重用一組元素)只用引用這個(gè)id值就可以了。
4.組合一組圖形元素可以統(tǒng)一設(shè)置這組元素的相關(guān)屬性(fill,stroke,transform等),這也是使用組合的一種場景。

模板-symbol元素
symbol元素用于定義圖形模板(模板可以包含很多圖形),這個(gè)模板可以被use元素實(shí)例化。模板的功能與g元素很相似,都是提供一組圖形對(duì)象,但是也有一些區(qū)別。與g元素不同的地方是:
1.symbol元素本身是不會(huì)被渲染的,只有symbol模板的實(shí)例會(huì)被渲染。
2.symbol元素可以擁有屬性viewBox和preserveAspectRatio,這些允許symbol縮放圖形元素。

從渲染角度來說,與symbol元素相似的元素是marker(定義箭頭和標(biāo)號(hào))和pattern(定義顏色)元素;這些元素不會(huì)直接被渲染;他們的使用方式基本都是由use元素去實(shí)例化。正是這個(gè)原因,對(duì)于symbol來說,'display'屬性是沒有意義的。
下面這個(gè)修改過的代碼顯示了symbol的使用方式:

復(fù)制代碼
代碼如下:

<svgxmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"
version="1.1"width="5cm"height="5cm">
<desc>Twogroups,eachoftworectangles</desc>
<symbolid="group1"fill="red">
<rectx="1cm"y="1cm"width="1cm"height="1cm"/>
<rectx="3cm"y="1cm"width="1cm"height="1cm"/>
</symbol>
<gid="group2"fill="blue">
<rectx="1cm"y="3cm"width="1cm"height="1cm"/>
<rectx="3cm"y="3cm"width="1cm"height="1cm"/>
</g>
<usexlink:href="#group1"target="_blank"rel="nofollow">
<!--Showoutlineofcanvasusing'rect'element-->
<rectx=".02cm"y=".02cm"width="4.96cm"height="4.96cm"
fill="none"stroke="blue"stroke-width=".02cm"/>
</svg>

定義-defs元素
SVG允許定義一組對(duì)象,然后重用這組對(duì)象(注意,不僅僅是圖形對(duì)象)。最常見的例子如定義漸變色,然后再其他的圖形對(duì)象中賦給fill屬性。漸變色定義的時(shí)候是不會(huì)渲染的,所以這類型的對(duì)象可以放到任何地方。重用對(duì)于圖形對(duì)象中也是經(jīng)常存在的,而且我們也不希望定義的時(shí)候直接渲染,而是想在引用的地方渲染,這個(gè)可以用defs元素實(shí)現(xiàn)。

通常情況下,推薦的做法是:只要有可能,就把被引用的對(duì)象放到defs元素中。這些對(duì)象通常是:altGlyphDef,clipPath,cursor,filter,marker,mask,pattern,linearGradient,radialGradient,symbol和圖形對(duì)象等。把這些對(duì)象定義在defs元素中很容易理解,所以就提高了可訪問性。

其實(shí)作為容器對(duì)象的g元素、symbol元素、defs元素都不同程度上提供了重用的作用,只不過每個(gè)元素的特性可能少許不同:比如g元素是直接渲染的,symbol和defs不會(huì)直接渲染,symbol含有viewBox屬性,會(huì)創(chuàng)建新的視窗。

通常都會(huì)給在defs中定義的元素賦予id屬性,并在用到的地方直接使用。根據(jù)元素的不同,這些定義可以用到不同地方,比如下面的漸進(jìn)色作為屬性來使用了:

復(fù)制代碼
代碼如下:

<svgwidth="8cm"height="3cm"
xmlns="http://www.w3.org/2000/svg"version="1.1">
<desc>LocalURIreferenceswithinancestor's'defs'element.</desc>
<defs>
<linearGradientid="Gradient01">
<stopoffset="20%"stop-color="#39F"/>
<stopoffset="90%"stop-color="#F3F"/>
</linearGradient>
</defs>
<rectx="1cm"y="1cm"width="6cm"height="1cm"
fill="url(#Gradient01)"/>
</svg>

圖形相關(guān)元素的定義可以用use元素鏈接到文檔。例如:

復(fù)制代碼
代碼如下:

<svgwidth="10cm"height="3cm"viewBox="0010030"version="1.1"
xmlns="http://www.w3.org/2000/svg"xmlns:xlink="http://www.w3.org/1999/xlink">
<desc>ExampleUse01-Simplecaseof'use'ona'rect'</desc>
<defs>
<rectid="MyRect"width="60"height="10"/>
</defs>
<rectx=".1"y=".1"width="99.8"height="29.8"
fill="none"stroke="blue"stroke-width=".2"/>
<usex="20"y="10"xlink:href="#MyRect"/>
</svg>

在這里請(qǐng)注意xlink名稱空間的使用。盡管大多數(shù)查看器沒有它也將正確顯示這一項(xiàng),但為了保持一致,xlink名稱空間應(yīng)該在<svg></svg>元素上定義。

引用-use元素
任何svg,symbol,g,單個(gè)的圖形元素和use元素本質(zhì)上都可以作為模板對(duì)象被use元素引用(例如初始化)。use引用的圖形內(nèi)容會(huì)在指定的位置渲染。與image元素不同,use元素不能引用整個(gè)文檔。
use元素也有x,y,width和height屬性,這些屬性可以省略,如果不省略的話,會(huì)將被引用的圖形內(nèi)容坐標(biāo)或長度映射到當(dāng)前的用戶坐標(biāo)空間來。

use元素的作用過程就相當(dāng)于把被引用的對(duì)象深拷貝一份到獨(dú)立的非公開的DOM樹中;這棵樹的父節(jié)點(diǎn)是use元素。雖然是非公開的DOM節(jié)點(diǎn),但是本質(zhì)上還是DOM節(jié)點(diǎn),所以被引用對(duì)象的所有屬性值、動(dòng)畫、事件、CSS的相關(guān)設(shè)置等都會(huì)拷貝多來并都還是會(huì)起作用,而且這些節(jié)點(diǎn)也會(huì)繼承use元素和use祖先的相關(guān)屬性(注意引用元素是深拷貝,這些拷貝過來的元素與原來的元素已經(jīng)無關(guān)系了,所以這里不會(huì)繼承被引用元素祖先節(jié)點(diǎn)的屬性),如果這些節(jié)點(diǎn)本身有相關(guān)(CSS)屬性,還會(huì)覆蓋繼承來的屬性,這些與普通的DOM節(jié)點(diǎn)是一致的,所以對(duì)use元素使用"visibility:hidden"時(shí)要小心,并不一定會(huì)起作用。但是由于這部分節(jié)點(diǎn)是非公開的,在DOM操作中,也只能看到use元素,所以也只能操作到use元素。

從視覺效果來看,use元素更像是占位符,渲染完成后的視覺效果就和直接用被引用對(duì)象渲染是一樣的:
1.use元素引用一個(gè)symbol元素
這種情況下,視覺效果就相當(dāng)于:
(1)把use元素?fù)Q成g元素;
(2)把use的除x,y,width,height,xlink:href外的屬性全部移到g元素;
(3)把use的x,y屬性變成translate(x,y),追加到g元素的transform屬性最后;
(4)把引用的symbol元素?fù)Q成svg元素,這個(gè)svg元素會(huì)顯式使用use元素的width和height屬性(use元素沒有這些屬性則是100%);
(5)把引用的symbol元素的圖形內(nèi)容深拷貝到替換的svg中。
2.use元素引用一個(gè)svg元素
這種情況下,視覺效果就相當(dāng)于:
(1)把use元素?fù)Q成g元素;
(2)把use的除x,y,width,height,xlink:href外的屬性全部移到g元素;
(3)把use的x,y屬性變成translate(x,y),追加到g元素的transform屬性最后;
(4)把引用的svg元素包括內(nèi)容拷貝過來,這個(gè)svg元素會(huì)顯式使用use元素的width和height屬性(use元素沒有這些屬性則使用原來的值);
3.其他情況
這些情況下的視覺效果就相當(dāng)于:
(1)把use元素?fù)Q成g元素;
(2)把use的除x,y,width,height,xlink:href外的屬性全部移到g元素;
(3)把use的x,y屬性變成translate(x,y),追加到g元素的transform屬性最后;
(4)把引用元素拷貝過來;
看下面例子的視覺效果

復(fù)制代碼
代碼如下:

<svgwidth="10cm"height="3cm"viewBox="0010030"version="1.1"
xmlns="http://www.w3.org/2000/svg"xmlns:xlink="http://www.w3.org/1999/xlink">
<desc>ExampleUse03-'use'witha'transform'attribute</desc>
<defs>
<rectid="MyRect"x="0"y="0"width="60"height="10"/>
</defs>
<rectx=".1"y=".1"width="99.8"height="29.8"
fill="none"stroke="blue"stroke-width=".2"/>
<usexlink:href="#MyRect"
transform="translate(20,2.5)rotate(10)"/>
</svg>

下面的圖和上面的圖外觀是一樣的

復(fù)制代碼
代碼如下:

<svgwidth="10cm"height="3cm"viewBox="0010030"
xmlns="http://www.w3.org/2000/svg"version="1.1">
<desc>ExampleUse03-'use'witha'transform'attribute</desc>
<rectx=".1"y=".1"width="99.8"height="29.8"
fill="none"stroke="blue"stroke-width=".2"/>
<gtransform="translate(20,2.5)rotate(10)">
<rectx="0"y="0"width="60"height="10"/>
</g>
</svg>

實(shí)用參考:
腳本索引:http://msdn.microsoft.com/zh-cn/library/ff971910(v=vs.85).aspx
開發(fā)中心:https://developer.mozilla.org/en/SVG
熱門參考:http://www.chinasvg.com/
官方文檔:http://www.w3.org/TR/SVG11/

標(biāo)簽:蚌埠 常德 廣東 廣西 阿克蘇 松原 鄂爾多斯 果洛

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5之SVG 2D入門7—SVG元素的重用與引用》,本文關(guān)鍵詞  HTML5,之,SVG,入門,元素,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5之SVG 2D入門7—SVG元素的重用與引用》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML5之SVG 2D入門7—SVG元素的重用與引用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    人妻无码中文字幕免费视频蜜桃| www.久久久| 中文字幕一区二区三区四区不卡| 黄色a级片免费| 欧美激情成人动漫| 国产精品视频精品| 美丽的小蜜桃4春潮| 国产乱码精品一区二区亚洲| 成人福利电影精品一区二区在线观看| av福利网址网站| 国产精品7m视频| www.成人爱| 国产成人av电影在线观看| av中文字幕在线不卡| 欧美好骚综合网| 五十度飞在线播放| 韩国三级中文字幕hd久久精品| 亚洲电影激情视频网站| 欧美疯狂性受xxxxx另类| 日韩成人免费视频| 国产1区2区视频| 久久综合五月天婷婷伊人| 天天碰日日操| 99国产精品白浆在线观看免费| 精品人妻一区二区三区麻豆91| 麻豆久久精品| 午夜精品久久久久久久蜜桃app| 亚洲国产高清av| 美女少妇全过程你懂的久久| 久久久精品影院| 国产精品久久久久久久久久白浆| 国产系列电影在线播放网址| 奇米影视亚洲狠狠色| 综合久久十次| 91色.com| 亚洲精品无码专区| 激情小说中文字幕| 午夜久久资源| 欧美激情二区三区| 久久av资源网站| 欧美电影一二区| 一区二区视频免费在线观看| 日本蜜桃在线观看| 东京热一区二区三区四区| 福利在线一区二区三区| 欧美精品激情在线观看| xvideos国产在线视频| 综合国产第二页| 夫妻av一区二区| 国产精品456| 欧美日韩一区在线视频| 色是在线视频| 91在线视频免费看| 亚洲另类在线观看| 一区二区在线免费观看| 日日狠狠久久| aaa日本高清在线播放免费观看| 精品国产1区2区3区| 国产亚洲成精品久久| 日韩美女啊v在线免费观看| 日韩免费在线看| 欧美aaaaa成人免费观看视频| 美女被久久久| 久久99精品久久久久久久久久久久| 蜜桃av噜噜一区二区三区| 久久久999国产| av在线天天| 黄色一级免费视频| 亚洲成人在线视频播放| 中国一级免费毛片| 欧美日韩亚洲一区二区三区在线| 欧美三级日韩三级国产三级| 曰韩少妇与小伙激情| 欧美18免费视频| 亚洲欧美偷拍另类| 国产人成高清视频观看| 日本欧美加勒比视频| 国产精品久久久久影院日本| 超级碰在线观看| 久久国产精品 国产精品| 麻豆一区二区三区| 精品久久久久99| 一区二区国产精品精华液| 亚洲乱码一区二区三区| 久久久噜噜噜久久中文字免| 女同性恋一区二区三区| 美女网站色91| 波多视频一区| 日韩毛片免费观看| 欧美猛男做受videos| 韩国三级中文字幕hd久久精品| 欧美黑人极品猛少妇色xxxxx| 成人av网在线| 99久久精品免费观看国产| 欧美精品三级在线观看| 国产在线视频精品视频免费看| 少妇特黄一区二区三区| 桃乃木かなav在线播放| 黄色免费在线播放| 欧美少妇网站| 国产日韩在线视频| 国产亚洲一区二区三区四区| 特级黄国产片一级视频播放| 乱插在线www| 久久精品国产免费看久久精品| 国产精品精品| 久久久精品福利| 国产不卡免费视频| 女色窝人体色77777| 成人激情午夜影院| 欧美成人黑人猛交| 大陆精大陆国产国语精品| 男人天堂欧美日韩| 色综合666| 嫩草成人www欧美| 国产在线不卡精品| 在线免费观看av网站| 偷拍盗摄高潮叫床对白清晰| 国产综合18久久久久久| 久久久久国产一区二区| 成人嘿咻视频免费看| 91久色porny| 国产精品成人99一区无码| 精品国产乱码久久久久久果冻传媒| 青青草影院在线观看| 国产日韩在线精品av| 亚洲图片自拍偷拍| 欧美一区二粉嫩精品国产一线天| 极品尤物av丝袜美腿在线观看| 国产精品视频在线免费观看| 国产美女主播在线| 波多野结衣福利| 精品丰满人妻无套内射| 国产精品久久国产精麻豆99网站| 精品精品欲导航| 国产永久免费观看| 日av在线不卡| 色婷婷在线视频| 日韩国产在线观看一区| jizzjizzjizz亚洲女| 夜夜躁狠狠躁日日躁婷婷小说| 老司机福利在线观看| 亚洲激情网站| 国产免费黄色录像| 四虎成人免费电影| 亚洲国产精品www| 成人久久综合| 男人晚上看的视频| 狠狠爱www人成狠狠爱综合网| 男人操女人的视频在线观看欧美| 久久精品一区中文字幕| 91九色蝌蚪porny| 色网站免费在线观看| zzjj国产精品一区二区| 一区二区三区亚洲| 国产精品直播网红| 日本三级日本三级日本三级极| 久久精品视频在线观看榴莲视频| 妞干网免费在线视频| 韩国三级与黑人| 91入口在线观看| 国产91丝袜在线播放0| 91精品久久久久久粉嫩| 一级特黄免费视频| 波多野结衣中文在线| 一二三四在线观看免费高清中文在线观看| 久久99国产精品视频| 香蕉影院在线观看| 日本国产一级片| 中文字幕在线影院| 精品粉嫩超白一线天av| 91免费视频网址| 99久久免费看精品国产一区| 欧美日韩免费不卡视频一区二区三区| 香蕉久久免费电影| 国产成人精品电影久久久| 亚洲有吗中文字幕| 国产亚洲欧美在线| 伦伦影院午夜理论片| 综合激情网站| 不卡av在线网站| 欧美日韩在线二区| 日韩精品一区二区三区四| 国产精品自产拍| 中文一区在线观看| 最近中文字幕免费mv| 亚洲大黄网站| 精品国产一二三四区| 国产高清视频免费观看| 久青草视频在线播放| 国产日韩欧美一区二区三区乱码| 美日韩一级片在线观看| 婷婷精品视频| 国产日韩欧美一区二区三区综合| 日本在线免费观看| 91精品亚洲| 人人妻人人澡人人爽人人欧美一区| 国产美女91呻吟求| 日韩在线国产精品| 四虎影视在线观看2413| 国产欧美一区二区在线| 欧美成人激情视频免费观看| 特黄特黄一级片| 日韩欧美精品网址| 国产精品视频内| 波多野结衣 在线| 欧美三级伦理在线| 亚洲一区美女视频在线观看免费| 最近免费中文字幕视频2019| 欧美电影完整版在线观看| 黄色小视频免费网站| 欧美日韩国产中文字幕在线| 年下总裁被打光屁股sp| 亚洲综合色网| 国产精品视频福利一区二区| 国产经典中年夫妇盗摄| 美女视频第一区二区三区免费观看网站| 一本久道中文字幕精品亚洲嫩| 不卡一本毛片| 国产精品一区二区精品视频观看| 在线免费观看黄色| 91成人福利在线| 国产精品入口麻豆九色| 成年女人色毛片免费| 国产精品久久欧美久久一区| 国产婷婷精品av在线| 午夜精品一区二区三区在线观看| 三区四区在线观看| av 日韩 人妻 黑人 综合 无码| 性色88av老女人视频| 国产精品久久久久久久久久| 91精品国产乱码久久久久| 日韩欧美主播在线| 亚洲视频国产| 亚洲精品久久区二区三区蜜桃臀| 美女视频黄 久久| 日韩av中字| 国产福利片在线观看| 一级黄色片在线免费观看| 欧美在线观看一区二区| 91精品国产欧美一区二区| 欧美一区二区在线观看| 亚洲专区国产精品| 亚洲人成啪啪网站| 国产精品久久久久久久久图文区| 国产成人av免费看| 欧洲一级毛片| 一色屋精品亚洲香蕉网站| 国产黄色一区| 欧美黑人又粗大| a v视频在线观看| 亚洲精品视频91| 高清精品视频| 免费一级片91| 色综合天天做天天爱| 精品国产自在久精品国产| 亚洲精品视频99| 精品亚洲综合| 99久久久精品免费观看国产蜜| 天堂网www中文在线| 日韩欧美不卡一区| 国产精品久久a| 亚洲一区二区三区视频播放| www日韩中文字幕在线看| 精品91久久久久| 西西人体44www大胆无码| 国产欧美成人xxx视频| 国内精品久久久久| 中国字幕a在线看韩国电影| 国产精品115| 天天操夜夜操国产精品| 国产成人97精品免费看片| 欧美 日韩 国产一区二区在线视频| 无码精品一区二区三区在线| 97人妻精品一区二区三区| 精品视频久久久久| 亚洲一二三四久久| 国产精品综合久久久久| www.久久草| 久久国产香蕉视频| 亚洲免费中文| 性生交生活影碟片| 国产亚洲一区二区手机在线观看| 91精品国产综合久久精品麻豆| 国产三级做爰高清在线| 黄色一级大片在线免费看国产一| 久久久黄色大片| 亚洲自拍中文字幕| 激情五月婷婷小说| 国产有码一区二区| 国产亚洲第一伦理第一区| 免费观看又色又爽又黄的网站| 岳的好大精品一区二区三区| 国产片一区二区| 亚洲最大福利视频网站| 欧美福利在线| 日本熟妇一区二区三区| 成人网在线观看| 在线观看精品一区二区三区| 亚洲欧美日韩精品一区二区| 黄色91视频| 成人美女视频在线看| 日本国产在线视频| 91色视频在线观看| 制服黑丝国产在线| 国产精品v欧美精品v日本精品动漫| 麻豆网站视频在线观看| 91精品一区二区三区综合在线爱| 亚洲激情在线观看视频免费| 国产日韩欧美一区二区| 免费网站成人| 国产aⅴ夜夜欢一区二区三区| 2017天天干夜夜操| 五月天黄色网址| the porn av| 久久久久亚洲精品成人网小说| 亚洲精品日韩丝袜精品| 久久婷婷蜜乳一本欲蜜臀| 秋霞av亚洲一区二区三| 亚洲免费高清视频在线| 国产精品影视| 成人毛片高清视频观看| 日韩精品乱码av一区二区| 999国产精品999久久久久久| 在线免费日韩| 日韩av影视综合网| 91免费视频国产| 亚洲影院色无极综合|