javascript線性漸變一
更新時間:2009年10月14日 19:59:13 作者:
javascript在處理圖像的能力其實是不弱的,可惜瀏覽器大戰(zhàn)連累了它,這還不算,Adobe 收購Macromedia更讓SVG處于怠工狀態(tài)。
作為新力軍,蘋果為我們帶來了canvas標(biāo)簽。canvas首次在Mac OS X中的Dashboard中被引入,之后又被蘋果公司的Safari瀏覽器所支持,緊接著就成為HTML5的標(biāo)準(zhǔn),被IE內(nèi)核以外的標(biāo)準(zhǔn)瀏覽器所支持。蘋果做的好事還不止這一樁,它認(rèn)為SVG太笨重了,于是它把SVG里的濾鏡標(biāo)簽統(tǒng)統(tǒng)CSS屬性化(SVG的濾鏡比IE濾鏡還多呢,而且功能更全面)。firefox一看不對勁,連忙自己也搞一套私有屬性,只不過是前綴由-webkit-改為-moz-罷了。opera的反應(yīng)比較呆滯,應(yīng)該說私底下非常不滿,因為opera的CTO就是CSS的發(fā)明者Hakon Wium Lie,不喜歡別人對自己的東西啥搞。因此我實現(xiàn)線性漸變就困難重重了,IE需要用IE濾鏡,firefox在動態(tài)創(chuàng)建SVG存在一些問題,需要用其-moz-前綴的CSS私有屬性,safari與chrome需要用-webkit-前綴的CSS私有屬性,opera需要用SVG?,F(xiàn)在一個個突破吧。
IE要用到DXImageTransform.Microsoft.Gradient濾鏡(最后那個Gradient的首字母大寫小寫無所謂)。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
接著講述一下SVG線性漸變的實現(xiàn),因為相關(guān)的CSS私有屬性都衍生于此。由于沒有什么空間支持上傳SVG,我只能動態(tài)生成SVG了。對我來說,能動態(tài)實現(xiàn)最好不過了,起碼能減少請求數(shù),少寫許多大于號小于號……下面是靜態(tài)實現(xiàn),至于怎樣加入html自己google吧。
linearGradient 有x1,x2,y1,y2等幾個屬性,可以幫助我們實現(xiàn)水平漸變或垂直漸變。我們大可以把x1,x2,y2,y2當(dāng)成顏色漸變體的兩個點的坐標(biāo)就是。
當(dāng)y1等于y2,x1不等于x2,實現(xiàn)水平漸變。
當(dāng)x1等于x2,y1不等于y2,實現(xiàn)垂直漸變。
當(dāng)y1不等于y2,x1不等于x2,實現(xiàn)角度漸變。
<?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í)行]
動態(tài)實現(xiàn),不過在火狐中啞火了,可見火狐在SVG上也怠工了。
<?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í)行]
<?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í)行]
接著說說-moz-linear-gradient,火狐的CSS私有屬性,隸屬于background-image,不過它也略寫成background。語法為:
-moz-linear-gradient( <POINT>, <POINT> [, <STOP>]* )
我們可以設(shè)置這兩個點的值坪決定其是水平還是垂直,如
/*水平*/
-moz-linear-gradient(left, right [, <STOP>]* )1.
/*垂直*/
-moz-linear-gradient(top, bottom [, <STOP>]* )
至于后面的部分,看看下面的運行框就足夠了。不過這要用最新版的firefox(3.6a1)才能見效果。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
接著下來看看-webkit-gradient這個CSS屬性,用法來-moz-linear-gradient差不多,但有三點不同。第一個參數(shù)用來決定是線性漸變與放射性漸變,這里寫linear就可以了。兩個點值,一定要為left,right,top與bottom的兩個,而且怎樣組合也實現(xiàn)不了角度漸變。三是color-stop的偏移量一定為小數(shù)。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
結(jié)語,這就是多種瀏覽器共存的帶來的和諧局面,我寧愿IE實現(xiàn)完全壟斷了。下一部分才是征途的開始,光IE處理濾鏡失效的問題,就要動用table這個上古神器了。SVG,在上面的運框中,你們看到了,我還特意搞了一個小工具來創(chuàng)建這些特殊的對象……
IE要用到DXImageTransform.Microsoft.Gradient濾鏡(最后那個Gradient的首字母大寫小寫無所謂)。
| 屬性 | 說明 |
|---|---|
| enabled | 是否啟用濾鏡,默認(rèn)為true |
| gradientType | 是垂直漸變還是水平漸變,默認(rèn)是0(垂直漸變),1為水平漸變 |
| startColorStr | 起始顏色,能接受一個8位hex顏色值,從#FF000000到#FFFFFFFF,默認(rèn)是藍色#FF0000F;或者使用red,green等顏色值F |
| endColorStr | 結(jié)束顏色,能接受一個8位hex顏色值,從#FF000000到#FFFFFFFF,默認(rèn)是黑色#FF000000 |
| startColor | 作用同startColorStr,接受一個0到4294967295整體顏色值,沒有默認(rèn)值 |
| endColor | 作用同endColorStr,接受一個0到4294967295整體顏色值,沒有默認(rèn)值 |
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
接著講述一下SVG線性漸變的實現(xiàn),因為相關(guān)的CSS私有屬性都衍生于此。由于沒有什么空間支持上傳SVG,我只能動態(tài)生成SVG了。對我來說,能動態(tài)實現(xiàn)最好不過了,起碼能減少請求數(shù),少寫許多大于號小于號……下面是靜態(tài)實現(xiàn),至于怎樣加入html自己google吧。
linearGradient 有x1,x2,y1,y2等幾個屬性,可以幫助我們實現(xiàn)水平漸變或垂直漸變。我們大可以把x1,x2,y2,y2當(dāng)成顏色漸變體的兩個點的坐標(biāo)就是。
當(dāng)y1等于y2,x1不等于x2,實現(xiàn)水平漸變。
當(dāng)x1等于x2,y1不等于y2,實現(xiàn)垂直漸變。
當(dāng)y1不等于y2,x1不等于x2,實現(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í)行]
動態(tài)實現(xià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í)行]
接著說說-moz-linear-gradient,火狐的CSS私有屬性,隸屬于background-image,不過它也略寫成background。語法為:
-moz-linear-gradient( <POINT>, <POINT> [, <STOP>]* )
我們可以設(shè)置這兩個點的值坪決定其是水平還是垂直,如
/*水平*/
-moz-linear-gradient(left, right [, <STOP>]* )1.
/*垂直*/
-moz-linear-gradient(top, bottom [, <STOP>]* )
至于后面的部分,看看下面的運行框就足夠了。不過這要用最新版的firefox(3.6a1)才能見效果。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
接著下來看看-webkit-gradient這個CSS屬性,用法來-moz-linear-gradient差不多,但有三點不同。第一個參數(shù)用來決定是線性漸變與放射性漸變,這里寫linear就可以了。兩個點值,一定要為left,right,top與bottom的兩個,而且怎樣組合也實現(xiàn)不了角度漸變。三是color-stop的偏移量一定為小數(shù)。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
結(jié)語,這就是多種瀏覽器共存的帶來的和諧局面,我寧愿IE實現(xiàn)完全壟斷了。下一部分才是征途的開始,光IE處理濾鏡失效的問題,就要動用table這個上古神器了。SVG,在上面的運框中,你們看到了,我還特意搞了一個小工具來創(chuàng)建這些特殊的對象……
相關(guān)文章
Javascript中Math.max和Math.max.apply的區(qū)別和用法詳解
這篇文章主要介紹了Javascript中Math.max和Math.max.apply的區(qū)別和用法,本文給大家啊介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08
利用ES6的Promise.all實現(xiàn)至少請求多長時間的實例
下面小編就為大家?guī)硪黄肊S6的Promise.all實現(xiàn)至少請求多長時間的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
Bootstrap實現(xiàn)省市區(qū)三級聯(lián)動(親測可用)
這篇文章主要為大家詳細(xì)介紹了Bootstrap實現(xiàn)省市區(qū)三級聯(lián)動,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07
原生JavaScript實現(xiàn)日歷功能代碼實例(無引用Jq)
這篇文章主要介紹了原生JavaScript實現(xiàn)日歷功能代碼實例(無引用Jq),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09
select2 ajax 設(shè)置默認(rèn)值,初始值的方法
今天小編就為大家分享一篇select2 ajax 設(shè)置默認(rèn)值,初始值的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
jq.ajax+php+mysql實現(xiàn)關(guān)鍵字模糊查詢(示例講解)
下面小編就為大家分享一篇jq.ajax+php+mysql實現(xiàn)關(guān)鍵字模糊查詢(示例講解),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01

