首頁 > web前端 > H5教程 > HTML5 canvas如何實作程式碼流瀑布? (附代碼)

HTML5 canvas如何實作程式碼流瀑布? (附代碼)

青灯夜游
發布: 2020-06-17 10:30:58
轉載
4620 人瀏覽過

本篇文章跟大家分享HTML5 canvas程式碼流瀑布的具體程式碼。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

HTML5 canvas如何實作程式碼流瀑布? (附代碼)

在js部分寫canvas程式碼,有詳細註解

#html部分:

一個canvas元素:

<canvas id="canvas" ></canvas>
登入後複製

css部分:

<style>
  *{
   padding: 0;
   margin: 0;
  }
  canvas{
   background-color: #111;
  }
  body{
   overflow: hidden;
  
  }
</style>
登入後複製

js部分

<script>
  var canvas = document.getElementById(&#39;canvas&#39;);
  var context = canvas.getContext(&#39;2d&#39;);
  // 获取浏览器的宽度和高度
  var w = window.innerWidth;
  var h = window.innerHeight;
  // 设置canvas的宽高
  canvas.width = w;
  canvas.height = h;
  // 每个文字的大小
  var fontSize = 16;
  // 一共可以有多少列文字
  var col = Math.floor(w / fontSize);
  // 记录每列文字的y轴坐标
  var cpy = [];
  for(var i = 0;i< col; i++)
  {
   cpy[i] = 1;
  }
  //定义文字
  var str = "Javascriphafhsdhfsfsf{}";
  // 绘制
  draw();
  setInterval(draw,30);
  function draw(){
   context.beginPath();
   // 背景填充颜色
   context.fillStyle = "rgba(0,0,0,0.05)";
   context.fillRect(0,0,w,h);
   // 设置字体大小
   context.font = fontSize +"px bold 微软雅黑 ";
   // 设置字体颜色
   context.fillStyle = "#00cc33";
   for(var i = 0; i < col;i++)
   {
    var index = Math.floor(Math.random()*str.length);
    var x = i*fontSize;
    var y = cpy[i]*fontSize;
    context.fillText(str.charAt(index),x,y);
    if(y >= h && Math.random()> 0.99)// 出现时间延迟的效果
    {
     cpy[i]=0;// 只要Math.random> 0.99 时才纵坐标从0开始写字
    }
    cpy[i]++;// 数组值加一,以便下一次写的字在下面一行
   }
  }
</script>
登入後複製

動態效果圖:

HTML5 canvas如何實作程式碼流瀑布? (附代碼)

更多酷特效,推薦訪問:js特效大全

以上是HTML5 canvas如何實作程式碼流瀑布? (附代碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
javascript - js addClass 無效
來自於 1970-01-01 08:00:00
0
0
0
php呼叫js並取得js的回傳值問題
來自於 1970-01-01 08:00:00
0
0
0
js進階教程
來自於 1970-01-01 08:00:00
0
0
0
找不到js檔案程式碼
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板