亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

canvas三角函數模擬水波效果的示例代碼

2024-08-26 00:20:48
字體:
來源:轉載
供稿:網友

最近項目中,ui設計了個水波效果的背景動畫,然而并沒有gif或svg動畫,開始試著用css實現了一下,動畫效果并不是很好,網上查了下基本都是用貝賽爾曲線實現,想起以看的各種前波形圖,于是想著用三角函數圖像初略模擬一下

一、繪制sin函數圖像

sin函數表達式如下,

y=Asin(wx+φ)+h

其中 A表示振幅,ω表示角頻率(ω=2π/T,T為函數的周期),φ表示初相,h表示圖像向y軸正方向平移的長度 ;(這里需要注意一下:h在數學學的本來是表示向上平移的,但在canvas中采用的是屏幕坐標系,即左上角為原點,h則表示向下平移);

繪制代碼如下:

(1)添加canvas標簽

<canvas id="canvas"></canvas>

(2)添加css樣式,設置canvas寬高

html,body {  padding: 0;  margin: 0;  width: 100%;  height: 100%;}canvas {  width: 100%;  height: 100%;}

(3)繪制函數圖像

var canvas = document.getElementById("canvas"),    ctx = canvas.getContext('2d'),    width = canvas.width = canvas.offsetWidth,    height = canvas.height = canvas.offsetHeight;//聲明參數var A=50,    W=1 / 50,    Q=0,    H= height / 2;//繪圖方法(function draw(){  ctx.clearRect(0, 0, width, height);//清空畫布  ctx.beginPath();                   //開始路徑  ctx.strokeStyle="#000";            //設置線條顏色  ctx.lineWidth = 1;                 //設置線條寬度  ctx.moveTo(0, height /2);          //起始點位置  for (let x = 0; x <=  width; x++) {// 繪制x對應y的     var y = A*Math.sin(W*x+Q) +H    ctx.lineTo(x, y)  }  ctx.stroke();                      //繪制路徑  ctx.closePath();                   //閉合路徑})()

這樣我們可以得到以下圖像:

canvasm,三角函數,代碼

二、為函數圖像添加動畫

上面得到的是是一個靜態的函數圖像,而我們一般見到的的波形圖或水波都是隨時間連續變化的,這里就要用到上一步中的參數相位φ,(js即代碼中的Q) ,我們將φ隨時間不斷增加或減小,即可得到不同時間的不同圖像;使用window.requestAnimationFrame實現幀動畫;

修改以上代碼為:

var canvas = document.getElementById("canvas"),    ctx = canvas.getContext('2d'),    width = canvas.width = canvas.offsetWidth,    height = canvas.height = canvas.offsetHeight;//聲明參數var A=50,    W=1 / 50,    Q=0,    H= height / 2;//繪圖方法(function draw(){  ctx.clearRect(0, 0, width, height);//清空畫布  ctx.beginPath();                   //開始路徑  ctx.strokeStyle="#000";            //設置線條顏色  ctx.lineWidth = 1;                 //設置線條寬度  ctx.moveTo(0, height /2);          //起始點位置  for (let x = 0; x <=  width; x++) {// 繪制x對應y的     var y = A*Math.sin(W*x+Q) +H    ctx.lineTo(x, y)  }  ctx.stroke();                      //繪制路徑  ctx.closePath();                   //閉合路徑})()

效果如下(渣渣截圖軟件):

canvasm,三角函數,代碼

三、繪制完整填充路徑

以上路徑雖有閉合,但卻不滿足我們需要填充的部分,直接填充效果如下:

canvasm,三角函數,代碼

完整填充路徑應如圖所示:

canvasm,三角函數,代碼

閉合路徑后創建一個漸變顏色,作為填充顏色,代碼如下:

var lingrad = ctx.createLinearGradient(0,0,width,0); lingrad.addColorStop(0, 'rgba(0,186,128,0.8)'); lingrad.addColorStop(1, 'rgba(111,224,195,1)');   (function draw(){  window.requestAnimationFrame(draw);  ctx.clearRect(0, 0, width, height);  ctx.beginPath();  ctx.strokeStyle="#000";  ctx.fillStyle = lingrad;  ctx.lineWidth = 1;  ctx.moveTo(0, height /2);    Q+=speed;  for (let x = 0; x <=  width; x++) {    var y = A*Math.sin(W*x+Q) +H;    ctx.lineTo(x, y);  }  ctx.lineTo(width, height);  ctx.lineTo(0, height);  ctx.fill();  ctx.closePath();})()

效果如下:

canvasm,三角函數,代碼

四、完善水波動畫

1、首先可以對上面波形疊加一個頻率更高的波形,使波形無規矩

var s = 0.1*Math.sin(x/150)+1;var y = A*Math.sin(W*x+Q) +H;y=y*s;

2、再添加一個相位變化不同的波形,其漸變填充與上一個漸變方向相反使其形成相互重疊的陰影效果;并設置路徑重疊效果globalCompositeOperation; 

var canvas = document.getElementById("canvas"),   ctx = canvas.getContext('2d'),   width = canvas.width = canvas.offsetWidth,   height = canvas.height = canvas.offsetHeight;var A=30,   W=1 /200,   Q=0,   H= height / 2;var A2=30,   W2=1/300,   Q2=0,   H2= height / 2;var speed=-0.01;var speed2=-0.02;var lingrad = ctx.createLinearGradient(0,0,width,0);lingrad.addColorStop(0, 'rgba(0,186,128,0.8)');lingrad.addColorStop(1, 'rgba(111,224,195,1)');  var lingrad2 = ctx.createLinearGradient(0,0,width,0);lingrad2.addColorStop(0,'rgba(111,224,195,1)');lingrad2.addColorStop(1, 'rgba(0,186,128,0.8)'); (function draw(){  window.requestAnimationFrame(draw);  ctx.clearRect(0, 0, width, height);  ctx.beginPath();  ctx.fillStyle = lingrad;  ctx.moveTo(0, height /2);  //繪制第一個波形  Q+=speed;  for (let x = 0; x <=  width; x++) {    var s = 0.1*Math.sin(x/150)+1;    var y = A*Math.sin(W*x+Q) +H;    y=y*s;    ctx.lineTo(x, y);  }  ctx.lineTo(width, height);  ctx.lineTo(0, height);  ctx.fill();  ctx.closePath()  //設置重疊效果  ctx.globalCompositeOperation = "destination-over"  //繪制第二個波形  ctx.beginPath();  ctx.fillStyle = lingrad2;  Q2+=speed2;  for (let x = 0; x < width; x++) {    var y = A2*Math.sin(x*W2+Q2) +H2;    ctx.lineTo(x, y);  }  ctx.lineTo(width,height);  ctx.lineTo(0,height);  ctx.fill()  ctx.closePath();})()

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕av一区中文字幕天堂| 久久久91精品| 欧美黑人极品猛少妇色xxxxx| 国产自产女人91一区在线观看| 国产精品亚洲第一区| 日韩欧美在线视频日韩欧美在线视频| 日韩亚洲欧美中文在线| 久久久久亚洲精品国产| 国产成人精品久久久| 日本一区二区在线免费播放| 欧美成人一区二区三区电影| 亚洲精品99999| 国产午夜精品免费一区二区三区| 亚洲福利视频在线| 久久久这里只有精品视频| 国产一区二区三区三区在线观看| 一区二区三区视频免费在线观看| 96pao国产成视频永久免费| 性欧美亚洲xxxx乳在线观看| 欧美与欧洲交xxxx免费观看| 视频在线观看99| 精品欧美国产一区二区三区| 欧美亚洲在线视频| 日韩精品黄色网| 国产原创欧美精品| 日韩欧美在线免费| 亚洲精品国产精品乱码不99按摩| 久久久精品亚洲| 国产成人精品优优av| 久久97久久97精品免视看| 欧美日韩国内自拍| 亚洲毛片在线观看.| 欧美在线视频一区| 91久久国产精品91久久性色| 欧美精品一区二区三区国产精品| 国产福利精品在线| 久久91亚洲人成电影网站| 亚洲欧洲一区二区三区久久| 成人淫片在线看| 欧美日韩国产麻豆| 日本免费在线精品| 久久久精品在线观看| 国产91热爆ts人妖在线| 久久久久久久亚洲精品| 国产成人在线一区二区| 国产伦精品一区二区三区精品视频| 国产成人黄色av| 中文字幕不卡av| 日本久久亚洲电影| 久久久久久久久久久人体| 国产免费一区二区三区在线观看| 亚洲成人久久网| 亚洲一区二区三区乱码aⅴ| www.99久久热国产日韩欧美.com| 精品丝袜一区二区三区| 亚洲综合中文字幕在线观看| 国产精品久久久999| 欧美激情欧美激情在线五月| 中文字幕精品—区二区| 欧美一区二区影院| 欧美日韩亚洲视频| 亚洲国产精品久久久久久| 亚洲一区二区久久久久久久| 68精品国产免费久久久久久婷婷| 精品人伦一区二区三区蜜桃网站| 久久久精品免费| 日韩精品极品在线观看播放免费视频| 欧美性视频网站| 国产在线视频2019最新视频| 亚洲人成在线观看网站高清| 成人免费自拍视频| 亚洲人成网站777色婷婷| 国产亚洲视频中文字幕视频| 亚洲欧美日韩成人| 欧美日韩免费在线观看| 日韩亚洲在线观看| 国产欧美精品久久久| 热久久美女精品天天吊色| 欧美日产国产成人免费图片| 1769国内精品视频在线播放| 夜夜躁日日躁狠狠久久88av| 亚洲а∨天堂久久精品喷水| 久久久亚洲网站| 亚洲大胆人体在线| 日韩免费在线免费观看| 九九久久久久久久久激情| 久久综合伊人77777尤物| 亚洲护士老师的毛茸茸最新章节| 不用播放器成人网| 国产第一区电影| 亚洲精品影视在线观看| 色噜噜狠狠色综合网图区| 日韩精品视频免费在线观看| 亚洲综合成人婷婷小说| 国产亚洲视频中文字幕视频| 北条麻妃99精品青青久久| 国语对白做受69| 日韩av电影中文字幕| 国产精品亚洲片夜色在线| 91久久综合亚洲鲁鲁五月天| 亚洲精品日韩在线| 亚洲美腿欧美激情另类| 欧美激情va永久在线播放| 欧日韩不卡在线视频| 精品久久国产精品| 成人激情视频网| 欧美国产高跟鞋裸体秀xxxhd| 亚洲男人天堂九九视频| 国产一区二区三区视频在线观看| 热99久久精品| 狠狠躁夜夜躁人人爽天天天天97| 国产精品自拍小视频| 欧美二区在线播放| 国产精品久久久久久影视| 国产欧美久久一区二区| 日韩av在线免费| 久久人体大胆视频| 美女少妇精品视频| 97超级碰碰碰| 久久久久国产精品免费网站| 欧美激情一区二区三区久久久| 精品香蕉在线观看视频一| 亚洲一区二区三区四区在线播放| 国产成人精品999| 国产精品视频久| www.亚洲一二| 一区二区欧美亚洲| 69视频在线播放| 福利一区福利二区微拍刺激| 色婷婷综合久久久久中文字幕1| 欧美国产日韩在线| 久久久久久久久久久av| 久久免费少妇高潮久久精品99| 日韩经典中文字幕| 4438全国亚洲精品在线观看视频| 久久久久久成人精品| 欧美激情综合亚洲一二区| 亚洲人精品午夜在线观看| 91九色精品视频| 最近2019年日本中文免费字幕| 亚洲欧美国产va在线影院| 亚洲日本欧美日韩高观看| 国产欧美久久久久久| 懂色aⅴ精品一区二区三区蜜月| 欧美理论电影在线观看| 一区二区三区动漫| 国产97色在线|日韩| 精品久久久久久久久久久久久久| 777777777亚洲妇女| 亚洲电影免费观看高清完整版在线观看| 欧美丰满少妇xxxx| 久久精品视频在线观看| 欧美日韩激情视频| 91中文在线视频| 成人av在线天堂| 国产福利精品av综合导导航| 欧美国产日韩中文字幕在线| 亚洲天堂av综合网| 国产精品入口免费视频一| 亚洲欧洲第一视频| 亚洲欧美综合v| 国产成人福利夜色影视| 最近2019年好看中文字幕视频| 亚洲精品国产精品自产a区红杏吧|