JavaScript canvas仿代码流瀑布


Posted in Javascript onFebruary 10, 2020

本文实例为大家分享了canvas仿代码流瀑布的具体代码,供大家参考,具体内容如下

JavaScript canvas仿代码流瀑布

在js部分写canvas代码,有详细注释

html部分:

一个canvas元素:

<canvas id="canvas" ></canvas>

css部分:

<style>
  *{
   padding: 0;
   margin: 0;
  }
  canvas{
   background-color: #111;
  }
  body{
   overflow: hidden;
  
  }
</style>
<script>
  var canvas = document.getElementById('canvas');
  var context = canvas.getContext('2d');
  // 获取浏览器的宽度和高度
  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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript中rem布局在react中的应用
Dec 09 Javascript
JS创建对象几种不同方法详解
Mar 01 Javascript
JS事件添加和移出的兼容写法示例
Jun 20 Javascript
用js写的一个路由(简单实例)
Sep 24 Javascript
基于jQuery制作小图标上下滑动特效
Jan 18 Javascript
Vue2.0利用 v-model 实现组件props双向绑定的优美解决方案
Mar 13 Javascript
微信小程序表单验证错误提示效果
May 19 Javascript
Bootstrap Table使用整理(三)
Jun 09 Javascript
Vue入门之animate过渡动画效果
Apr 08 Javascript
vue-cli3环境变量与分环境打包的方法示例
Feb 18 Javascript
微信小程序实现跳转的几种方式总结(推荐)
Apr 24 Javascript
JavaScript简易计算器制作
Jan 17 Javascript
Vue数字输入框组件使用方法详解
Feb 10 #Javascript
JavaScript canvas实现跟随鼠标事件
Feb 10 #Javascript
JavaScript实现简易聊天对话框(加滚动条)
Feb 10 #Javascript
node.js使用 http-proxy 创建代理服务器操作示例
Feb 10 #Javascript
node.js中 redis 的安装和基本操作示例
Feb 10 #Javascript
js实现登录拖拽窗口
Feb 10 #Javascript
javascript 原型与原型链的理解及应用实例分析
Feb 10 #Javascript
You might like
PHP的Socket网络编程入门指引
2015/08/11 PHP
php 生成Tab键或逗号分隔的CSV
2016/09/24 PHP
PHP微商城开源代码实例
2019/03/27 PHP
基础的prototype.js常用函数及其用法
2007/03/10 Javascript
JS检测图片大小的实例
2013/08/21 Javascript
jquery代码实现简单的随机图片瀑布流效果
2015/04/20 Javascript
JS实现控制文本框的内容
2016/07/10 Javascript
javascript实现下雨效果
2017/03/27 Javascript
D3.js进阶系列之CSV表格文件的读取详解
2017/06/06 Javascript
js es6系列教程 - 新的类语法实战选项卡(详解)
2017/09/02 Javascript
JS脚本实现网页自动秒杀点击
2018/01/11 Javascript
mpvue 如何使用腾讯视频插件的方法
2018/07/16 Javascript
[49:54]Ti4 循环赛第三日 LGD vs Titan
2014/07/12 DOTA
跟老齐学Python之类的细节
2014/10/13 Python
Python实现截屏的函数
2015/07/26 Python
Python函数式编程
2017/07/20 Python
Python实现的计数排序算法示例
2017/11/29 Python
Python之ReportLab绘制条形码和二维码的实例
2018/01/15 Python
django 将model转换为字典的方法示例
2018/10/16 Python
Django外键(ForeignKey)操作以及related_name的作用详解
2019/07/29 Python
Python面向对象封装操作案例详解
2019/12/31 Python
Pytorch使用MNIST数据集实现CGAN和生成指定的数字方式
2020/01/10 Python
Python常用库大全及简要说明
2020/01/17 Python
Python多进程multiprocessing、进程池用法实例分析
2020/03/24 Python
HTML5 Canvas中绘制矩形实例
2015/01/01 HTML / CSS
美国最古老的精致书写工具制造商:A.T. Cross(高仕)
2018/01/30 全球购物
美国校服网上商店:French Toast
2019/10/08 全球购物
应届生的求职推荐信范文
2013/11/30 职场文书
英文自我鉴定
2013/12/10 职场文书
银行个人求职自荐信范文
2013/12/16 职场文书
中专药剂专业应届毕的自我评价
2013/12/27 职场文书
工作过失检讨书
2014/02/23 职场文书
捐款感谢信
2015/01/20 职场文书
欠款起诉书范文
2015/05/19 职场文书
尊师重教主题班会
2015/08/14 职场文书
Python绘制分类图的方法
2021/04/20 Python