中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

HTML5之SVG 2D入門7—SVG元素的重用與引用
來源:易賢網 閱讀:1512 次 日期:2016-07-22 15:15:45
溫馨提示:易賢網小編為您整理了“HTML5之SVG 2D入門7—SVG元素的重用與引用”,方便廣大網友查閱!

前面介紹了很多的圖形元素,如果很多圖形本身是一樣的,需要每次都去定義一個新的么?我們能否共用一些圖形呢?這是這節的重點-SVG元素的重用。

組合-g元素

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

代碼如下:

<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命名空間的相關規則這里都是適用的。例如可以給svg顯示的指定命名空間,給命名空間提供別名等。

2.g元素是可以嵌套的。

3.組合起來的圖形元素就和單個的元素一樣,可以給id值,這樣,需要的時候(例如動畫和重用一組元素)只用引用這個id值就可以了。

4.組合一組圖形元素可以統一設置這組元素的相關屬性(fill,stroke,transform等),這也是使用組合的一種場景。

模板-symbol元素

symbol元素用于定義圖形模板(模板可以包含很多圖形),這個模板可以被use元素實例化。模板的功能與g元素很相似,都是提供一組圖形對象,但是也有一些區別。與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元素實現。

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

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

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

代碼如下:

<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名稱空間的使用。盡管大多數查看器沒有它也將正確顯示這一項,但為了保持一致,xlink名稱空間應該在<svg></svg>元素上定義。

引用-use元素

任何svg,symbol,g,單個的圖形元素和use元素本質上都可以作為模板對象被use元素引用(例如初始化)。use引用的圖形內容會在指定的位置渲染。與image元素不同,use元素不能引用整個文檔。

use元素也有x,y,width和height屬性,這些屬性可以省略,如果不省略的話,會將被引用的圖形內容坐標或長度映射到當前的用戶坐標空間來。

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

更多信息請查看網頁制作
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
久久精品九九| 99视频精品在线| 欧美成人亚洲成人| 欧美国产丝袜视频| 国产精品久久久久秋霞鲁丝 | 欧美视频一二三区| 国产日韩欧美日韩| 亚洲国产欧美不卡在线观看| 夜夜爽夜夜爽精品视频| 欧美成人午夜| 午夜一区二区三视频在线观看| 欧美一区二区三区成人| 欧美啪啪一区| 国内外成人免费激情在线视频网站| 亚洲精品日本| 免费亚洲婷婷| 黄色日韩在线| 久久精品国产69国产精品亚洲| 欧美精品粉嫩高潮一区二区 | 欧美亚洲尤物久久| 欧美激情一区三区| 亚洲人成人99网站| 久久频这里精品99香蕉| 国产视频一区二区三区在线观看| 亚洲一级二级| 欧美日韩亚洲天堂| 亚洲视频久久| 欧美性事在线| 一区二区电影免费在线观看| 免费日韩一区二区| 亚洲视频图片小说| 亚洲精品一区中文| 欧美日韩理论| 国内精品久久久久久久果冻传媒| 亚洲欧美激情在线视频| 欧美成在线观看| 国产亚洲一区精品| 欧美亚洲视频| 好看不卡的中文字幕| 欧美在线视屏| 精品动漫3d一区二区三区| 久久精品国产清高在天天线| 国产午夜久久| 欧美一级艳片视频免费观看| 国产视频不卡| 午夜在线精品偷拍| 久久爱91午夜羞羞| 久久xxxx| 国产精品视屏| 欧美在线视频一区二区| 国产精品免费一区二区三区观看| 亚洲天堂男人| 国产啪精品视频| 久久精品天堂| 国产亚洲精品v| 久久久久青草大香线综合精品| 在线观看亚洲一区| 久久久噜噜噜久久久| 最新中文字幕亚洲| 欧美日韩国产探花| 亚洲一区免费网站| 国产麻豆视频精品| 久久成人资源| 午夜宅男久久久| 欧美激情国产日韩| 午夜精品一区二区在线观看| 亚洲国产精品电影| 国产精品毛片a∨一区二区三区| 先锋影院在线亚洲| 国产精品综合| 亚洲欧美日韩中文播放| 国产日韩欧美在线播放不卡| 乱中年女人伦av一区二区| 亚洲免费精品| 国产在线欧美日韩| 欧美日韩国产经典色站一区二区三区| 亚洲永久视频| 亚洲福利在线观看| 国产精品免费网站| 欧美sm视频| 亚洲欧美一区二区三区极速播放| 国产伦精品一区二区三区| 久久久久久国产精品一区| 国产免费成人av| 亚洲片在线资源| 国产色视频一区| 欧美激情综合五月色丁香小说| 欧美日本一道本| 久久亚洲一区二区| 校园春色国产精品| 久久一区二区精品| 这里只有精品视频在线| 一区二区三区在线视频观看 | 欧美激情一区二区三区四区| 亚洲先锋成人| 亚洲高清不卡在线观看| 亚洲欧美综合网| 国产九九精品视频| 欧美日韩另类一区| 免费成人激情视频| 久久精选视频| 欧美在线视频免费播放| 一本色道久久加勒比88综合| 在线观看欧美一区| 伊人蜜桃色噜噜激情综合| 99精品欧美一区二区三区综合在线| 国产综合香蕉五月婷在线| 国产精品视频成人| 欧美日韩国产综合视频在线| 久久精品国产亚洲一区二区三区| 国产精品一区二区三区四区| 国产伦精品一区二区三区免费| 国产一区二区高清视频| 欧美日韩中国免费专区在线看| 欧美一区二区性| 国产精品日产欧美久久久久| 欧美视频免费看| 欧美午夜精彩| 欧美午夜一区二区| 免费国产一区二区| 久久九九热免费视频| 久久精品国产亚洲aⅴ| 欧美精品三区| 免费在线观看一区二区| 久久亚洲综合色| 久久久国产精品亚洲一区| 欧美/亚洲一区| 欧美成人一品| 欧美久久久久免费| 欧美激情成人在线视频| 欧美国产大片| 欧美日韩成人综合天天影院| 欧美精品一区二区三区蜜桃| av成人天堂| 欧美另类一区二区三区| 欧美精品1区2区| 国产模特精品视频久久久久| 国产真实精品久久二三区| 亚洲日韩成人| 亚洲一区二区三区777| 久久久久久9| 欧美精品成人一区二区在线观看| 国产精品免费观看视频| 一区福利视频| 亚洲视频一区二区| 日韩一区二区精品葵司在线| 性久久久久久久| 欧美肥婆在线| 国产精品久久久久一区二区三区| 国产精品色在线| 亚洲电影在线看| 亚洲影视在线播放| 欧美一区日韩一区| 亚洲黄色天堂| 久久精品人人爽| 国产精品普通话对白| 亚洲黑丝在线| 欧美综合77777色婷婷| 欧美日韩精品伦理作品在线免费观看 | 亚洲人成绝费网站色www| 亚欧美中日韩视频| 欧美日韩国产精品自在自线| 国产区在线观看成人精品| 99精品视频免费观看视频| 蜜桃久久精品乱码一区二区| 国产真实乱偷精品视频免| 性欧美大战久久久久久久免费观看| 欧美日韩aaaaa| 狠狠色狠狠色综合系列| 在线视频亚洲| 久久久久久久久久久久久9999| 欧美亚州一区二区三区| 亚洲精品一级| 性色av一区二区三区在线观看| 欧美日韩一二三四五区| 亚洲精品系列| 久久综合激情| 亚洲国产成人久久综合| 麻豆av福利av久久av| 国产欧美日韩精品专区| 欧美在线啊v一区| 国产情侣久久| 久久精品国产精品亚洲| 亚洲高清毛片| 欧美国产欧美综合| 99视频在线精品国自产拍免费观看| 久久综合中文字幕| 亚洲三级影院| 国产精品播放| 欧美一区二区精品久久911| 欧美日韩系列| 久久这里有精品视频| 亚洲精品久久久蜜桃| 欧美日韩少妇| 久久9热精品视频| 亚洲国产欧美一区| 欧美性开放视频| 影音先锋国产精品| 欧美日韩免费观看一区二区三区| 中文在线资源观看网站视频免费不卡|