婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 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電話 威海營(yíng)銷外呼系統(tǒng)招商 漳州人工外呼系統(tǒng)排名 鶴壁手機(jī)自動(dòng)外呼系統(tǒng)怎么安裝

效果 :)

不帶連線效果:

帶連線的效果:

教程

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

創(chuàng)建canvas

首先需要在需要展示粒子背景的父元素中創(chuàng)建一個(gè)canvas標(biāo)簽, 指定widthheight, 在我們生成隨機(jī)點(diǎn)坐標(biāo)的時(shí)候需要用widthheight來(lái)做參照。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來(lái)改動(dòng)點(diǎn)的位置。

// 調(diào)用draw函數(shù)開(kāi)啟動(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

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

標(biāo)簽:咸陽(yáng) 蘇州 文山 營(yíng)口 紅河 惠州 甘南 萍鄉(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)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《canvas粒子動(dòng)畫背景的實(shí)現(xiàn)示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于canvas粒子動(dòng)畫背景的實(shí)現(xiàn)示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品18久久久久久vr| 亚洲乱码一区二区三区在线观看| 日韩欧美一二三四区| 亚洲专区一二三| 91在线精品一区二区三区| 国产午夜亚洲精品不卡| 国产成人综合亚洲网站| 国产欧美日韩激情| 色综合久久天天综合网| 亚洲一区二区三区精品在线| 欧美日韩在线观看一区二区 | 欧美亚洲图片小说| 国产精品成人免费在线| 九九在线精品视频| 亚洲另类春色国产| 亚洲一区二区三区视频在线 | 婷婷丁香久久五月婷婷| 欧美日韩三级一区二区| 麻豆一区二区三| 久久先锋资源网| av一区二区久久| 亚洲风情在线资源站| 717成人午夜免费福利电影| 韩国女主播成人在线观看| 欧美激情一区二区三区不卡| www.亚洲人| 日韩精品电影在线观看| 久久精品水蜜桃av综合天堂| 色婷婷亚洲婷婷| 久久91精品国产91久久小草| 亚洲图片你懂的| 亚洲影院久久精品| 久久蜜桃一区二区| 欧美体内she精高潮| 国产高清不卡一区二区| 亚洲国产aⅴ天堂久久| 久久无码av三级| 91麻豆精品国产91久久久资源速度 | 亚洲v日本v欧美v久久精品| 精品久久久久一区二区国产| 成人av网站免费| 人妖欧美一区二区| 亚洲激情图片qvod| 久久久久国产一区二区三区四区| 在线观看亚洲a| www.亚洲色图| 国产精品一区专区| 免费日韩伦理电影| 亚洲国产精品久久人人爱 | 欧美日韩一区不卡| 欧美不卡激情三级在线观看| 成人高清在线视频| 蜜桃久久久久久| 亚洲成人av在线电影| 国产日本欧美一区二区| 91精品国产欧美一区二区18 | 欧美一区二区久久久| 色综合中文字幕国产 | 中文字幕免费不卡| 国产精品久久久久久久第一福利| 欧美日韩黄色一区二区| 91丝袜美腿高跟国产极品老师| 国产乱码精品一区二区三| 午夜伦理一区二区| 天涯成人国产亚洲精品一区av| 亚洲黄一区二区三区| 亚洲男同1069视频| 夜夜爽夜夜爽精品视频| 亚洲影视资源网| 亚洲午夜av在线| 日韩成人精品视频| 日韩精品1区2区3区| 五月综合激情婷婷六月色窝| 亚洲电影在线播放| 亚洲图片自拍偷拍| 日本一区中文字幕| 激情综合网av| 成人深夜福利app| 色系网站成人免费| 欧美日韩一区二区欧美激情| 欧美久久久久久久久| 欧美一区二区在线免费播放| 日韩一区国产二区欧美三区| 日韩三级视频中文字幕| 久久综合狠狠综合| 中文字幕欧美一区| 亚洲午夜电影在线观看| 青青草成人在线观看| 国产麻豆视频精品| 成人福利视频网站| 欧美日韩国产在线观看| 日韩一级欧美一级| 欧美激情一区二区三区| 亚洲一区二区影院| 国产在线一区二区综合免费视频| 狠狠色狠狠色综合日日91app| 成人av一区二区三区| 欧美日韩一级黄| 中文字幕成人在线观看| 亚洲精品久久7777| 激情小说欧美图片| 精品视频一区二区三区免费| 久久免费的精品国产v∧| 亚洲一区电影777| 丁香亚洲综合激情啪啪综合| 欧美日韩另类一区| 国产女同互慰高潮91漫画| 亚洲一区在线观看视频| 国产不卡视频在线播放| 欧美日韩国产高清一区二区| 中文字幕精品在线不卡| 日本欧洲一区二区| 99re成人精品视频| 国产亚洲综合在线| 免费欧美日韩国产三级电影| 一本大道久久精品懂色aⅴ| 久久亚洲精精品中文字幕早川悠里| 樱桃国产成人精品视频| 丰满白嫩尤物一区二区| 日韩精品专区在线影院重磅| 午夜激情一区二区| 色天天综合久久久久综合片| 久久在线免费观看| 日本亚洲一区二区| 欧美日韩亚洲不卡| 性欧美大战久久久久久久久| 99r精品视频| 日本高清免费不卡视频| 综合精品久久久| 成人教育av在线| 国产欧美va欧美不卡在线| 久久成人免费网| 国产一区不卡在线| 精品国产三级a在线观看| 午夜欧美2019年伦理| 欧美另类高清zo欧美| 一级日本不卡的影视| 欧美系列日韩一区| 亚洲高清免费在线| 欧美日韩一区二区三区在线看| 亚洲五码中文字幕| 6080亚洲精品一区二区| 免费在线观看一区| 日韩免费视频线观看| 日本欧美在线看| 日韩精品一区二区三区swag| 美女网站视频久久| 国产欧美一区二区精品忘忧草| 国产精品1024| 中文字幕日韩精品一区| 色婷婷亚洲婷婷| 亚洲制服丝袜av| 日韩三级伦理片妻子的秘密按摩| 美洲天堂一区二卡三卡四卡视频| 欧美v日韩v国产v| 国产精品一区专区| 亚洲欧美激情一区二区| 欧美日韩国产乱码电影| 久久精品二区亚洲w码| 欧美国产综合色视频| a在线欧美一区| 亚洲综合久久av| 精品国产乱码久久久久久闺蜜| 国产九色sp调教91| 亚洲永久免费av| 欧美一区二区久久| 九九**精品视频免费播放| 久久无码av三级| 一本久久a久久精品亚洲| 日本午夜精品视频在线观看| 欧美国产国产综合| 欧美欧美欧美欧美| 风流少妇一区二区| 伊人一区二区三区| 国产亚洲欧美一区在线观看| 色婷婷精品大视频在线蜜桃视频| 免费亚洲电影在线| 亚洲色图在线视频| 日韩精品一区二区三区在线观看 | xfplay精品久久| 一本一道综合狠狠老| 青青草精品视频| 亚洲欧洲综合另类在线 | 欧美在线不卡视频| 国产宾馆实践打屁股91| 亚洲自拍偷拍麻豆| 日本一区二区三区在线不卡| 7799精品视频| 91麻豆免费视频| 国产精品中文有码| 日韩精品成人一区二区在线| 亚洲婷婷在线视频| 国产亚洲一区二区在线观看| 欧美高清hd18日本| 欧美亚洲一区三区| 99久久久免费精品国产一区二区| 韩国午夜理伦三级不卡影院| 午夜精品123| 一区二区成人在线| 亚洲美女屁股眼交3|