校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > canvas三角函數模擬水波效果的示例代碼

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

熱門標簽:中紳電銷智能機器人 跟電銷機器人做同事 漳州人工外呼系統排名 鄭州電銷外呼系統違法嗎 濟南辦理400電話 ai電銷機器人連接網關 農村住宅地圖標注 威海營銷外呼系統招商 鶴壁手機自動外呼系統怎么安裝

最近項目中,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();                   //閉合路徑
})()

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

二、為函數圖像添加動畫

上面得到的是是一個靜態的函數圖像,而我們一般見到的的波形圖或水波都是隨時間連續變化的,這里就要用到上一步中的參數相位φ,(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();                   //閉合路徑
})()

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

三、繪制完整填充路徑

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

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

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

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();
})()

效果如下:

四、完善水波動畫

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();

})()

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

標簽:蘇州 甘南 營口 咸陽 文山 惠州 紅河 萍鄉

巨人網絡通訊聲明:本文標題《canvas三角函數模擬水波效果的示例代碼》,本文關鍵詞  canvas,三角函數,模擬,水波,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas三角函數模擬水波效果的示例代碼》相關的同類信息!
  • 本頁收集關于canvas三角函數模擬水波效果的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    97精品视频在线观看自产线路二| 国产精品一区二区在线播放| 一本色道久久综合精品竹菊| 中文字幕乱码久久午夜不卡| 国产福利一区在线| 久久久亚洲精品石原莉奈| 狠狠久久亚洲欧美| 精品日韩欧美在线| 黄页网站大全一区二区| 久久青草欧美一区二区三区| 国产精品一区2区| 午夜视频久久久久久| 国产高清在线精品| 国产精品狼人久久影院观看方式| 天天综合网 天天综合色| 欧美日韩情趣电影| 丝袜美腿亚洲综合| 精品三级在线看| 国产精品夜夜爽| 久久先锋资源网| 国产91丝袜在线播放| 国产精品狼人久久影院观看方式| 色综合网站在线| 亚洲风情在线资源站| 这里只有精品视频在线观看| 美女一区二区三区在线观看| 成人免费电影视频| 波多野结衣的一区二区三区| 中文字幕色av一区二区三区| 欧美怡红院视频| 日韩不卡一二三区| xfplay精品久久| av中文字幕一区| 亚洲一区二区欧美日韩 | 夜色激情一区二区| 欧美片网站yy| 国产中文一区二区三区| 中文字幕国产精品一区二区| 99久久精品免费| 亚洲综合免费观看高清完整版 | 丝袜脚交一区二区| 日韩欧美一级片| 国产高清不卡二三区| 亚洲美女区一区| 56国语精品自产拍在线观看| 国产一区欧美二区| 中文字幕一区二区三区av| 欧美日韩午夜精品| 国产在线视视频有精品| 亚洲欧美另类久久久精品2019| 欧美va在线播放| av一区二区三区在线| 一区二区三区.www| 精品国产污污免费网站入口| www.欧美色图| 欧美aaaaa成人免费观看视频| 91免费在线看| 午夜视频一区二区三区| 国产三级精品视频| 欧美日韩久久一区二区| 国产成人综合亚洲91猫咪| 亚洲一区二区成人在线观看| 精品sm在线观看| 欧美午夜精品免费| 国产福利精品导航| 亚洲成av人片一区二区三区| 国产午夜亚洲精品理论片色戒| 欧美在线免费观看亚洲| 国产精品18久久久久| 亚洲成人先锋电影| 91在线视频播放地址| 亚洲欧美在线高清| 日韩视频在线你懂得| 91在线云播放| 国产伦精一区二区三区| 香蕉成人伊视频在线观看| 中文字幕第一页久久| 这里只有精品视频在线观看| 91麻豆国产福利在线观看| 国内精品免费**视频| 视频一区中文字幕国产| 国产精品美女久久久久久久久| 日韩视频永久免费| 欧洲国产伦久久久久久久| 懂色av一区二区在线播放| 日本中文一区二区三区| 一区二区三区中文在线观看| 国产女主播在线一区二区| 日韩一区二区三区四区| 91国产成人在线| a4yy欧美一区二区三区| 中文字幕一区二区三区四区| 欧美精品一区二区高清在线观看| 欧美性一二三区| 国产精品久久久久久户外露出| 国产一区二区美女| 丝袜诱惑亚洲看片| 一区二区三区波多野结衣在线观看| 国产欧美一区二区在线| 精品少妇一区二区三区免费观看 | 日韩丝袜美女视频| 欧美日韩一级二级| 亚洲欧洲精品成人久久奇米网| 91福利资源站| 99精品久久免费看蜜臀剧情介绍| 国产一区二区在线观看免费| 国产精品网站在线| 欧美性猛交xxxx乱大交退制版| 99久久婷婷国产| 成人午夜精品在线| 国产精品一级片| 精品一区二区三区免费| 免费观看在线色综合| 五月婷婷激情综合网| 亚洲国产精品久久人人爱蜜臀| 日韩美女啊v在线免费观看| 国产精品不卡一区二区三区| 国产精品久久久久久久久晋中 | ●精品国产综合乱码久久久久| 国产亚洲精品中文字幕| 久久亚洲捆绑美女| 亚洲国产日韩一级| 成人综合在线观看| 国产精品久久久久aaaa樱花| 欧美视频自拍偷拍| 色综合久久综合中文综合网| www.亚洲精品| 成人黄色小视频在线观看| 国产不卡免费视频| 国产精品123| 成人免费黄色在线| 99久久99久久免费精品蜜臀| 91在线精品秘密一区二区| 成人午夜精品在线| 日本亚洲电影天堂| 日本一区免费视频| 国产精品麻豆欧美日韩ww| 国产精品久久午夜夜伦鲁鲁| 亚洲欧洲精品成人久久奇米网| 亚洲色图视频网| 一区二区不卡在线播放| 亚洲电影在线播放| 日韩成人精品在线观看| 麻豆精品在线播放| 国产伦理精品不卡| 不卡的av网站| 在线看不卡av| 555www色欧美视频| 成人黄页在线观看| 精品影视av免费| 国产精品综合久久| 成人涩涩免费视频| 色一情一乱一乱一91av| 欧美色老头old∨ideo| 欧美一级理论片| 国产日韩欧美精品在线| 在线播放91灌醉迷j高跟美女 | 美女视频黄免费的久久| 亚洲人成伊人成综合网小说| 亚洲一区在线看| 肉色丝袜一区二区| 国产麻豆成人精品| 99国产一区二区三精品乱码| 欧美在线视频你懂得| 91精品久久久久久蜜臀| 天使萌一区二区三区免费观看| 一区二区三区在线视频免费| 五月天激情综合网| 国产午夜精品福利| 日本亚洲三级在线| 麻豆91在线播放| 国产99精品国产| 欧美性受极品xxxx喷水| 欧美tickle裸体挠脚心vk| 国产精品毛片高清在线完整版 | 国产成人在线观看| 国产一区二区在线影院| 色婷婷综合激情| 欧美一区二区三区在线| 国产精品女主播在线观看| 亚洲成人黄色影院| 国产乱色国产精品免费视频| 色综合咪咪久久| 欧美v日韩v国产v| 亚洲欧美日韩国产手机在线| 日本成人超碰在线观看| 亚洲一区二区三区自拍| 狠狠色狠狠色综合| 欧美在线你懂的| 欧美探花视频资源| 久久综合资源网| 日韩午夜av一区| 国产精品免费看片| 欧美在线视频不卡| 日本午夜一本久久久综合| 91免费在线看| 欧美日产国产精品| 国产精品看片你懂得| 久久精品国产在热久久| 色综合天天综合在线视频|