成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識(shí)庫 > canvas粒子動(dòng)畫背景的實(shí)現(xiàn)示例

canvas粒子動(dòng)畫背景的實(shí)現(xiàn)示例

熱門標(biāo)簽:鄭州電銷外呼系統(tǒng)違法嗎 ai電銷機(jī)器人連接網(wǎng)關(guān) 跟電銷機(jī)器人做同事 中紳電銷智能機(jī)器人 農(nóng)村住宅地圖標(biāo)注 濟(jì)南辦理400電話 威海營銷外呼系統(tǒng)招商 漳州人工外呼系統(tǒng)排名 鶴壁手機(jī)自動(dòng)外呼系統(tǒng)怎么安裝

效果 :)

不帶連線效果:

帶連線的效果:

教程

要實(shí)現(xiàn)這樣的效果其實(shí)很簡單,大概分為這么幾個(gè)步驟:

創(chuàng)建canvas

首先需要在需要展示粒子背景的父元素中創(chuàng)建一個(gè)canvas標(biāo)簽, 指定widthheight, 在我們生成隨機(jī)點(diǎn)坐標(biāo)的時(shí)候需要用widthheight來做參照。widthheight等于父元素的寬和高。

// 假如父元素是body
const ele = document.body;
const canvas = document.createElement('canvas');
canvas.width = ele.clientWidth;
canvas.height = ele.clientHeight;
// 將canvas標(biāo)簽插入
ele.appendChild(canvas);

隨機(jī)生成一定數(shù)量的點(diǎn)坐標(biāo)信息

widthheight做參照隨機(jī)生成一定數(shù)量的點(diǎn)坐標(biāo)信息,包含x, y, rateX(點(diǎn)在X軸的移動(dòng)速率), rateY(點(diǎn)在Y軸移動(dòng)的速率), rateXrateY決定了點(diǎn)的運(yùn)動(dòng)軌跡。

const points = [];
// 隨機(jī)生成點(diǎn)的坐標(biāo),需指定radius的最大值
function getPoint(radius) {
  const x = Math.ceil(Math.random() * this.width), // 粒子的x坐標(biāo)
    y = Math.ceil(Math.random() * this.height), // 粒子的y坐標(biāo)
    r = +(Math.random() * this.radius).toFixed(4), // 粒子的半徑
    rateX = +(Math.random() * 2 - 1).toFixed(4), // 粒子在x方向運(yùn)動(dòng)的速率
    rateY = +(Math.random() * 2 - 1).toFixed(4); // 粒子在y方向運(yùn)動(dòng)的速率

  return { x, y, r, rateX, rateY };
}

// 隨機(jī)生成100個(gè)點(diǎn)的坐標(biāo)信息
for (let i = 0; i < 100; i++) {
  points.push(this.getPoint());
}

將生成的點(diǎn)數(shù)組畫到canvas上

function drawPoints() {
  points.forEach((item, i) => {
    ctx.beginPath();
    ctx.arc(item.x, item.y, item.r, 0, Math.PI*2, false);
    ctx.fillStyle = '#fff';
    ctx.fill();
    // 根據(jù)rateX和rateY移動(dòng)點(diǎn)的坐標(biāo)
    if(item.x > 0 && item.x < width && item.y > 0 && item.y < height) {
      item.x += item.rateX * rate;
      item.y += item.rateY * rate;
    } else {
      // 如果粒子運(yùn)動(dòng)超出了邊界,將這個(gè)粒子去除,同時(shí)重新生成一個(gè)新點(diǎn)。
      points.splice(i, 1);
      points.push(getPoint(radius));
    }
  });
}

畫線

遍歷點(diǎn)數(shù)組,兩兩比較點(diǎn)坐標(biāo),如果兩點(diǎn)之間距離小于某個(gè)值,在兩個(gè)點(diǎn)之間畫一條直線,lineWidth隨兩點(diǎn)之間距離改變,距離越大,線越細(xì)。

// 計(jì)算兩點(diǎn)之間的距離
function dis(x1, y1, x2, y2) {
  var disX = Math.abs(x1 - x2),
    disY = Math.abs(y1 - y2);

  return Math.sqrt(disX * disX + disY * disY);
}

function drawLines() {
  const len = points.length;
  //對(duì)圓心坐標(biāo)進(jìn)行兩兩判斷
  for(let i = 0; i < len; i++) {
    for(let j = len - 1; j >= 0; j--) {
      const x1 = points[i].x,
        y1 = points[i].y,
        x2 = points[j].x,
        y2 = points[j].y,
        disPoint = dis(x1, y1, x2, y2);

      // 如果兩點(diǎn)之間距離小于150,畫線
      if(disPoint <= 150) {
        ctx.beginPath();
        ctx.moveTo(x1, y1);
        ctx.lineTo(x2, y2);
        ctx.strokeStyle = '#fff';
        //兩點(diǎn)之間距離越大,線越細(xì),反之亦然
        ctx.lineWidth = 1 - disPoint / distance;
        ctx.stroke();
      }
    }
  }
}

動(dòng)畫

使用requestAnimationFrame循環(huán)調(diào)用draw方法(draw方法里包含畫點(diǎn)和畫線),同時(shí)在draw的時(shí)候根據(jù)rateXrateY來改動(dòng)點(diǎn)的位置。

// 調(diào)用draw函數(shù)開啟動(dòng)畫
(function draw() {
  ctx.clearRect(0, 0, width, height);
  drawPoints();
  // 如果不需要畫線,取消下面這行代碼即可。
  drawLines();
  window.requestAnimationFrame(draw);
}());

完整代碼請(qǐng)看: https://github.com/PengJiyuan/particle-bg

我的Github:https://github.com/PengJiyuan

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:咸陽 蘇州 文山 營口 紅河 惠州 甘南 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《canvas粒子動(dòng)畫背景的實(shí)現(xiàn)示例》,本文關(guān)鍵詞  canvas,粒子,動(dòng)畫,背景,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《canvas粒子動(dòng)畫背景的實(shí)現(xiàn)示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于canvas粒子動(dòng)畫背景的實(shí)現(xiàn)示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    视频一区欧美精品| 韩国无码一区二区三区精品| 国产精品久久午夜| 少妇无码av无码专区在线观看| 麻豆电影在线| 精品在线观看视频| www.91av视频.com| 久久久青草青青国产亚洲免观| 黄色片免费在线观看| 骚视频在线观看| 一级特黄a大片免费| 精品视频在线观看一区二区| 国产小视频福利在线| 欧美贵妇videos办公室| 国产精品白丝喷水在线观看| 亚洲欧美另类日本| 久久riav二区三区| 日本视频精品一区| 精品三级av| 国产三级三级三级看三级| 久久99久久99精品| 欧美日韩综合久久| 丁香花在线影院| 亚洲日本一区二区三区在线观看| 欧美精品九九99久久| 粉嫩aⅴ一区二区三区四区五区| 欧美成人免费高清视频| 欧美视频在线第一页| 在线不卡日本v二区707| 日韩在线免费高清视频| 波多野结衣视频一区二区| 亚洲天堂伊人网| 老司机精品久久| 性色av一区二区三区四区| av色综合网| 天堂av手机在线| 精品久久久久久中文字幕2017| 国产精品欧美一区喷水| 亚洲欧美日韩国产yyy| 国产网站一区二区| 国户精品久久久久久久久久久不卡| 国产亚洲一本大道中文在线| 欧美色视频一区二区三区在线观看| 国产福利短视频| 伊人成综合网站| 校园春色亚洲| 韩国19禁主播vip福利视频| 青娱乐一区二区| 亚洲黄色在线| 极品中文字幕一区| 国产麻豆视频在线观看| 国产精品伊人色| 欧美激情视频在线免费观看 欧美视频免费一| 欧美三级免费看| 男女视频在线观看免费| 国产成人亚洲综合小说区| 成人免费看黄yyy456| 国产日本欧美在线观看| 美女主播视频一区| 99精品久久99久久久久| 亚洲女优在线| 可以直接看的无码av| 粉嫩蜜臀av国产精品网站| 黄色三级电影网站| 夜夜嗨av一区二区三区| 亚洲小说春色综合另类电影| av一级亚洲| 国产hs免费高清在线观看| www四虎com| 国产精品久久国产精麻豆99网站| 偷偷要91色婷婷| 欧美视频在线视频| 欧美91福利在线观看| 无套内精的网站| 亚洲精品国产美女| 美女免费视频一区| 2018高清国产日本一道国产| 91亚洲国产成人精品性色| 天堂av在线资源| 91福利视频网站| 久久久久久综合网天天| 东京干手机福利视频| 绿色成人影院| 亚洲精品tv久久久久久久久久| 91麻豆精品国产91| 激情丁香综合五月| 亚洲高清av| 日本精品一二三区| 国产精品成人av在线| 茄子视频成人在线观看| 五月婷婷在线观看视频| 狠狠入ady亚洲精品经典电影| 国产成人亚洲综合a∨婷婷| av高清资源| 亚洲色图第一区| 国产又黄又粗又猛又爽的| 亚洲永久无码7777kkk| 黑丝美女一区二区| 中文字幕免费精品一区高清| 天天综合天天添夜夜添狠狠添| 未来日记在线观看| 白丝校花扒腿让我c| 免费黄网在线观看| 午夜视频免费看| 国产淫片免费看| 亚洲最新视频在线观看| 中文字幕在线观看视频www| 久久国产精品亚洲va麻豆| 韩国精品免费视频| 亚洲情侣在线| www在线免费观看视频| 国产91色综合久久免费分享| 污污视频网站| 香蕉视频在线观看网站| 五月婷婷综合激情网| 精品国产乱码91久久久久久网站| 中文字幕有码在线视频| 欧美绝品在线观看成人午夜影视| 国产视频一区二区视频| 天天想你在线观看完整版电影免费| 国产成人精品国内自产拍免费看| 日韩中文综合网| 国产日产精品久久久久久婷婷| 久久青青草原一区二区| 男人的天堂亚洲在线| 亚洲精品乱码久久久久久久久久久久| 在线 亚洲欧美在线综合一区| 久久黄色免费看| 免费在线观看麻豆视频| 盗摄精品av一区二区三区| 91成人网在线| 国产大片中文字幕在线观看| 欧美经典影片视频网站| a视频在线免费看| 精品卡一卡卡2卡3网站| 中文字幕在线一区| 无码粉嫩虎白一线天在线观看| 精品久久中文| 欧美一区二不卡视频| 国产精华一区二区三区| 欧美三区在线观看| 久久麻豆一区二区| 久久综合影音| 久久精品欧美一区二区三区不卡| 国产成人亚洲综合91精品| 在线播放/欧美激情| 国产精品午夜福利| 精品毛片一区二区三区| 成a人片国产精品| 色丁香婷婷综合久久| av影院在线播放| 影音av在线| 国产精品一区二区久久| 国产·精品毛片| 欧美有码在线观看视频| 女厕嘘嘘一区二区在线播放| 亚洲成人资源| 国产手机视频精品| luxu259在线中文字幕| 黄色在线观看www| 99视频在线免费| 国产日本精品| 一级黄色免费视频| 国产精品一区hongkong| 无码播放一区二区三区| 一区二区精品| 日韩国产成人无码av毛片| 国产精品av免费| 羞羞视频网站在线观看| 色婷婷亚洲一区二区三区| 精品视频在线观看网站| 亚洲精品一区二区三区中文字幕| 日韩一二三四| 国产又黄又爽视频| 麻豆疯狂做受xxxx高潮视频| 色婷婷视频在线观看| 日本免费高清视频| 黄色国产网站在线播放| 麻豆成人精品| 久久手机免费视频| 亚洲成人久久网| 黄色综合网址| 天天综合五月天| 国产综合第一页| 97热精品视频官网| 奇米网一区二区| 欧美日韩99| 久久精品国产电影| 麻豆亚洲精品| 国产伦精品一区二区三区四区视频_| 小嫩嫩12欧美| 男人通一通女人的下水道| 26uuu国产一区二区三区| 视频直播国产精品| 免费日韩精品中文字幕视频在线| 日本学生初尝黑人巨免费视频| 国产精品午夜av| av免费在线一区二区三区| 国产福利资源| 成人污版视频| 亚洲乱码国产乱码精品精软件| 欧美性猛交xxxxbbbb| 成人欧美一区二区三区在线湿哒哒| 成人国产精品一级毛片视频| 午夜精品福利一区二区蜜股av| 国产成人aaaa| 国产视频在线一区| 超薄肉色丝袜一二三| 欧美激情一区在线观看| 国产一区二三区好的| 欧美区一区二区三区| 日韩亚洲欧美中文在线| 久久激情网站| 精品人妻一区二区三区免费| 国产成人在线视频网站| 伊人久久大香线蕉无限次| 日本不卡免费高清视频| 亚洲国产一区二区三区a毛片| 国产午夜激情视频| 高清毛片在线看| 日韩精品在线视频| 亚洲成人精品一区二区| 丁香桃色午夜亚洲一区二区三区| 国产中文字幕网| 久久亚洲精品中文字幕蜜潮电影| av电影一区| 亚洲午夜视频| 国产精品福利在线观看| 国产精品久久久久久福利| 成人网18入口| 久久久久久亚洲精品中文字幕| 黄色电影网站在线观看| 国产欧美一区二区三区精品酒店| 欧美系列在线观看| 精品视频麻豆入口| 国产小视频精品| 亚洲无毛电影| 成人免费在线视频网站| 欧美日韩不卡一区二区| 国产精品视频分类| 99精品在线直播| 国偷自产av一区二区三区麻豆| 亚洲国产精品毛片| 成人精品一区二区三区免费| 91视频免费进入| 日韩av电影免费在线| 成人中文字幕电影| www在线观看免费| 国产精品私人影院| 欧美激情一区二区三区p站| av网站免费在线播放| 亚洲一区二区三区久久| 国精产品一区一区二区三区mba| 欧美free性| 久久久91麻豆精品国产一区| 18禁免费无码无遮挡不卡网站| 图片专区亚洲欧美另类| 在线视频不卡一区二区| 羞羞的视频网站| 香蕉视频免费版| 69视频在线观看免费| av在线亚洲男人的天堂| 青青青青在线| 农民人伦一区二区三区| 人人妻人人澡人人爽| 国产传媒免费在线观看| 国产伦精品一区二区三区照片| 亚洲蜜桃精久久久久久久久久久久| 91精品国产乱码久久| 亚洲国产视频二区| 亚洲精选在线视频| 久久福利视频网| 亚洲成人黄色网址| 中文字幕久久熟女蜜桃| 性综艺节目av在线播放| 91啪亚洲精品| 国产l精品国产亚洲区在线观看| 国产探花在线观看视频| 91精品国产综合久久久久久久久| 911美女片黄在线观看游戏| 高潮毛片在线观看| 亚洲人成在线免费观看| 亚洲国产精品精华液网站| 久久精品无码一区二区三区| 中文字幕在线不卡一区| 欧美激情综合五月色丁香小说| xxxx在线视频| 国语对白中文字幕| 日韩精品无码一区二区三区久久久| 精品国产髙清在线看国产毛片| 久久99精品视频一区97| 国产精品自拍三区| 日韩欧洲国产| 欧美日韩一区二区三区| 加勒比日本影视| 五月婷婷在线观看视频| 无码黑人精品一区二区| 宅男噜噜噜66国产精品免费| 影音先锋男人资源在线| 欧美日韩国产精品一区二区三区| 丝袜连裤袜欧美激情日韩| 久久亚洲二区三区| 午夜天堂在线视频| 日本欧美日韩| 色哟哟一区二区在线观看| 亚洲精品成人天堂一二三| 四虎影院在线免费播放| 公交车上扒开嫩j挺进去| 国产成人8x视频一区二区| 国产亚洲精品成人a| 久久久99精品免费观看| 国产精品一区二区久久不卡| 欧美男男gaygay1069| 韩国主播福利视频一区二区三区| 日韩欧美国产网站| 波多野结衣视频网站| 欧美俄罗斯乱妇| 国产精品极品美女粉嫩高清在线| 久久久久久久久综合影视网| 成人性生交大片免费看视频在线| 可以在线看黄的网站| 国产精品久久婷婷六月丁香| 视频一区视频二区视频三区视频四区国产| 亚洲午夜久久久久久尤物| 绯色av一区二区| 在线播放国产一区| 亚洲国产精品电影在线观看| 日韩激情在线视频|