欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

javascriptCanvas動(dòng)態(tài)粒子連線

好久沒(méi)寫(xiě)博客了,最近負(fù)責(zé)了公司年會(huì)的大屏簽到、滾動(dòng)抽獎(jiǎng)、節(jié)目投票,整個(gè)項(xiàng)目做下來(lái)有驚也有喜。期間用到了Canvas制作動(dòng)畫(huà),我這邊就簡(jiǎn)單做了個(gè)動(dòng)態(tài)粒子連線的例子與大家分享。

成都創(chuàng)新互聯(lián)公司主營(yíng)和順網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,app軟件開(kāi)發(fā)公司,和順h5小程序定制開(kāi)發(fā)搭建,和順網(wǎng)站營(yíng)銷(xiāo)推廣歡迎和順等地區(qū)企業(yè)咨詢

一、效果圖

javascript Canvas動(dòng)態(tài)粒子連線

二、思路如下:

1.繪制隨機(jī)區(qū)域的粒子,記錄每個(gè)粒子x軸、y軸坐標(biāo)以及x軸與y軸每次移動(dòng)的距離

2.通過(guò)定時(shí)函數(shù)使得粒子進(jìn)行移動(dòng),移動(dòng)后判斷是否超過(guò)界限,超過(guò)則將該粒子刪除并生成一個(gè)新的粒子

3.判斷所有粒子之間的距離,對(duì)給定距離的粒子進(jìn)行連線。

三、代碼如下:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title>Canvas動(dòng)態(tài)粒子連線</title>
 </head>
 
 <body>
 <canvas id="myCanvas" ></canvas>
 <script>
 var myCanvas = document.getElementById("myCanvas");
 myCanvas.width = "800";
 myCanvas.height = "800";
 var cxt = myCanvas.getContext("2d");
 cxt.fillStyle="#ddd";
 var points =new Array();
 //繪制60個(gè)粒子
 for(var i=0;i<60;i++)
 {
 drawlizi();
 }
 setInterval(movelizi,100);
 
 //繪制靜態(tài)粒子
 function drawlizi(){
 var x = generate_random(3,797);
 var y = generate_random(3,797);
 var speedx = generate_random(-4,4);
 var speedy = generate_random(-4,4);
 //防止出現(xiàn)不移動(dòng)的粒子
 while(speedx==0&&speedy==0)
 {
 speedx = generate_random(-4,4);
 speedy = generate_random(-4,4);
 }
 var point={
 x_index:x,
 y_index:y,
 x_speed:speedx,
 y_speed:speedy
 };
 points.push(point);
 cxt.beginPath();
 cxt.arc(x,y,3,0,360);
 cxt.closePath();
 cxt.fill();
 }
 
 //粒子移動(dòng)
 function movelizi(){
 cxt.clearRect(0, 0,myCanvas.width,myCanvas.height);
 for(var i=0;i<points.length;i++)
 {
 points[i].x_index = points[i].x_index+points[i].x_speed;
 points[i].y_index = points[i].y_index+points[i].y_speed;
 cxt.beginPath();
 cxt.arc(points[i].x_index,points[i].y_index,3,0,360);
 cxt.closePath();
 cxt.fill();
 //判斷超過(guò)界限刪除并再生
 if((points[i].x_index<3||points[i].y_index<3)||(points[i].x_index>797||points[i].y_index<3)||(points[i].x_index<3||points[i].y_index>797)||(points[i].x_index>797||points[i].y_index>797)){
 points.splice(i,1);
 drawlizi();
 }
 }
 //相近的粒子進(jìn)行連線
 for (var i=0;i<points.length;i++) {
 for (var j=0;j<points.length;j++) {
 if(i!=j)
 {
 var one_x = points[i].x_index;
 var one_y = points[i].y_index;
 var two_x = points[j].x_index;
 var two_y = points[j].y_index;
 // 根據(jù)兩點(diǎn)間的距離公式,小于界限值便進(jìn)行連線
 var jl = Math.sqrt(Math.pow(one_x-two_x,2)+Math.pow(one_y-two_y,2));
 if(jl<100)
 {
 cxt.strokeStyle="#ddd";
 cxt.moveTo(one_x,one_y);
 cxt.lineTo(two_x,two_y);
 cxt.stroke();
 }
 }
 }
 }
 }
 //生成兩個(gè)數(shù)之間的隨機(jī)數(shù)
 function generate_random(min,max){
 return Math.floor(Math.random()*(max-min)+min);
 } 
 </script>
 </body>
 
</html>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

文章標(biāo)題:javascriptCanvas動(dòng)態(tài)粒子連線
URL分享:http://aaarwkj.com/article44/pesjhe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作商城網(wǎng)站、企業(yè)建站、網(wǎng)站改版、網(wǎng)站營(yíng)銷(xiāo)、網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)
夜夜爽精品国产亚洲av成人| 国产精品久久久久久老熟女| av中文字幕国产精品| 亚洲新大香蕉视频在线播放| 国产亚洲精品女人久久久| 精品丝袜熟女一区二区三区| 国产国产人免费人成免费人妖| 日本东京热不卡一区二区| 亚洲成年人黄色小说网站| 日韩欧美国产麻豆91在线精品| 国产在线一区二区三区观看| 日韩在线一区二区视频| 亚洲中文字幕偷拍色图| 亚洲av成人噜噜网站| 国产精品18禁一区二区三区| 97国产一区二区精品久久呦| 午在线亚洲男人午在线| 成人免费视频国产免费| 亚洲国产精品激情在线| 亚洲小视频免费在线观看| 亚洲av一区二区三区网站| 一区二区三区欧美久久| 一级黄片视频免费下载| 中国日本欧美最黄大片| 丰满人妻少妇一区二区| 久久午夜av一区二区| 日韩精品中文女同在线播放| 亚洲大尺码在线视频香蕉| 午夜精品三级一区二区三区| 日韩在线免费色视频| 91欧美精品一区二区| 日本午夜福利久久久| 婷婷丁香久久五月婷婷| 亚洲精品成人久久网| 成人黄色av大片在线观看| 激情图区亚洲一区二区| 黄片大全视频在线免费观看| 国产精品伦理一区二区三区| 亚洲黄色成人免费观看| 天天躁日日躁夜夜躁夜夜| 亚洲欧美日韩国产一区|