如何使用p5.js臨摹動(dòng)態(tài)圖形

這篇文章給大家介紹如何使用p5.js臨摹動(dòng)態(tài)圖形,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

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

一、描述所臨摹圖像的規(guī)律

1、圖像由多個(gè)閃光圓點(diǎn)和圓點(diǎn)之間的連線組成

2、圓點(diǎn)的運(yùn)動(dòng)軌跡是隨機(jī)的
3、圓點(diǎn)之間靠近時(shí)會(huì)產(chǎn)生連線,并且相互靠近的圓點(diǎn)會(huì)顏色加深

二、代碼實(shí)現(xiàn)

圓點(diǎn)之間產(chǎn)生連線,隨機(jī)生成線條和運(yùn)動(dòng)軌跡:

//隨機(jī)生成s.n條線位置信息
for (var t = [], p = 0; s.n > p; p++) {
  var h = random() * r, //隨機(jī)位置
   g = random() * n,
   q = 2 * random() - 1, //隨機(jī)運(yùn)動(dòng)方向
   d = 2 * random() - 1;
  t.push({
   x: h,
   y: g,
   xa: q,
   ya: d,
   max: 6000 //圓點(diǎn)靠近產(chǎn)生線條的距離
  })
 }

繪制閃光圓點(diǎn):

//由三個(gè)透明度不同的圓組成
 context.beginPath();
 context.arc(r.x,r.y,1.7,0*Math.PI,2*Math.PI);
 context.fillStyle="#FF1493";
 context.fill();
   
 context.beginPath();
 context.arc(r.x,r.y,6,0*Math.PI,2*Math.PI);
 context.fillStyle='rgba(255,20,147,0.3)';
 context.fill();
   
 context.beginPath();
 context.arc(r.x,r.y,10,0*Math.PI,2*Math.PI);
 context.fillStyle='rgba(255,20,147,0.1)';
 context.fill();

效果圖

如何使用p5.js臨摹動(dòng)態(tài)圖形

因?yàn)閷?duì)于臨摹動(dòng)態(tài)圖像仍有很多困惑的地方,無法實(shí)現(xiàn)多個(gè)圓點(diǎn)相互靠近顏色加深,非常遺憾最終不能臨摹出完全一樣的圖像。

三、拓展

增加交互性,使得線條能夠附著到鼠標(biāo)上,跟隨鼠標(biāo)移動(dòng)。
鼠標(biāo)靠近圓點(diǎn)時(shí),圓點(diǎn)會(huì)加速運(yùn)動(dòng),

//存儲(chǔ)鼠標(biāo)位置,離開的時(shí)候,釋放當(dāng)前位置信息
window.onmousemove = function(i) {
  i = i || window.event, f.x = i.clientX, f.y = i.clientY
 },
window.onmouseout = function() {
  f.x = null, f.y = null
 };

for (v = 0; v < w.length; v++) {//從下一個(gè)點(diǎn)開始
    x = w[v];
    if (i !== x && null !== x.x && null !== x.y) {
     B = i.x - x.x, z = i.y - x.y, y = B * B + z * z;
     //與鼠標(biāo)靠近到一定距離的時(shí)候圓點(diǎn)加速(x.max/2<y<x.max)
     y < x.max && (x == current_point && y >= x.max / 2 
      && (i.x -= 0.03 * B, i.y -= 0.03 * z), 
     ...
     )}

關(guān)于如何使用p5.js臨摹動(dòng)態(tài)圖形就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

本文題目:如何使用p5.js臨摹動(dòng)態(tài)圖形
文章出自:http://muchs.cn/article24/jcgije.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)定制網(wǎng)站、網(wǎng)站收錄、小程序開發(fā)、網(wǎng)站導(dǎo)航、域名注冊(cè)

廣告

聲明:本網(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í)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名