使用canvas制作炫酷黑客帝國數字雨背景html+css+js
制作:
1.定義canvas標簽:
<canvas id="canvas"></canvas>
2.開始js部分,先定義變量:
/* 獲取畫佈 */ var canvas = document.querySelector("#canvas"); var ctx = canvas.getContext('2d'); /* 定義一個字符串數組,後面字符串會從裡隨機選值 */ var text = "SAFAF1D56FLK43F7PHM76VC9XNJL23"; /* 定義 w為窗口寬度,h為窗體高度 */ var w=window.innerWidth; var h=window.innerHeight; /* 設置len為20,其為背景裡每條字符串的長度 */ var len = 20; /* 設置num為100,窗口一共顯示100條字符串 */ var num = 100; /* 定義數組,裡面存取每條字符串的字符與位置 */ var arr=[]; /* 畫佈寬等於窗口寬 */ canvas.width=window.innerWidth; /* 畫佈高等於窗口高 */ canvas.height=window.innerHeight;
3.初始化字符串數組,先給每條字符串位置,字符先不給:
/* 初始化字符串數組 */ for(let i=0;i<num;i++){ /* 用.push方法給arr數組添加值 */ arr.push({ /* 字符先為空 */ str:[], /* x軸位置為窗口寬度乘上一個0帶1的隨機數 */ x: parseInt(w*Math.random()), /* y軸位置為窗口高度乘上一個0帶1的隨機數,再減個150把,可以為負數 */ y: parseInt(h*Math.random()-150) }) }
4.繪制每條字符串:
/* 繪制每條字符串 */ function txt(){ /* 給個循環,共繪制num條 */ for(let i=0;i<num;i++){ /* 設置變量letter為當前arr數組裡的第i條字符串 */ var letter = arr[i]; /* 讓字符串的字符為空 */ letter.str = []; /* 給個循環,一個字符一個字符的拼接成字符串 */ for(let k=0;k<len;k++){ /* 隨機選取text裡的一個字符 */ letter.str.push(text[Math.floor(Math.random() * text.length)]); } /* 再來循環,開始繪制渲染字符串的每個字符 */ for(let j=0;j<len;j++){ if(j==len-1){ /* 第一個字符為白色 */ ctx.fillStyle = `rgb(255, 255, 255)`; }else{ /* 後面的為綠色,慢慢變不透明 */ ctx.fillStyle = `rgba(0, 255, 21,${j*0.15})`; } /* 渲染字符 */ ctx.font = "20px FangSong"; ctx.fillText(letter.str[j],letter.x,letter.y+j*15); } } /* 調用更新 */ move(); }
5.更新字符串:
/* 讓字符串移動,若某字符串出瞭可視區,則重新生成 */ function move(){ /* 來個循環,給全部字符串更新位置 */ for(let j=0;j<num;j++){ /* y軸位置加3 */ arr[j].y=arr[j].y+3; /* 如果改字符已經走出窗口瞭重新賦值 */ if(arr[j].y>=h){ arr[j]={ str:[], x: parseInt(w*Math.random()), y: parseInt(h*Math.random()-150) } } } }
6.設置動畫過程:
setInterval(function(){ /* 清屏 */ ctx.clearRect(0,0,w,h); /* 渲染 */ move(); /* 更新 */ txt(); },50);
7.在窗口大小改變時,設置canvas畫佈能實時鋪滿屏幕:
/* 綁定窗口大小發生改變事件,重新繪制字符串數組,讓canvas隨時鋪滿瀏覽器可視區 */ window.onresize=resizeCanvas; function resizeCanvas(){ w=canvas.width=window.innerWidth; h=canvas.height=window.innerHeight; /* 重新給全部字符串賦值 */ for(let j=0;j<num;j++){ arr[j]={ str:[], x: parseInt(w*Math.random()), y: parseInt(h*Math.random()-150) } } } resizeCanvas();
完整代碼:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> *{ margin: 0; padding: 0; box-sizing: border-box; } body{ height: 100vh; background-color: rgb(0, 0, 0); } canvas{ position: fixed; top: 0; left: 0; z-index: -1; } h1{ font-family: 'FangSong'; position: fixed; top: 50%; left: 50%; transform: translate(-40%,-50%); font-size: 3em; color: rgb(255, 255, 255); text-shadow: 0 0 10px rgb(30, 255, 0), 0 0 20px rgb(30, 255, 0), 0 0 30px rgb(30, 255, 0), 0 0 50px rgb(30, 255, 0); } </style> </head> <body> <h1>北極光之夜。</h1> <canvas id="canvas"></canvas> <script> /* 獲取畫佈 */ var canvas = document.querySelector("#canvas"); var ctx = canvas.getContext('2d'); /* 定義一個字符串數組,後面字符串會從裡隨機選值 */ var text = "SAFAF1D56FLK43F7PHM76VC9XNJL23"; /* 定義 w為窗口寬度,h為窗體高度 */ var w=window.innerWidth; var h=window.innerHeight; /* 設置len為20,其為背景裡每條字符串的長度 */ var len = 20; /* 設置num為100,窗口一共顯示100條字符串 */ var num = 100; /* 定義數組,裡面存取每條字符串的字符與位置 */ var arr=[]; /* 畫佈寬等於窗口寬 */ canvas.width=window.innerWidth; /* 畫佈高等於窗口高 */ canvas.height=window.innerHeight; /* 綁定窗口大小發生改變事件,重新繪制字符串數組,讓canvas隨時鋪滿瀏覽器可視區 */ window.onresize=resizeCanvas; function resizeCanvas(){ w=canvas.width=window.innerWidth; h=canvas.height=window.innerHeight; /* 重新給全部字符串賦值 */ for(let j=0;j<num;j++){ arr[j]={ str:[], x: parseInt(w*Math.random()), y: parseInt(h*Math.random()-150) } } } resizeCanvas(); /* 初始化字符串數組 */ for(let i=0;i<num;i++){ /* 用.push方法給arr數組添加值 */ arr.push({ /* 字符先為空 */ str:[], /* x軸位置為窗口寬度乘上一個0帶1的隨機數 */ x: parseInt(w*Math.random()), /* y軸位置為窗口高度乘上一個0帶1的隨機數,再減個150把,可以為負數 */ y: parseInt(h*Math.random()-150) }) } /* 繪制每條字符串 */ function txt(){ /* 給個循環,共繪制num條 */ for(let i=0;i<num;i++){ /* 設置變量letter為當前arr數組裡的第i條字符串 */ var letter = arr[i]; /* 讓字符串的字符為空 */ letter.str = []; /* 給個循環,一個字符一個字符的拼接成字符串 */ for(let k=0;k<len;k++){ /* 隨機選取text裡的一個字符 */ letter.str.push(text[Math.floor(Math.random() * text.length)]); } /* 再來循環,開始繪制渲染字符串的每個字符 */ for(let j=0;j<len;j++){ if(j==len-1){ /* 第一個字符為白色 */ ctx.fillStyle = `rgb(255, 255, 255)`; }else{ /* 後面的為綠色,慢慢變不透明 */ ctx.fillStyle = `rgba(0, 255, 21,${j*0.15})`; } /* 渲染字符 */ ctx.font = "20px FangSong"; ctx.fillText(letter.str[j],letter.x,letter.y+j*15); } } /* 調用更新 */ move(); } /* 讓字符串移動,若某字符串出瞭可視區,則重新生成 */ function move(){ /* 來個循環,給全部字符串更新位置 */ for(let j=0;j<num;j++){ /* y軸位置加3 */ arr[j].y=arr[j].y+3; /* 如果改字符已經走出窗口瞭重新賦值 */ if(arr[j].y>=h){ arr[j]={ str:[], x: parseInt(w*Math.random()), y: parseInt(h*Math.random()-150) } } } } setInterval(function(){ /* 清屏 */ ctx.clearRect(0,0,w,h); /* 渲染 */ move(); /* 更新 */ txt(); },50); </script> </body> </html>
到此這篇關於使用canvas制作炫酷黑客帝國數字雨背景html+css+js的文章就介紹到這瞭,更多相關canvas制作數字雨背景特效html+css+js內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- html+css+js實現canvas跟隨鼠標的小圓特效源碼
- javascript canvas實現雨滴效果
- js+canvas實現代碼雨效果
- JavaScript實現環繞鼠標旋轉效果
- JS實現代碼雨特效