<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
前言:
canvas是HTML5新增的元素,也被稱為畫布,可以結合javascript實現繪製各種圖形,製作各種炫酷的動畫效果,現在我們也來使用canvas畫隨機運動小球。
先準備畫布確定對應的寬高:
<canvas id="canvas" width="400" height="400"></canvas> <script> let canvas = document.getElementById('canvas'); let ctx = canvas.getContext('2d'); let maxWidth = canvas.width, maxHeight = canvas.height; ctx.fillStyle = '#000'; ctx.fillRect(0, 0, maxWidth, maxHeight); </script>
因為是隨機運動,所以要建立一個獲取亂數的方法:
function getRandomNum(minNum, maxNum) { switch (arguments.length) { case 1: return Math.round(Math.random() * minNum + minNum); break; case 2: return Math.round( Math.random() * (maxNum - minNum) + minNum); break; case 0: return 0; break; } } // 建立一個Ball的建構函式 function Ball(maxWidth, maxHeight, ctx) { this.ctx = ctx; this.maxWidth = maxWidth; this.maxHeight = maxHeight; // 隨機半徑 this.r = getRandomNum(5, 15); // 隨機x,y座標 this.x = getRandomNum(this.r, this.maxWidth - this.r); this.y = getRandomNum(this.r, this.maxHeight - this.r); // 平移速度,正負區間是為了移動方向多樣 this.speedX = getRandomNum(-2, 2); this.speedY = getRandomNum(-2, 2); // 顏色隨機 this.color = `rgba(${getRandomNum(0, 255)}, ${getRandomNum(0, 255)}, ${getRandomNum(0, 255)},${Math.random()})`; } Ball.prototype = { draw: function () { ctx.beginPath(); ctx.fillStyle = this.color; ctx.arc(this.x, this.y, this.r, 0, Math.PI * 2); ctx.fill(); ctx.closePath(); }, move: function () { // 判斷邊界值,讓圓球始終保證在畫面內 if (this.x > this.maxWidth - this.r || this.x < this.r) { this.speedX = -this.speedX; } if (this.y > this.maxHeight - this.r || this.y < this.r) { this.speedY = -this.speedY; } this.x += this.speedX; this.y += this.speedY; } }; // 建立100個Ball範例 let balls = []; for (let i = 0; i < 100; i++) { let newBall = new Ball(maxWidth, maxHeight, ctx); newBall.draw(); balls.push(newBall); }
現在我們畫出了不同半徑和顏色的靜止圓球:
呼叫move
方法,間隔修改每個球的x,y值。
setInterval(() => { // 每次畫之前都要清除畫布 ctx.clearRect(0, 0, maxWidth, maxHeight); ctx.fillStyle = '#000'; ctx.fillRect(0, 0, maxWidth, maxHeight); for (let j = 0; j < 100; j++) { balls[j].draw(ctx); balls[j].move(); } }, 100);
效果展示:
canvas強大的繪圖能力可以使網頁的內容更加豐富多彩,給使用者帶來更好的視覺效果和和互動體驗,掌握一些功能的使用可以讓我們的專案更好的理解與canvas相關的框架使用,也能夠建立豐富的web應用,同時也要求我們更好的掌握
到此這篇關於JavaScript結合Canvas畫運動小球的文章就介紹到這了,更多相關JS與Canvas畫運動小球內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45