婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

組合-g元素
g元素是一種容器,它組合一組相關的圖形元素成為一個整體;這樣,我們就可以對這個整體進行操作。這個元素通??梢院蚫esc和title元素配合使用,提供文檔的結構信息。結構良好的文檔通??勺x性和渲染效率都不錯??匆粋€小例子:

復制代碼
代碼如下:

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

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

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

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

復制代碼
代碼如下:

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

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

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

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

復制代碼
代碼如下:

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

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

復制代碼
代碼如下:

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

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

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

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

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

復制代碼
代碼如下:

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

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

復制代碼
代碼如下:

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

實用參考:
腳本索引: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/

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

巨人網絡通訊聲明:本文標題《HTML5之SVG 2D入門7—SVG元素的重用與引用》,本文關鍵詞  HTML5,之,SVG,入門,元素,的,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML5之SVG 2D入門7—SVG元素的重用與引用》相關的同類信息!
  • 本頁收集關于HTML5之SVG 2D入門7—SVG元素的重用與引用的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩美少妇| 精品国产免费一区二区三区香蕉| 欧美精品国产精品| 中文字幕国产一区二区| 亚洲va欧美va人人爽| 国产91丝袜在线观看| 在线免费不卡电影| 日本一区二区成人| 麻豆国产欧美日韩综合精品二区| thepron国产精品| 欧美xxx久久| 日韩黄色片在线观看| 在线影视一区二区三区| 国产精品网站在线观看| 国产一区二区三区观看| 日韩精品在线网站| 日韩高清在线电影| 欧美精品丝袜久久久中文字幕| 国产精品丝袜91| 麻豆国产欧美日韩综合精品二区| 91精彩视频在线| 一区二区三区四区蜜桃| 色呦呦网站一区| 亚洲精品视频免费看| 91网站最新地址| 亚洲婷婷国产精品电影人久久| 成人午夜私人影院| 国产精品五月天| 91网站视频在线观看| **性色生活片久久毛片| 99re这里只有精品6| 亚洲欧洲日韩av| 99国产精品一区| 亚洲另类色综合网站| 欧洲一区在线观看| 亚洲国产aⅴ天堂久久| 欧美日韩中文精品| 日欧美一区二区| 欧美成人一区二区三区片免费 | 这里是久久伊人| 日本vs亚洲vs韩国一区三区| 日韩一区二区在线观看| 国产一区激情在线| 亚洲国产精品二十页| 99re热这里只有精品视频| 亚洲精品免费在线观看| 欧美精品第1页| 国内精品在线播放| 自拍偷拍国产精品| 欧美中文字幕不卡| 久久精品72免费观看| 国产日韩欧美综合在线| 色婷婷久久一区二区三区麻豆| 亚洲成人免费影院| 26uuu精品一区二区| 99国产精品国产精品久久| 天天影视涩香欲综合网 | 成人爽a毛片一区二区免费| 国产精品久久久久久户外露出| 欧美中文一区二区三区| 久久疯狂做爰流白浆xx| 中文字幕在线观看不卡视频| 欧美日韩精品一区二区三区四区 | 91福利在线播放| 免费观看在线综合| 国产精品久久久久久久蜜臀| 欧美日本一道本| 成人av资源在线观看| 青青草精品视频| 椎名由奈av一区二区三区| 欧美一级艳片视频免费观看| 成人动漫一区二区在线| 日韩成人免费看| 国产精品视频一区二区三区不卡| 欧美日韩亚洲国产综合| 国产黄色成人av| 日本伊人精品一区二区三区观看方式| 久久精品视频免费观看| 3d成人动漫网站| 色婷婷精品久久二区二区蜜臂av| 国产最新精品免费| 日韩精品一二三区| 亚洲精品少妇30p| 久久久精品人体av艺术| 欧美一区中文字幕| 91美女在线视频| 成人免费视频免费观看| 久久精品国产成人一区二区三区| 亚洲综合视频在线| 欧美经典一区二区| 亚洲精品在线观看网站| 欧美一区二区三区喷汁尤物| 欧美体内she精视频| 色婷婷久久久亚洲一区二区三区| www.av精品| 成人h版在线观看| 风流少妇一区二区| 国产传媒一区在线| 国产精品一二一区| 极品少妇一区二区三区精品视频| 日本不卡不码高清免费观看| 午夜精品久久久久久久久久久| 亚洲激情校园春色| 伊人色综合久久天天人手人婷| 国产精品另类一区| 国产精品久久久久国产精品日日| 日本一二三不卡| 欧美国产精品一区二区三区| 精品免费一区二区三区| 亚洲精品在线三区| 2023国产精华国产精品| 26uuu精品一区二区 | 在线播放欧美女士性生活| 91丝袜呻吟高潮美腿白嫩在线观看| 成人午夜碰碰视频| 91色.com| 欧美日韩极品在线观看一区| 欧美一区二区三区免费大片 | 国产亚洲精品bt天堂精选| 亚洲精品一区二区三区在线观看| 久久一区二区视频| 国产精品色噜噜| 亚洲精品乱码久久久久久黑人| 亚洲综合在线五月| 偷拍一区二区三区| 久久精品国产99国产| 国产精品99久久久久久似苏梦涵| 国产河南妇女毛片精品久久久| 懂色一区二区三区免费观看| av日韩在线网站| 欧美日本在线视频| 精品国产123| 亚洲伦理在线精品| 天天爽夜夜爽夜夜爽精品视频| 激情六月婷婷久久| 99精品视频一区二区三区| 欧美日韩在线不卡| 精品国产乱码久久久久久浪潮| 中国色在线观看另类| 亚洲chinese男男1069| 久久www免费人成看片高清| 成人国产在线观看| 欧美高清一级片在线| 中文字幕精品一区| 午夜电影网一区| 成人的网站免费观看| 3751色影院一区二区三区| 国产精品欧美一级免费| 丝袜亚洲另类丝袜在线| 成人动漫中文字幕| 日韩女优电影在线观看| 亚洲美女一区二区三区| 麻豆国产精品视频| 欧洲一区在线电影| 欧美韩国日本综合| 日韩成人精品视频| 93久久精品日日躁夜夜躁欧美| 日韩欧美电影一区| 一片黄亚洲嫩模| 成人动漫一区二区三区| 91精品国产综合久久香蕉的特点| 一色桃子久久精品亚洲| 国模少妇一区二区三区| 欧美日韩免费观看一区二区三区 | 亚洲午夜免费视频| 福利一区二区在线| 日韩欧美一级特黄在线播放| 一个色在线综合| 99久久久国产精品| 国产婷婷色一区二区三区| 日本中文在线一区| 欧美日韩在线一区二区| 亚洲欧美一区二区在线观看| 国产传媒一区在线| 久久色在线视频| 精品伊人久久久久7777人| 欧美四级电影在线观看| 亚洲精品精品亚洲| 成人av在线一区二区三区| 精品成a人在线观看| 麻豆精品一区二区av白丝在线| 欧美久久一二三四区| 亚洲一区二区高清| 欧美三级视频在线观看| 一区二区三区中文免费| 色噜噜久久综合| 亚洲乱码一区二区三区在线观看| 99精品一区二区三区| 亚洲欧美日韩一区二区 | 欧美自拍偷拍一区| 一区二区三区在线视频观看58| 91丨porny丨户外露出| 综合激情网...| 在线观看一区日韩| 亚洲综合视频在线观看| 欧美日本国产视频| 日本伊人色综合网| 精品欧美久久久| 国产精品99精品久久免费| 国产女主播在线一区二区|