天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript線性漸變一

作為新力軍,蘋(píng)果為我們帶來(lái)了canvas標(biāo)簽。canvas首次在Mac OS X中的Dashboard中被引入,之后又被蘋(píng)果公司的Safari瀏覽器所支持,緊接著就成為HTML5的標(biāo)準(zhǔn),被IE內(nèi)核以外的標(biāo)準(zhǔn)瀏覽器所支持。蘋(píng)果做的好事還不止這一樁,它認(rèn)為SVG太笨重了,于是它把SVG里的濾鏡標(biāo)簽統(tǒng)統(tǒng)CSS屬性化(SVG的濾鏡比IE濾鏡還多呢,而且功能更全面)。firefox一看不對(duì)勁,連忙自己也搞一套私有屬性,只不過(guò)是前綴由-webkit-改為-moz-罷了。opera的反應(yīng)比較呆滯,應(yīng)該說(shuō)私底下非常不滿,因?yàn)閛pera的CTO就是CSS的發(fā)明者Hakon Wium Lie,不喜歡別人對(duì)自己的東西啥搞。因此我實(shí)現(xiàn)線性漸變就困難重重了,IE需要用IE濾鏡,firefox在動(dòng)態(tài)創(chuàng)建SVG存在一些問(wèn)題,需要用其-moz-前綴的CSS私有屬性,safari與chrome需要用-webkit-前綴的CSS私有屬性,opera需要用SVG。現(xiàn)在一個(gè)個(gè)突破吧。

IE要用到DXImageTransform.Microsoft.Gradient濾鏡(最后那個(gè)Gradient的首字母大寫(xiě)小寫(xiě)無(wú)所謂)。
屬性說(shuō)明
enabled是否啟用濾鏡,默認(rèn)為true
gradientType是垂直漸變還是水平漸變,默認(rèn)是0(垂直漸變),1為水平漸變
startColorStr起始顏色,能接受一個(gè)8位hex顏色值,從#FF000000到#FFFFFFFF,默認(rèn)是藍(lán)色#FF0000F;或者使用red,green等顏色值F
endColorStr結(jié)束顏色,能接受一個(gè)8位hex顏色值,從#FF000000到#FFFFFFFF,默認(rèn)是黑色#FF000000
startColor作用同startColorStr,接受一個(gè)0到4294967295整體顏色值,沒(méi)有默認(rèn)值
endColor作用同endColorStr,接受一個(gè)0到4294967295整體顏色值,沒(méi)有默認(rèn)值

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
接著講述一下SVG線性漸變的實(shí)現(xiàn),因?yàn)橄嚓P(guān)的CSS私有屬性都衍生于此。由于沒(méi)有什么空間支持上傳SVG,我只能動(dòng)態(tài)生成SVG了。對(duì)我來(lái)說(shuō),能動(dòng)態(tài)實(shí)現(xiàn)最好不過(guò)了,起碼能減少請(qǐng)求數(shù),少寫(xiě)許多大于號(hào)小于號(hào)……下面是靜態(tài)實(shí)現(xiàn),至于怎樣加入html自己google吧。

linearGradient 有x1,x2,y1,y2等幾個(gè)屬性,可以幫助我們實(shí)現(xiàn)水平漸變或垂直漸變。我們大可以把x1,x2,y2,y2當(dāng)成顏色漸變體的兩個(gè)點(diǎn)的坐標(biāo)就是。

當(dāng)y1等于y2,x1不等于x2,實(shí)現(xiàn)水平漸變。
當(dāng)x1等于x2,y1不等于y2,實(shí)現(xiàn)垂直漸變。
當(dāng)y1不等于y2,x1不等于x2,實(shí)現(xiàn)角度漸變。
復(fù)制代碼 代碼如下:
<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN"
"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="800px" height="400px" version="1.1"
xmlns="http://www.w3.org/2000/svg">
<desc>Javascript線性漸變(水平) by 司徒正美</desc>
<defs>
<linearGradient id="gradient" x1="0%" y1="0%" x2="100%" y2="0%">
<stop offset="20%" stop-color="rgb(255,255,0)" stop-opacity="1"/>
<stop offset="80%" stop-color="rgb(255,0,0)" stop-opacity="1"/>
</linearGradient>
</defs>
<ellipse cx="200" cy="190" rx="85" ry="55" fill="url(#gradient)"/>
</svg>


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
動(dòng)態(tài)實(shí)現(xiàn),不過(guò)在火狐中啞火了,可見(jiàn)火狐在SVG上也怠工了。
復(fù)制代碼 代碼如下:
<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="800px" height="400px" version="1.1"
xmlns="http://www.w3.org/2000/svg">
<desc>Javascript線性漸變(垂直) by 司徒正美</desc>
<defs>
<linearGradient id="gradient" x1="0%" y1="0%" x2="0%" y2="100%">
<stop offset="0%" stop-color="#008000" stop-opacity="1"/>
<stop offset="80%" stop-color="#a9ea00" stop-opacity="0"/>
</linearGradient>
</defs>
<polygon id = "s1" points = "60,0 120,0 180,60 180,120 120,180 60,180 0,120 0,60" fill="url(#gradient)"/>
</svg>


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
復(fù)制代碼 代碼如下:
<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="800px" height="400px"
xmlns="http://www.w3.org/2000/svg" version="1.1">
<desc>Javascript線性漸變(角度) by 司徒正美</desc>
<defs>
<linearGradient id="content" x1="0%" y1="0%" x2="100%" y2="100%">
<stop stop-color="black" offset="0%"/>
<stop stop-color="teal" offset="50%"/>
<stop stop-color="white" offset="100%"/>
</linearGradient>
</defs>
<rect x="10px" y="10px" width="350" height="350" fill="url(#content)"/>
</svg>


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
接著說(shuō)說(shuō)-moz-linear-gradient,火狐的CSS私有屬性,隸屬于background-image,不過(guò)它也略寫(xiě)成background。語(yǔ)法為:
-moz-linear-gradient( <POINT>, <POINT> [, <STOP>]* )
我們可以設(shè)置這兩個(gè)點(diǎn)的值坪決定其是水平還是垂直,如
/*水平*/
-moz-linear-gradient(left, right [, <STOP>]* )1.
/*垂直*/
-moz-linear-gradient(top, bottom [, <STOP>]* )
至于后面的部分,看看下面的運(yùn)行框就足夠了。不過(guò)這要用最新版的firefox(3.6a1)才能見(jiàn)效果。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
接著下來(lái)看看-webkit-gradient這個(gè)CSS屬性,用法來(lái)-moz-linear-gradient差不多,但有三點(diǎn)不同。第一個(gè)參數(shù)用來(lái)決定是線性漸變與放射性漸變,這里寫(xiě)linear就可以了。兩個(gè)點(diǎn)值,一定要為left,right,top與bottom的兩個(gè),而且怎樣組合也實(shí)現(xiàn)不了角度漸變。三是color-stop的偏移量一定為小數(shù)。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
結(jié)語(yǔ),這就是多種瀏覽器共存的帶來(lái)的和諧局面,我寧愿IE實(shí)現(xiàn)完全壟斷了。下一部分才是征途的開(kāi)始,光IE處理濾鏡失效的問(wèn)題,就要?jiǎng)佑胻able這個(gè)上古神器了。SVG,在上面的運(yùn)框中,你們看到了,我還特意搞了一個(gè)小工具來(lái)創(chuàng)建這些特殊的對(duì)象……

JavaScript技術(shù)javascript線性漸變一,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 啊…嗯啊好深男男小黄文 | 两个人看的www免费高清直播 | 91精品婷婷国产综合久久8 | 亚洲精品www久久久久久 | 久久精品黄AA片一区二区三区 | 猪蜜蜜网站在线观看电视剧 | 中文国产在线观看 | 亚洲精品久久区二区三区蜜桃臀 | 亚洲精品视频区 | 久久精品99国产精品日本 | 亚洲黄视频在线观看 | 久久精品一卡二卡三卡四卡视频版 | 国产高清国内精品福利色噜噜 | 国产AV精品白浆一区二 | 草莓视频在线播放视频 | 99久在线国内在线播放免费观看 | 双性h浪荡受bl | 囯产免费久久久久久国产免费 | 狠狠色狠狠色综合日日32 | 亚洲午夜精品A片久久WWW解说 | 青青青青青青草 | 天天色狠狠干 | 风月宝鉴之淫乱英雄传 电影 | 6080yy亚洲久久无码 | 国产性夜夜性夜夜爽91 | 亚洲国产AV无码综合在线 | 国产亚洲美女精品久久久2020 | 久久国产精品高清一区二区三区 | 骚妇BB双飞插| 中国女人内谢69XXXXXA片 | 荡乳乱公小说 | 天堂网久久 | 国产精品无码亚洲精品 | 99RE8国产这里只有精品 | 国产精品久免费的黄网站 | 久久成人国产精品一区二区 | 麻豆精品传媒一二三区 | 草比比过程图 | 亚洲国产精品一区二区三区在线观看 | 92国产精品午夜免费福利视频 | 久久这里都是精品 |