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

首頁 > 開發(fā) > HTML5 > 正文

HTML實(shí)現(xiàn)代碼雨源碼及效果示例

2024-09-05 07:23:17
字體:
供稿:網(wǎng)友

最近學(xué)習(xí)了HTML,今天寫個(gè)HTML代碼雨,然后下面用HTML和js也寫了一個(gè),給自己留點(diǎn)筆記

先看看效果

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;    //動(dòng)畫繪制對(duì)象    var requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame;    var codeRainArr = []; //代碼雨數(shù)組    var cols = parseInt(cw / 14); //代碼雨列數(shù)    var step = 16;    //步長(zhǎng),每一列內(nèi)部數(shù)字之間的上下間隔    ctx.font = "bold 26px microsoft yahei"; //聲明字體,個(gè)人喜歡微軟雅黑     function createColorCv() {        //畫布基本顏色        ctx.fillStyle = "#242424";        ctx.fillRect(0, 0, cw, ch);    }     //創(chuàng)建代碼雨    function createCodeRain() {        for (var n = 0; n < cols; n++) {            var col = [];            //基礎(chǔ)位置,為了列與列之間產(chǎn)生錯(cuò)位            var basePos = parseInt(Math.random() * 300);            //隨機(jī)速度 3~13之間            var speed = parseInt(Math.random() * 10) + 3;            //每組的x軸位置隨機(jī)產(chǎn)生            var colx = parseInt(Math.random() * cw)             //綠色隨機(jī)            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  //隨機(jī)生成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)], //隨機(jī)生成字母數(shù)組中的一個(gè)                    color: "rgb(" + rgbr + ',' + rgbg + ',' + rgbb + ")"                }                col.push(code);            }            codeRainArr.push(col);        }    }     //代碼雨下起來    function codeRaining() {        //把畫布擦干凈        ctx.clearRect(0, 0, cw, ch);        //創(chuàng)建有顏色的畫布        //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 顏色也隨機(jī)變化                //ctx.fillStyle = "hsl("+(parseInt(Math.random()*359)+1)+",30%,"+(50-i*2)+"%)";                  //2 綠色逐漸變淺                // ctx.fillStyle = "hsl(123,80%,"+(30-i*2)+"%)";                  //3 綠色隨機(jī)                // 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);    }     //創(chuàng)建代碼雨    createCodeRain();    //開始下雨吧 GO>>    requestAnimationFrame(codeRaining);</script>   </body></html>

更多代碼雨的文章請(qǐng)參考我的其它文章:

“代碼雨”js+css+html實(shí)現(xiàn)

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;}

 到此這篇關(guān)于HTML實(shí)現(xiàn)代碼雨源碼及效果示例的文章就介紹到這了,更多相關(guān)HTML代碼雨內(nèi)容請(qǐng)搜索武林網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持武林網(wǎng)!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: av免费在线播放网址 | 九一免费版在线观看 | 欧美色淫| 国产妇女乱码一区二区三区 | 国产亚洲精品yxsp | 欧美日韩国产一区二区三区在线观看 | 国产精品视频在 | 久久亚洲精品久久国产一区二区 | 国产精品高清一区 | 成人片免费视频 | 久久精品视频3 | 国产一国产一级毛片视频在线 | 日韩精品中文字幕一区二区三区 | 一级免费看片 | 草b视频在线观看 | 久草在线观看福利视频 | 久久噜噜噜 | 免费看欧美一级特黄a大片 久久免费视频一区二区三区 | 免费国产成人高清在线看软件 | 久久最新网址 | 91看片免费版 | 国产毛片毛片 | 在线观看国产日韩 | 国产精品成人免费一区久久羞羞 | 久久思思爱 | 关键词 | 羞羞的动漫在线观看 | 性 毛片| 男女无套免费视频 | 狠狠干91 | 72pao成人国产永久免费视频 | 国产精品九九久久一区hh | www亚洲免费| 天天碰天天操 | 久久久久国产一区二区三区不卡 | 精品一区二区亚洲 | 美女黄视频在线观看 | 今井夏帆av一区二区 | 精品在线观看一区二区 | 成年人黄色片视频 | 成人毛片100部免费观看 |