日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript如何使用插值實現圖像漸變

瀏覽:80日期:2023-10-23 09:41:03

描述由一個圖形變化為另一個圖形過程中的各個中間圖形,稱為漸變圖形。可以利用插值算法求得各個漸變圖形。

設在源圖形和目標圖形上各取M個對應坐標點,并分別保存到數組中,源圖形用數組SX[M]和SY[M]保存M個坐標點(sx,sy),目標圖形用數組DX[M]和DY[M]保存M個坐標點(dx,dy)。若需生成源圖形變換到目標圖形中的N-1個漸變圖形,采用簡單的線性插值可以編寫如下的二重循環:

for (k=1;k<N;k++) for (i=0;i<M;i++) { x=(dx[i]-sx[i])/N*k+sx[i]; y=(dy[i]-sy[i])/N*k+sy[i]; // 按求得的插值坐標點繪制漸變圖形 }

1.六瓣花朵漸變為圓

六瓣花朵的笛卡爾坐標方程式設定為:

t=r1*(1+sin(18*θ)/5) *(0.5+Math.sin(6*θ)/2);

x=t*cos(θ);

y=t* sin(θ); (0≤θ≤2π)

圓的笛卡爾坐標方程式為:

x=r*cos(θ)

y=r*sin(θ) (0≤θ≤2π)

在六瓣花朵和圓上分別取128個點,然后利用簡單的線性插值繪制中間24個漸變圖形。編寫如下的HTML代碼。

<!DOCTYPE html><head><title>六瓣花朵漸變為圓</title><script type='text/javascript'>function draw(id){var canvas = document.getElementById(id);if (canvas == null)return false;var context = canvas.getContext(’2d’);context.fillStyle = '#EEEEFF';context.fillRect(0, 0, 200, 200);context.strokeStyle = 'red';context.lineWidth = 1;var dig = Math.PI / 64;var x1 = new Array(129);var y1 = new Array(129);var x2 = new Array(129);var y2 = new Array(129);for (var i = 0; i <= 128; i++){d = 50 * (1 + Math.sin(18 * i * dig) /5);t = d * (0.5 + Math.sin(6 * i * dig) /2);x1[i] = t * Math.cos(i * dig);y1[i] = t * Math.sin(i * dig);x2[i] = 80 * Math.cos(i * dig);y2[i] = 80 * Math.sin(i * dig);}context.beginPath();for (n = 0; n <= 25; n++)for (i = 0; i <= 128; i++){x = (x2[i] - x1[i]) / 25 * n + x1[i] +100;y = (y2[i] - y1[i]) / 25 * n + y1[i] +100;if (i == 0){context.moveTo(x, y);bx = x;by = y;} elsecontext.lineTo(x, y);}context.lineTo(bx, by);context.closePath();context.stroke();}</script></head><body onload='draw(’myCanvas’);'><canvas height='200'></canvas></body></html>

將上述HTML代碼保存到一個html文本文件中,再在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在畫布中繪制出從六瓣花朵漸變為圓的圖案,如圖1所示。

JavaScript如何使用插值實現圖像漸變

圖1 六瓣花朵漸變為圓

2.圓漸變為花朵

我們將圖1圖形中的圓漸變為六瓣花朵的過程動態展示出來。編寫的HTML文件內容如下。

<!DOCTYPE><html><head><title>圓漸變為花朵</title></head><body><canvas height='200'style='border:3px double #996633;'></canvas><script type='text/javascript'>var canvas = document.getElementById(’myCanvas’);var context = canvas.getContext(’2d’);context.fillStyle = '#EEEEFF';context.fillRect(0, 0, 200, 200);context.fillStyle = 'red';var dig = Math.PI / 64;var x1 = new Array(129);var y1 = new Array(129);var x2 = new Array(129);var y2 = new Array(129);var n = 0;for (var i = 0; i <= 128; i++){d = 50 * (1 + Math.sin(18 * i * dig) /5);t = d * (0.5 + Math.sin(6 * i * dig) /2);x1[i] = t * Math.cos(i * dig);y1[i] = t * Math.sin(i * dig);x2[i] = 80 * Math.cos(i * dig);y2[i] = 80 * Math.sin(i * dig);}function draw(){context.clearRect(0, 0, 200, 200);context.beginPath();for (i = 0; i <= 128; i++){x = (x1[i] - x2[i]) / 25 * n + x2[i] +100;y = (y1[i] - y2[i]) / 25 * n + y2[i] +100;if (i == 0){context.moveTo(x, y);bx = x;by = y;} elsecontext.lineTo(x, y);}context.lineTo(bx, by);context.stroke();n = n + 1;if (n > 25) n = 0;context.fill();}window.setInterval(’draw()’, 300);</script></body></html>

將上述HTML代碼保存到一個html文本文件中,再在瀏覽器中打開包含這段HTML代碼的html文件,可以在畫布中看到從圓漸變為六瓣花朵的動畫過程,如圖2所示。

JavaScript如何使用插值實現圖像漸變

圖2 從圓漸變為六瓣花朵

3.六瓣花朵漸變為正方形

仿照上面的思路,設計程序將六瓣花朵漸變為正方形,且漸變計算時采用對數函數。編寫如下的HTML代碼。

<!DOCTYPE html><head><title>六瓣花朵漸變為正方形</title><script type='text/javascript'>function draw(id){var canvas = document.getElementById(id);if (canvas == null)return false;var context = canvas.getContext(’2d’);context.fillStyle = '#EEEEDD';context.fillRect(0, 0, 300, 300);context.strokeStyle = 'red';context.lineWidth = 1;var dig = Math.PI / 60;var x1 = new Array(120);var y1 = new Array(120);var x2 = new Array(120);var y2 = new Array(120);// 生成花瓣基本數據,坐標保存在(x1[i],y1[i])中var petalNum = 6; // 花瓣數for (var i = 0; i < 120; i++){d = 50 * (1 + Math.sin(petalNum * (i * dig + Math.PI / 4)));x1[i] = d * Math.cos(i * dig + Math.PI / 4);y1[i] = -d * Math.sin(i * dig +Math.PI / 4);}// 生成多邊形基本數據,坐標保存在(x2[i],y2[i])中var r = 150;var sideNum = 4; // 正多邊形邊數var k = 120 / sideNum;dig = Math.PI / sideNum;var dd = 2 * r * Math.sin(dig) / k;for (i = 0; i < sideNum; i++){aa = 2 * i * dig + 3 * Math.PI / 4;x0 = r * Math.sin(aa);y0 = r * Math.cos(aa);for (j = 0; j < k; j++){x2[i * k + j] = x0 + j * dd * Math.sin(aa + Math.PI / 2 + Math.PI /sideNum);y2[i * k + j] = y0 + j * dd * Math.cos(aa + Math.PI / 2 + Math.PI /sideNum);}}context.beginPath();// 按對數規律進行圖案漸變for (n = 0; n <= 25; n++){for (i = 0; i < 120; i++){x = (x2[i] - x1[i]) / Math.log(25) *Math.log(n) + x1[i] + 150;y = (y2[i] - y1[i]) / Math.log(25) *Math.log(n) + y1[i] + 150;if (i == 0){context.moveTo(x, y);bx = x;by = y;} elsecontext.lineTo(x, y);}context.lineTo(bx, by);}context.closePath();context.stroke();}</script></head><body onload='draw(’myCanvas’);'><canvas height='320'></canvas></body></html>

將上述HTML代碼保存到一個html文本文件中,再在瀏覽器中打開包含這段HTML代碼的html文件,可以看到在畫布中繪制出從六瓣花朵漸變為正方形的圖案,如圖3所示。

JavaScript如何使用插值實現圖像漸變

圖3 從六瓣花朵漸變為正方形

將繪制圖3的HTML程序中的花瓣數設置為5,正多邊形邊數也設置為5,即修改語句“var petalNum=6;”為“var petalNum=5;”,修改語句“var sideNum=4;”為“var sideNum=5;”,則在畫布中繪制出如圖4所示的從五瓣花朵漸變為正五邊形的圖案。

JavaScript如何使用插值實現圖像漸變

圖4 從五瓣花朵漸變為正五邊形

4.正五邊形漸變為五瓣花朵

我們將圖4圖形中的正五邊形漸變為五瓣花朵的過程動態展示出來。編寫的HTML文件內容如下。

<!DOCTYPE><html><head><title>正五邊形漸變為五瓣花朵</title></head><body><canvas height='300'style='border:3px double #996633;'></canvas><script type='text/javascript'>var canvas = document.getElementById(’myCanvas’);var context = canvas.getContext(’2d’);context.fillStyle = '#EEEEFF';context.fillRect(0, 0, 300, 300);context.fillStyle = 'red';var dig = Math.PI / 60;var x1 = new Array(120);var y1 = new Array(120);var x2 = new Array(120);var y2 = new Array(120);// 生成花瓣基本數據,坐標保存在(x1[i],y1[i])中var petalNum = 5;for (var i = 0; i < 120; i++){d = 50 * (1 + Math.sin(petalNum * (i *dig + Math.PI / 4)));x1[i] = d * Math.cos(i * dig + Math.PI /4);y1[i] = -d * Math.sin(i * dig + Math.PI / 4);}// 生成多邊形基本數據,坐標保存在(x2[i],y2[i])中var r = 150;var sideNum = 5;var k = 120 / sideNum;dig = Math.PI / sideNum;var dd = 2 * r * Math.sin(dig) / k;for (i = 0; i < sideNum; i++){aa = 2 * i * dig + 3 * Math.PI / 4;x0 = r * Math.sin(aa);y0 = r * Math.cos(aa);for (j = 0; j < k; j++){x2[i * k + j] = x0 + j * dd * Math.sin(aa + Math.PI / 2 + Math.PI /sideNum);y2[i * k + j] = y0 + j * dd * Math.cos(aa + Math.PI / 2 + Math.PI /sideNum);}}var n = 0;function draw(){context.clearRect(0, 0, 300, 300);context.beginPath();for (i = 0; i < 120; i++){x = (x1[i] - x2[i]) / Math.log(25) *Math.log(n) + x2[i] + 150;y = (y1[i] - y2[i]) / Math.log(25) *Math.log(n) + y2[i] + 150;if (i == 0){context.moveTo(x, y);bx = x;by = y;} elsecontext.lineTo(x, y);}context.lineTo(bx, by);context.closePath();context.stroke();n = n + 1;if (n > 25) n = 0;context.fill();}window.setInterval(’draw()’, 400);</script></body></html>

將上述HTML代碼保存到一個html文本文件中,再在瀏覽器中打開包含這段HTML代碼的html文件,可以在畫布中看到從正五邊形漸變為五瓣花朵的動畫過程,如圖5所示。

JavaScript如何使用插值實現圖像漸變

圖5 正五邊形漸變為五瓣花朵

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品久久精品| 日本91福利区| 精品国产美女a久久9999| 国产精品tv| 国产劲爆久久| 美女久久99| 欧美国产一级| 欧美亚洲激情| 在线亚洲欧美| 亚洲精品字幕| 国产精区一区二区| 国产一区精品福利| 高清不卡亚洲| 欧美日韩国产探花| 亚洲综合专区| 一本综合精品| 国产精品扒开腿做爽爽爽软件| 久久精品五月| 国产精品字幕| 欧美特黄一级| 日韩手机在线| 国产精品视频一区二区三区四蜜臂| 精品免费在线| 国产综合亚洲精品一区二| 性色av一区二区怡红| 中文在线资源| 最新日韩av| 欧美一级全黄| 国产在线看片免费视频在线观看| 在线日韩电影| 国产亚洲网站| 国产精品99精品一区二区三区∴ | 日韩有码av| 久久精品福利| 欧美日韩国产在线观看网站 | 久久国产亚洲精品| 蜜桃一区二区三区在线| 久久爱www.| 国产在线日韩| 91精品国产自产在线丝袜啪| 精品国产乱码久久久| 91精品国产91久久久久久黑人| 日韩中文欧美在线| 麻豆精品国产91久久久久久| 精品欧美激情在线观看| 午夜久久av | 99久久久久久中文字幕一区| 免费日韩一区二区三区| 波多视频一区| 中文字幕中文字幕精品| 久久精品资源| 久久高清一区| 精品视频在线观看网站| 亚洲一区二区成人| 久久国产人妖系列| 婷婷成人在线| 国产精品一区高清| 国产精品呻吟| 国产在线一区不卡| 久久亚洲欧洲| 亚洲黄色免费看| 日本欧美久久久久免费播放网| 色爱综合av| 天堂精品久久久久| 日韩在线欧美| 青青国产精品| 亚洲欧美日韩高清在线| 国产精品密蕾丝视频下载| 91高清一区| 精品欠久久久中文字幕加勒比| 免费成人av在线播放| 在线看片国产福利你懂的| 久久精品欧美一区| 久久免费影院| 亚洲一区av| 亚洲第一区色| 国产成人黄色| 97久久超碰| 亚洲成人国产| 久久影视三级福利片| 中文字幕日韩亚洲| 日韩电影在线视频| 国产精品1区在线| 蜜臀av一区二区在线免费观看| 日本精品在线中文字幕| 国产精品久久久久77777丨| 国产一区导航| 久久久夜精品| 精品免费av一区二区三区| 日韩三区四区| 亚洲欧美日韩综合国产aⅴ| 日韩毛片在线| 国产精品成人a在线观看| 日本免费新一区视频| 美女久久网站| 免费精品国产的网站免费观看| www在线观看黄色| 麻豆精品在线观看| 国产精品一区二区三区四区在线观看 | 高清精品久久| 欧美一区影院| 只有精品亚洲| 日韩中文字幕av电影| 99久久夜色精品国产亚洲1000部| 精品国产亚洲一区二区三区大结局| 亚洲人成毛片在线播放女女| 久久精品高清| 正在播放日韩精品| 精品资源在线| 国产精品va| 欧美日本久久| 日本va欧美va瓶| 日韩欧美高清一区二区三区| 亚洲精品乱码| 天堂久久av| 一级成人国产| 一区二区高清| 蜜臀91精品一区二区三区| 亚洲免费播放| 最新日韩欧美| 在线亚洲自拍| 亚洲丝袜美腿一区| 日韩精品久久理论片| 色狠狠一区二区三区| 亚洲精品看片| 欧美日韩91| 国产精品三p一区二区| 国产精品欧美一区二区三区不卡| 国产亚洲人成a在线v网站| 国产视频一区二| 国产美女久久| 国产高清亚洲| 麻豆视频在线看| 成人片免费看| 欧美+亚洲+精品+三区| 波多视频一区| 人人爱人人干婷婷丁香亚洲| 日韩国产精品久久久久久亚洲| 日韩高清二区| 国产精久久一区二区| 欧美1区二区| 9999国产精品| 免费久久精品| 亚洲欧美日韩综合国产aⅴ| 综合激情网站| 日韩三区四区| 久久成人福利| 欧美日韩免费观看视频| 国产欧美综合一区二区三区| 久久91导航| 日本一区二区三区视频在线看| 欧美黑人巨大videos精品| 国产在线视频欧美一区| 欧美经典一区| 国产v日韩v欧美v| 亚洲成人av观看| 欧美在线网站| 亚洲欧洲av| 国产日韩亚洲| 老司机免费视频一区二区三区| 欧美精品一卡| 欧美日韩国产综合网| 中文一区一区三区免费在线观 | 四虎成人精品一区二区免费网站| 99亚洲精品| 国产亚洲一区| 国产精久久一区二区| 加勒比视频一区| 成人午夜网址| 久久国产影院| 国产亚洲网站| 亚洲精品裸体| 麻豆精品av| 久久国产欧美| 亚洲一区二区免费看| 国产精品九九| 欧美sm一区| 国产二区精品| 欧美午夜不卡影院在线观看完整版免费| 国产欧美一区二区三区米奇| 国产激情久久| 欧美经典一区| 欧美综合另类| 亚洲一二三区视频| 国产精品三p一区二区| 91偷拍一区二区三区精品| 91看片一区| 美日韩精品视频| 日本视频中文字幕一区二区三区| 国内自拍视频一区二区三区| 丝袜诱惑制服诱惑色一区在线观看 | 国产精品一区二区三区av麻| 久久中文亚洲字幕| 日韩精品中文字幕吗一区二区 | 亚洲欧洲美洲国产香蕉| 欧美成a人国产精品高清乱码在线观看片在线观看久| 好吊视频一区二区三区四区| 精品久久久中文字幕| 亚洲精品无播放器在线播放| 久久久天天操|