HTML5 캔버스는 코드 흐름 폭포를 어떻게 구현합니까? (코드 포함)

青灯夜游
풀어 주다: 2020-06-17 10:30:58
앞으로
4452명이 탐색했습니다.

이 기사에서는 HTML5 캔버스 코드 흐름 폭포의 특정 코드를 공유합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

HTML5 캔버스는 코드 흐름 폭포를 어떻게 구현합니까? (코드 포함)

자세한 설명과 함께 js 부분에 캔버스 코드 작성

html 부분:

캔버스 요소:

<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 캔버스는 코드 흐름 폭포를 어떻게 구현합니까? (코드 포함)

더 멋진 특수 효과를 보려면 js 특수 효과 컬렉션을 방문하는 것이 좋습니다!

위 내용은 HTML5 캔버스는 코드 흐름 폭포를 어떻게 구현합니까? (코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!