中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > JavaScript顏色梯度和漸變效果改進
IE bug:1像素的dotted/dashed邊框 回到列表 純CSS圖片預(yù)加載
 JavaScript顏色梯度和漸變效果改進

作者:cloudgamer 時間: 2009-11-02 文檔類型:原創(chuàng) 來自:藍色理想

第 1 頁 JavaScript顏色梯度和漸變效果改進 [1]
第 2 頁 JavaScript顏色梯度和漸變效果改進 [2]
第 3 頁 JavaScript顏色梯度和漸變效果改進 [3]
第 4 頁 JavaScript顏色梯度和漸變效果改進 [4]
第 5 頁 JavaScript顏色梯度和漸變效果改進 [5]

如果是關(guān)鍵字形式那就要另外想方法了,可以用一個字典對象來匹配顏色值,但這樣程序會變得很龐大。
ps:可以到 這里看所有顏色名對應(yīng)的數(shù)值。
近來dean發(fā)表了“Convert any colour value to hex in MSIE”,終于解決了這個難題。
其中的關(guān)鍵是利用queryCommandValue("ForeColor")來獲取顏色值(或許做過編輯器的會比較熟悉)。
queryCommandValue 的作用是返回document、range或current selection對于給定命令的當前值。
ForeColor 命令是設(shè)置或獲取文本時的前景色。

具體的做法是先創(chuàng)建一個textarea:

if (!frag) {
    frag = document.createElement("textarea");
    frag.style.display = "none";
    document.body.insertBefore(frag, document.body.childNodes[0]);
};

ps:由于 ie的document.body.appendChild()導(dǎo)致IE已終止操作bug ,所以要用insertBefore。

然后設(shè)置color為要取值的顏色:

try { frag.style.color = color; } catch(e) { return [0, 0, 0]; }

在ie如果設(shè)置錯誤的顏色值會報錯,所以這里用try...catch來保證能返回值。

能使用queryCommandValue的包括document、range和current selection。
用createTextRange就可以建立一個range:

color = frag.createTextRange().queryCommandValue("ForeColor");

createTextRange可以用在Body,Button,Input和TextArea。
在dean的方法中是用createPopup().document.body的,好處是不用插入元素到dom。
但createPopup是ie的方法,而TextArea還可以用于getComputedStyle,后面會用到。

這樣得到的顏色值是一個數(shù)值,這個數(shù)字跟顏色的關(guān)系是這樣的:
例如紅色的16進制rgb是ff0000,先轉(zhuǎn)成bgr,即0000ff,然后轉(zhuǎn)成10進制,得到255。
同樣粉紅色pink是FFC0CB,轉(zhuǎn)成bgr是CBC0FF,10進制是13353215。
ps:使用時要注意queryCommandValue("ForeColor")得到的顏色是bgr排列的,跟一般的不一樣。

要得到rgb的值可以把轉(zhuǎn)換過程倒過來獲取,不過參考dean的文章有更巧妙的方法:

ret = [ color & 0x0000ff, (color & 0x00ff00) >>> 8, (color & 0xff0000) >>> 16 ];

先用與操作(&)把對應(yīng)位的數(shù)值取出來,再用右移運算符(>>>)把數(shù)值移到正確的位置上。

例如粉紅色FFC0CB要取得綠(g)的顏色值,用與操作(&)取得對應(yīng)值,F(xiàn)FC0CB & 0x00ff00得到C000,然后右移8個數(shù)位得到C0(16進制的一位相當于二進制的4位),即192。

其他支持document.defaultView的可以直接用getComputedStyle獲取color。
從上面各個瀏覽器獲取顏色值的結(jié)果可知獲取的值都是RGB形式的值,所以可以直接用GetData轉(zhuǎn)換:

ret = GetData(document.defaultView.getComputedStyle(frag, null).color);

注意除了ff,如果元素沒有插入dom,用getComputedStyle是獲取不了color的,所以元素創(chuàng)建時要順便插入到body中。

在GetStep用GetColor獲得顏色值之后,再根據(jù)step就可以獲得步長了:

r colors = [], start = GetColor(start), end = GetColor(end),
    stepR = (end[0] - start[0]) / step,
    stepG = (end[1] - start[1]) / step,
    stepB = (end[2] - start[2]) / step;

再根據(jù)步長生成集合:

for(var i = 0, r = start[0], g = start[1], b = start[2]; i < step; i++){
    colors[i] = [r, g, b]; r += stepR; g += stepG; b += stepB;
}
colors[i] = end;

正確的顏色值是在0到255之間的,而且是不帶小數(shù)的,需要修正一下:

return $$A.map(colors, function(x){ return $$A.map(x, function(x){
    return Math.min(Math.max(0, Math.floor(x)), 255);
});});

程序支持設(shè)置多個顏色的連續(xù)變換:

for(var i = 0, n = len - 1; i < n; i++){
    var steps = GetStep( colors[i], colors[i+1], step );
    i < n - 1 && steps.pop();
    ret = ret.concat(steps);
}

注意的是各次變換之間要去掉重復(fù)的顏色(steps.pop())。

出處:藍色理想
責任編輯:bluehearts

上一頁 JavaScript顏色梯度和漸變效果改進 [2] 下一頁 JavaScript顏色梯度和漸變效果改進 [4]

◎進入論壇網(wǎng)頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章 更多相關(guān)鏈接
14條最佳JS代碼編寫技巧
JavaScript組件之旅:測試組件
JavaScript組件之旅:用Ant構(gòu)建組件
JavaScript圖片放大效果詳解
JS實現(xiàn)2D桌球小游戲
作者文章 更多作者文章
JavaScript 圖片滑動切換效果
JavaScript Table行定位效果
JavaScript 浮動定位提示效果
JavaScript 顏色梯度和漸變效果
JavaScript Tween算法及緩動效果
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大福“敬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:3/51個記錄/頁 轉(zhuǎn)到 頁 共5個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2