這篇文章給大家介紹如何使用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();
效果圖
因?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)