亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

HTML實現代碼雨源碼及效果示例

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

最近學習了HTML,今天寫個HTML代碼雨,然后下面用HTML和js也寫了一個,給自己留點筆記

先看看效果

1、綠色:

2、彩色:

3、背景色:

4、綠色逐漸變淺:

源代碼:

<!DOCTYPE html><html>   <head>       <meta http-equiv="Content-Type" content="text/html;charset=utf-8">    <title>Code -by ZhenYu.Sha</title>    <style type="text/css">        html, body {            width: 100%;            height: 100%;        }        body {            background: #000;            overflow: hidden;            margin: 0;            padding: 0;        }    </style></head>   <body>  <canvas id="cvs"></canvas><script type="text/javascript">    var cvs = document.getElementById("cvs");    var ctx = cvs.getContext("2d");    var cw = cvs.width = document.body.clientWidth;    var ch = cvs.height = document.body.clientHeight;    //動畫繪制對象    var requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame;    var codeRainArr = []; //代碼雨數組    var cols = parseInt(cw / 14); //代碼雨列數    var step = 16;    //步長,每一列內部數字之間的上下間隔    ctx.font = "bold 26px microsoft yahei"; //聲明字體,個人喜歡微軟雅黑     function createColorCv() {        //畫布基本顏色        ctx.fillStyle = "#242424";        ctx.fillRect(0, 0, cw, ch);    }     //創建代碼雨    function createCodeRain() {        for (var n = 0; n < cols; n++) {            var col = [];            //基礎位置,為了列與列之間產生錯位            var basePos = parseInt(Math.random() * 300);            //隨機速度 3~13之間            var speed = parseInt(Math.random() * 10) + 3;            //每組的x軸位置隨機產生            var colx = parseInt(Math.random() * cw)             //綠色隨機            var rgbr = 0;            var rgbg = parseInt(Math.random() * 255);            var rgbb = 0;            //ctx.fillStyle = "rgb("+r+','+g+','+b+")"             for (var i = 0; i < parseInt(ch / step) / 2; i++) {                var code = {                    x: colx,                    y: -(step * i) - basePos,                    speed: speed,                    //  text : parseInt(Math.random()*10)%2 == 0 ? 0 : 1  //隨機生成0或者1                    text: ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "s", "t", "u", "v", "w", "x", "y", "z"][parseInt(Math.random() * 11)], //隨機生成字母數組中的一個                    color: "rgb(" + rgbr + ',' + rgbg + ',' + rgbb + ")"                }                col.push(code);            }            codeRainArr.push(col);        }    }     //代碼雨下起來    function codeRaining() {        //把畫布擦干凈        ctx.clearRect(0, 0, cw, ch);        //創建有顏色的畫布        //createColorCv();        for (var n = 0; n < codeRainArr.length; n++) {            //取出列            col = codeRainArr[n];            //遍歷列,畫出該列的代碼            for (var i = 0; i < col.length; i++) {                var code = col[i];                if (code.y > ch) {                    //如果超出下邊界則重置到頂部                    code.y = 0;                } else {                    //勻速降落                    code.y += code.speed;                }                                //1 顏色也隨機變化                //ctx.fillStyle = "hsl("+(parseInt(Math.random()*359)+1)+",30%,"+(50-i*2)+"%)";                  //2 綠色逐漸變淺                // ctx.fillStyle = "hsl(123,80%,"+(30-i*2)+"%)";                  //3 綠色隨機                // var r= 0;                // var g= parseInt(Math.random()*255) + 3;                // var b= 0;                // ctx.fillStyle = "rgb("+r+','+g+','+b+")";                 //4 一致綠                ctx.fillStyle = code.color;                  //把代碼畫出來                ctx.fillText(code.text, code.x, code.y);            }        }        requestAnimationFrame(codeRaining);    }     //創建代碼雨    createCodeRain();    //開始下雨吧 GO>>    requestAnimationFrame(codeRaining);</script>   </body></html>

更多代碼雨的文章請參考我的其它文章:

“代碼雨”js+css+html實現

HTML代碼:

<!DOCTYPE html><html><head><meta charset="utf-8"><link rel="stylesheet" type="text/css" href="css/ok.css"><title>code by-zhenyu.sha</title></head> <body><canvas id="canvas"></canvas></body><script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script><script src="http://neilcarpenter.com/demos/canvas/matrix/stats.min.js"></script><script type="text/javascript" src="js/ok.js"></script></html>

js代碼:

(function() {  var lastTime = 0;  var vendors = ['ms', 'moz', 'webkit', 'o'];  for (var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) {    window.requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame'];    window.cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] ||      window[vendors[x] + 'CancelRequestAnimationFrame'];  }  if (!window.requestAnimationFrame)    window.requestAnimationFrame = function(callback, element) {      var currTime = new Date().getTime();      var timeToCall = Math.max(0, 16 - (currTime - lastTime));      var id = window.setTimeout(function() {          callback(currTime + timeToCall);        },        timeToCall);      lastTime = currTime + timeToCall;      return id;    };  if (!window.cancelAnimationFrame)    window.cancelAnimationFrame = function(id) {      clearTimeout(id);    };}());// statsvar stats = new Stats();stats.setMode(0);stats.domElement.style.position = 'absolute';stats.domElement.style.left = '0px';stats.domElement.style.top = '0px';document.body.appendChild(stats.domElement);var M = {  settings: {    COL_WIDTH: 20,    COL_HEIGHT: 25,    VELOCITY_PARAMS: {      min: 4,      max: 8    },    CODE_LENGTH_PARAMS: {      min: 20,      max: 40    }  },  animation: null,  c: null,  ctx: null,  lineC: null,  ctx2: null,  WIDTH: window.innerWidth,  HEIGHT: window.innerHeight,  COLUMNS: null,  canvii: [],  font: '30px matrix-code',  letters: ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '$', '+', '-', '*', '/', '=', '%', '"', '/'', '#', '&', '_', '(', ')', ',', '.', ';', ':', '?', '!', '//', '|', '{', '}', '<', '>', '[', ']', '^', '~'],  codes: [],  createCodeLoop: null,  codesCounter: 0,  init: function() {    M.c = document.getElementById('canvas');    M.ctx = M.c.getContext('2d');    M.c.width = M.WIDTH;    M.c.height = M.HEIGHT;    M.ctx.shadowBlur = 0;    M.ctx.fillStyle = '#000';    M.ctx.fillRect(0, 0, M.WIDTH, M.HEIGHT);    M.ctx.font = M.font;    M.COLUMNS = Math.ceil(M.WIDTH / M.settings.COL_WIDTH);    for (var i = 0; i < M.COLUMNS; i++) {      M.codes[i] = [];      M.codes[i][0] = {        'open': true,        'position': {          'x': 0,          'y': 0        },        'strength': 0      };    }    M.loop();    M.createLines();    M.createCode();    // not doing this, kills CPU    // M.swapCharacters();    window.onresize = function() {      window.cancelAnimationFrame(M.animation);      M.animation = null;      M.ctx.clearRect(0, 0, M.WIDTH, M.HEIGHT);      M.codesCounter = 0;      M.ctx2.clearRect(0, 0, M.WIDTH, M.HEIGHT);      M.WIDTH = window.innerWidth;      M.HEIGHT = window.innerHeight;      M.init();    };  },  loop: function() {    M.animation = requestAnimationFrame(function() {      M.loop();    });    M.draw();    stats.update();  },  draw: function() {    var velocity, height, x, y, c, ctx;    // slow fade BG colour    M.ctx.shadowColor = 'rgba(0, 0, 0, 0.5)';    M.ctx.fillStyle = 'rgba(0, 0, 0, 0.5)';    M.ctx.fillRect(0, 0, M.WIDTH, M.HEIGHT);    M.ctx.globalCompositeOperation = 'source-over';    for (var i = 0; i < M.COLUMNS; i++) {      // check member of array isn't undefined at this point      if (M.codes[i][0].canvas) {        velocity = M.codes[i][0].velocity;        height = M.codes[i][0].canvas.height;        x = M.codes[i][0].position.x;        y = M.codes[i][0].position.y - height;        c = M.codes[i][0].canvas;        ctx = c.getContext('2d');        M.ctx.drawImage(c, x, y, M.settings.COL_WIDTH, height);        if ((M.codes[i][0].position.y - height) < M.HEIGHT) {          M.codes[i][0].position.y += velocity;        } else {          M.codes[i][0].position.y = 0;        }      }    }  },  createCode: function() {    if (M.codesCounter > M.COLUMNS) {      clearTimeout(M.createCodeLoop);      return;    }    var randomInterval = M.randomFromInterval(0, 100);    var column = M.assignColumn();    if (column) {      var codeLength = M.randomFromInterval(M.settings.CODE_LENGTH_PARAMS.min, M.settings.CODE_LENGTH_PARAMS.max);      var codeVelocity = (Math.random() * (M.settings.VELOCITY_PARAMS.max - M.settings.VELOCITY_PARAMS.min)) + M.settings.VELOCITY_PARAMS.min;      var lettersLength = M.letters.length;      M.codes[column][0].position = {        'x': (column * M.settings.COL_WIDTH),        'y': 0      };      M.codes[column][0].velocity = codeVelocity;      M.codes[column][0].strength = M.codes[column][0].velocity / M.settings.VELOCITY_PARAMS.max;      for (var i = 1; i <= codeLength; i++) {        var newLetter = M.randomFromInterval(0, (lettersLength - 1));        M.codes[column][i] = M.letters[newLetter];      }      M.createCanvii(column);      M.codesCounter++;    }    M.createCodeLoop = setTimeout(M.createCode, randomInterval);  },  createCanvii: function(i) {    var codeLen = M.codes[i].length - 1;    var canvHeight = codeLen * M.settings.COL_HEIGHT;    var velocity = M.codes[i][0].velocity;    var strength = M.codes[i][0].strength;    var text, fadeStrength;    var newCanv = document.createElement('canvas');    var newCtx = newCanv.getContext('2d');    newCanv.width = M.settings.COL_WIDTH;    newCanv.height = canvHeight;    for (var j = 1; j < codeLen; j++) {      text = M.codes[i][j];      newCtx.globalCompositeOperation = 'source-over';      newCtx.font = '30px matrix-code';      if (j < 5) {        newCtx.shadowColor = 'hsl(104, 79%, 74%)';        newCtx.shadowOffsetX = 0;        newCtx.shadowOffsetY = 0;        newCtx.shadowBlur = 10;        newCtx.fillStyle = 'hsla(104, 79%, ' + (100 - (j * 5)) + '%, ' + strength + ')';      } else if (j > (codeLen - 4)) {        fadeStrength = j / codeLen;        fadeStrength = 1 - fadeStrength;        newCtx.shadowOffsetX = 0;        newCtx.shadowOffsetY = 0;        newCtx.shadowBlur = 0;        newCtx.fillStyle = 'hsla(104, 79%, 74%, ' + (fadeStrength + 0.3) + ')';      } else {        newCtx.shadowOffsetX = 0;        newCtx.shadowOffsetY = 0;        newCtx.shadowBlur = 0;        newCtx.fillStyle = 'hsla(104, 79%, 74%, ' + strength + ')';      }      newCtx.fillText(text, 0, (canvHeight - (j * M.settings.COL_HEIGHT)));    }    M.codes[i][0].canvas = newCanv;  },  swapCharacters: function() {    var randomCodeIndex;    var randomCode;    var randomCodeLen;    var randomCharIndex;    var newRandomCharIndex;    var newRandomChar;    for (var i = 0; i < 20; i++) {      randomCodeIndex = M.randomFromInterval(0, (M.codes.length - 1));      randomCode = M.codes[randomCodeIndex];      randomCodeLen = randomCode.length;      randomCharIndex = M.randomFromInterval(2, (randomCodeLen - 1));      newRandomCharIndex = M.randomFromInterval(0, (M.letters.length - 1));      newRandomChar = M.letters[newRandomCharIndex];      randomCode[randomCharIndex] = newRandomChar;    }    M.swapCharacters();  },  createLines: function() {    M.linesC = document.createElement('canvas');    M.linesC.width = M.WIDTH;    M.linesC.height = M.HEIGHT;    M.linesC.style.position = 'absolute';    M.linesC.style.top = 0;    M.linesC.style.left = 0;    M.linesC.style.zIndex = 10;    document.body.appendChild(M.linesC);    var linesYBlack = 0;    var linesYWhite = 0;    M.ctx2 = M.linesC.getContext('2d');    M.ctx2.beginPath();    M.ctx2.lineWidth = 1;    M.ctx2.strokeStyle = 'rgba(0, 0, 0, 0.7)';    while (linesYBlack < M.HEIGHT) {      M.ctx2.moveTo(0, linesYBlack);      M.ctx2.lineTo(M.WIDTH, linesYBlack);      linesYBlack += 5;    }    M.ctx2.lineWidth = 0.15;    M.ctx2.strokeStyle = 'rgba(255, 255, 255, 0.7)';    while (linesYWhite < M.HEIGHT) {      M.ctx2.moveTo(0, linesYWhite + 1);      M.ctx2.lineTo(M.WIDTH, linesYWhite + 1);      linesYWhite += 5;    }    M.ctx2.stroke();  },  assignColumn: function() {    var randomColumn = M.randomFromInterval(0, (M.COLUMNS - 1));    if (M.codes[randomColumn][0].open) {      M.codes[randomColumn][0].open = false;    } else {      return false;    }    return randomColumn;  },  randomFromInterval: function(from, to) {    return Math.floor(Math.random() * (to - from + 1) + from);  },  snapshot: function() {    window.open(M.c.toDataURL());  }};function eventListenerz() {  var controlToggles = document.getElementsByClassName('toggle-info');  var controls = document.getElementById('info');  var snapshotBtn = document.getElementById('snapshot');  function toggleControls(e) {    e.preventDefault();    controls.className = controls.className === 'closed' ? '' : 'closed';  }  for (var j = 0; j < 2; j++) {    controlToggles[j].addEventListener('click', toggleControls, false);  }  snapshotBtn.addEventListener('click', M.snapshot, false);}window.onload = function() {  M.init();  eventListenerz();};

css代碼:

@import url("http://fonts.googleapis.com/css?family=Carrois+Gothic");@font-face {  font-family: 'matrix-code';  src: url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.eot?#iefix') format('embedded-opentype'), url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.woff') format('woff'), url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.ttf') format('truetype'), url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.svg#svgFontName') format('svg');}html,body {  -webkit-font-smoothing: antialiased;  font: normal 12px/14px "Carrois Gothic", sans-serif;  width: 100%;  height: 100%;  margin: 0;  overflow: hidden;  color: #fff;  -webkit-user-select: none;  -moz-user-select: none;  -ms-user-select: none;  user-select: none;}body {  background: black;}#stats {  z-index: 100;}#info {  background: rgba(0, 0, 0, 0.7);  position: fixed;  bottom: 0;  left: 0px;  width: 250px;  padding: 10px 20px 20px;  z-index: 100;  -webkit-transform-origin: bottom center;  -moz-transform-origin: bottom center;  -o-transform-origin: bottom center;  transform-origin: bottom center;  -webkit-transform: rotate(0deg);  -moz-transform: rotate(0deg);  -o-transform: rotate(0deg);  transform: rotate(0deg);  -webkit-transition: -webkit-transform .5s ease-in-out;  -moz-transition: -moz-transform .5s ease-in-out;  -o-transition: -o-transform .5s ease-in-out;  transition: transform .5s ease-in-out;}#info.closed {  -webkit-transform: rotate(180deg);  -moz-transform: rotate(180deg);  -o-transform: rotate(180deg);  transform: rotate(180deg);}.toggle-info {  position: absolute;  display: block;  height: 10px;  background: rgba(0, 0, 0, 0.8);  width: 290px;  left: 0;  text-align: center;  padding: 3px 0 7px;  text-decoration: none;  color: white;  text-shadow: none;}.toggle-info:hover {  background: rgb(0, 0, 0);}#close {  top: -20px;}#open {  bottom: -20px;  -webkit-transform: rotate(-180deg);  -moz-transform: rotate(-180deg);  -o-transform: rotate(-180deg);  transform: rotate(-180deg);}button {  background: rgba(255, 255, 255, 0.2);  color: #fff;  border: 0;  border-radius: 2px;  padding: 7px 10px;  box-shadow: 0 0 3px 0px rgba(255, 255, 255, 0.3);  cursor: pointer;}button:hover {  background: rgba(255, 255, 255, 0.1);}pa {  color: #fff;}pa:hover {  color: #EFFDEB;  text-shadow: 0px 0px 5px #75AD61;}

 到此這篇關于HTML實現代碼雨源碼及效果示例的文章就介紹到這了,更多相關HTML代碼雨內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩资源在线观看| 日韩第一页在线| 亚洲人成啪啪网站| 亚洲精品不卡在线| 亚洲精品第一页| 日本精品视频网站| 国产精品免费一区| 在线国产精品播放| 欧美日韩亚洲系列| 久久久精品国产亚洲| 欧美黑人巨大精品一区二区| 啊v视频在线一区二区三区| 欧美激情aaaa| 日韩高清av在线| 亚洲美女自拍视频| 国产中文字幕日韩| 亚洲欧美在线免费观看| 97精品视频在线| 欧美亚洲成人免费| 国产精品久久一| 欧美亚洲日本黄色| 久久久亚洲福利精品午夜| 亚洲成人激情小说| 亚洲自拍高清视频网站| 黑人巨大精品欧美一区二区免费| 欧美又大又硬又粗bbbbb| 色综合视频一区中文字幕| 国模视频一区二区| 亚洲码在线观看| 日韩av成人在线| 91精品在线影院| 亚洲欧美第一页| 日韩一级裸体免费视频| 国产ts人妖一区二区三区| 国产精品老牛影院在线观看| 性欧美激情精品| 亚洲精品91美女久久久久久久| 亚洲人成网站色ww在线| 成人免费在线视频网站| 中文字幕日韩欧美精品在线观看| 国产午夜精品麻豆| 亚洲成人网在线| 91高清视频免费观看| 亚洲精品一区二区三区婷婷月| 亚洲人成网站色ww在线| 成人久久精品视频| 久久精品国产成人精品| 日韩av在线免费观看| 日本精品免费一区二区三区| 国产精品久久久av| 色综合亚洲精品激情狠狠| 一本大道香蕉久在线播放29| 欧美国产视频一区二区| 国外日韩电影在线观看| 美女国内精品自产拍在线播放| 久热国产精品视频| 亚洲一级片在线看| 欧美色另类天堂2015| 久热精品视频在线观看| 中文日韩在线视频| 日韩中文字幕在线看| 亚洲人成电影网站色xx| 日韩av网站大全| 一本一道久久a久久精品逆3p| 欧美激情一区二区三区久久久| 日韩欧美一区二区在线| 日韩av资源在线播放| 国产精品视频午夜| 日韩成人中文电影| xxx欧美精品| 日本午夜人人精品| 欧美激情一二三| 一区二区欧美久久| 久久久久久久久久久人体| 欧美亚洲第一区| 日韩高清免费在线| 亚洲一区二区久久久| 午夜精品99久久免费| 国产精品成人观看视频国产奇米| 欧美日韩另类视频| 成人在线观看视频网站| 色无极亚洲影院| 夜夜嗨av一区二区三区四区| 亚洲综合社区网| 欧洲美女7788成人免费视频| 欧美性猛交xxxx乱大交| 国产精品海角社区在线观看| 亚洲国产精品大全| 亚洲国产精品国自产拍av秋霞| 亚洲国产日韩一区| 欧美性猛交视频| 精品国产一区二区三区久久久狼| 国产精品精品一区二区三区午夜版| 国产精品美女网站| 精品亚洲aⅴ在线观看| 日韩免费高清在线观看| 欧美成人sm免费视频| 日韩电影中文 亚洲精品乱码| 欧美在线激情视频| 亚洲欧美中文字幕在线一区| 91在线观看免费高清完整版在线观看| 精品久久久视频| 蜜臀久久99精品久久久久久宅男| 精品久久久视频| 国产欧美日韩中文字幕在线| 日韩综合中文字幕| 亚洲影院色无极综合| 色婷婷久久一区二区| 5566日本婷婷色中文字幕97| 亚洲午夜女主播在线直播| 日韩中文字幕在线看| 国产精品免费看久久久香蕉| 日韩国产中文字幕| 国产精品激情av电影在线观看| 国产在线观看精品| 国产亚洲福利一区| 中文字幕欧美日韩精品| 国产91av在线| 亚洲欧洲视频在线| 国产精品1区2区在线观看| 91在线视频精品| 欧美在线免费视频| 国产成人午夜视频网址| 欧美成人精品xxx| 久久久精品视频成人| 日韩中文字幕av| 欧美视频免费在线| 狠狠色狠色综合曰曰| 97在线视频一区| 欧美亚洲在线视频| 中文字幕亚洲综合久久| 亚洲无限乱码一二三四麻| 欧洲成人在线观看| 在线播放国产一区中文字幕剧情欧美| 久久久久久久久久久久av| 欧美日韩日本国产| 正在播放欧美一区| 国产精品专区h在线观看| 岛国av在线不卡| 亚洲中国色老太| 亚洲黄一区二区| 亚洲精品99999| 日韩成人激情影院| 久久精品福利视频| 亚洲欧美日韩一区二区在线| 欧洲中文字幕国产精品| 欧美大码xxxx| 亚洲午夜精品视频| 久久久国产精彩视频美女艺术照福利| 亚洲日本欧美日韩高观看| 国产亚洲精品美女久久久| 色先锋资源久久综合5566| 日韩免费在线看| 国产97人人超碰caoprom| 亚洲国产精品久久久久| 国产狼人综合免费视频| 亚洲精品v欧美精品v日韩精品| 浅井舞香一区二区| 国产视频久久久| 久久中文字幕在线视频| 日韩精品在线免费播放| 欧美精品一区二区三区国产精品| 97热在线精品视频在线观看| 久久免费国产精品1|