麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > HTML5 > 正文

Canvas繪制浮動球效果的示例

2024-09-05 07:22:16
字體:
來源:轉載
供稿:網友

最近關注區塊鏈方面的信息, 瞎轉悠, 偶然看到這個網站首頁的效果. 一堆浮動的球, 球在距離較近的時候會有感應線連接, 鼠標也可以和球產生感應線. 看了下是用canvas做的.

原效果 

實現效果

之前對svg有過很多接觸, canvas知道也可以做到很強大的渲染效果, 但是一直沒有什么使用場景給我上手的機會. 于是這次打算自己試著上手下.

另外, 之所以對這個感興趣, 一個是喜歡視覺效果類的東西, 二是喜歡類似游戲引擎那種模擬物理世界的感覺, 試想一下這些球會相互碰撞, 或者相互之間有引力斥力, 或者加上重力因素. 這個動畫還可以開不少腦洞.

github repo見這里.

Canvas

Canvas的畫圖指令很類似SVG里面的指令, 很簡單.

畫圓

ctx.beginPath();ctx.arc(this.center.x, this.center.y, this.radius, 0, 2 * Math.PI);ctx.fill();

beginPath開始一段路徑, arc畫一個圓, 然后fill填充顏色.

畫線

ctx.beginPath();ctx.moveTo(from.x, from.y);ctx.lineTo(to.x, to.y);ctx.stroke();

同樣是beginPath開始一段路徑, moveTo移動畫筆到起點, lineTo繪制線到終點, stroke描邊.

Canvas全屏

要保持canvas一直全屏, 只要在window onload或onresize的時候重置一下canvas的寬高即可.

var canvas = document.getElementById("canvas");function resizeCanvas() {    canvas.width = window.innerWidth;    canvas.height = window.innerHeight;}window.onload = window.onresize = resizeCanvas;

動畫

Basic animations帶我上手.

基本步驟

做動畫的四個步驟:

  1. 清除canvas內容, 通常使用clearRect()
  2. 保存canvas狀態
  3. 繪制內容
  4. 重置canvas狀態

我做的這個比較簡單, 只用到了1和3, 就是不斷地清空canvas然后重繪.

window.onload = function () {    resizeCanvas();    window.requestAnimationFrame(draw);};function cleanCanvas() {    ctx.clearRect(0, 0, canvas.width, canvas.height);}function draw() {    cleanCanvas();    // draw stuffs.    window.requestAnimationFrame(draw);}

控制函數

三個可以用:

  1. window.setInterval() 如果完全不需要用戶交互, 只是不斷重繪, 用這個就夠了.
  2. window.setTimeout() 如果想要用戶操作, 如鍵盤鼠標, 影響動畫, 可以用這個. (不懂, 不是requestAnimationFrame更好么?)
  3. window.requestAnimationFrame() 告知瀏覽器下次重繪之前要做的事情, 即你自己定制的繪制操作.

MDN里面的這個例子還挺酷的. CodePen. 可以動起來的, 下面只是一個截圖.

數據結構

之前看過一點Game Engine Development, 有意識地做面向對象的封裝. 這里面用到的是非常簡單的.

最基礎的是Vector代表二維空間上的點/向量, 成員只有x, y.

在此基礎上, Circle代表圓, 成員center: Vector代表圓心, radius: number代表半徑, speed: Vector代表速度.

然后封裝一些自用的成員函數即可.

開發環境

TypeScript + Webpack + Webpack-dev-server 不復雜, 參考以下內容即可:

  1. Webpack/Getting Started
  2. Webpack/Typescript
  3. Webpack/devServer
  4. webpack-dev-server

另外, 還試用了npx, 用來運行npm的可執行程序. 以前webpack什么的都是全局安裝的, 直接調用webpack xx即可. 如果本地安裝webpack的話, 就需要通過./node_modules/.bin/webpack來運行本地的webpack, 現在可以npx webpack xxx.

一個小坑

在devServer的config里面, 加入了hot: true想開啟熱更新, 結果網頁里面提示: [HMR] Hot Module Replacement is disabled.

發現是一個老坑, 需要調用的時候加上命令行參數: webpack-dev-server --hot --inline

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日本成人二区 | 7777视频| 久久精品一区二区三区不卡牛牛 | 久久免费视频一区二区三区 | 亚洲成人福利电影 | 国产手机在线视频 | 久久成人视屏 | www.91成人 | 97中文字幕第一一一页 | 国产成人精品区 | 在线a| 久久免费精品视频 | 久久精品视频16 | 亚洲欧美aⅴ | 国产精品视频一区二区三区四区五区 | 精国品产一区二区三区有限公司 | 亚洲国产网址 | 香蕉国产在线视频 | 久久精品久 | 久久国产精品一区 | 有色视频在线观看 | 99seav| www.射| 亚洲骚妻 | 毛片免费视频在线观看 | 久久久久久久久久久亚洲 | 欧美精品一级 | 中国女警察一级毛片视频 | 毛片一级片 | 在线成人免费观看www | 黄片毛片一级 | 日本在线播放一区二区三区 | 国产成人av免费 | 手机av免费在线 | 伦一区二区三区中文字幕v亚洲 | 看中国一级毛片 | 成年毛片| 国产精品视频中文字幕 | 在线观看视频日本 | 在线观看中文字幕av | 欧美18一19sex性护士农村 |