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 相关文章推荐
DIV菜单层实现代码
Nov 19 Javascript
利用jq让你的div居中的好方法分享
Nov 21 Javascript
JavaScript操作Cookie方法实例分析
May 27 Javascript
javascript实现输出指定行数正方形图案的方法
Aug 03 Javascript
Cookies 和 Session的详解及区别
Apr 21 Javascript
hammer.js实现图片手势放大效果
Aug 29 Javascript
简述JS控制台的使用
Jul 15 Javascript
vue-vuex中使用commit提交mutation来修改state的方法详解
Sep 16 Javascript
layui添加动态菜单与选项卡 AJAX请求的例子
Sep 25 Javascript
vscode调试node.js的实现方法
Mar 22 Javascript
JavaScript设计模式之观察者模式与发布订阅模式详解
May 07 Javascript
Javascript的promise,async和await的区别详解
Mar 24 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
thinkPHP下的widget扩展用法实例分析
2015/12/26 PHP
php自动加载方式集合
2016/04/04 PHP
php链式操作的实现方式分析
2019/08/12 PHP
TP5框架实现一次选择多张图片并预览的方法示例
2020/04/04 PHP
jQuery使用一个按钮控制图片的伸缩实现思路
2013/04/19 Javascript
使用js+jquery实现无限极联动
2013/05/23 Javascript
当鼠标移动到图片上时跟随鼠标显示放大的图片效果
2013/06/06 Javascript
jQuery Ajax异步处理Json数据详解
2013/11/05 Javascript
JavaScript中的公有、私有、特权和静态成员用法分析
2014/11/20 Javascript
jQuery判断元素是否显示 是否隐藏的简单实现代码
2016/05/19 Javascript
JavaScript实现九九乘法表的简单实例
2016/06/07 Javascript
原生JavaScript实现的简单省市县三级联动功能示例
2017/05/27 Javascript
Vue.js实现一个todo-list的上移下移删除功能
2017/06/26 Javascript
利用JavaScript如何查询某个值是否数组内
2017/07/30 Javascript
cocos creator Touch事件应用(触控选择多个子节点的实例)
2017/09/10 Javascript
初学者AngularJS的环境搭建过程
2017/10/27 Javascript
在 Linux/Unix 中不重启 Vim 而重新加载 .vimrc 文件的流程
2018/03/21 Javascript
vue2使用keep-alive缓存多层列表页的方法
2018/09/21 Javascript
nodejs简单抓包工具使用详解
2019/08/23 NodeJs
微信小程序之滑动页面隐藏和显示组件功能的实现代码
2020/06/19 Javascript
原生js+canvas实现验证码
2020/11/29 Javascript
[10:34]DOTA2上海特级锦标赛全纪录
2016/03/25 DOTA
Python 返回汉字的汉语拼音
2009/02/27 Python
python实现simhash算法实例
2014/04/25 Python
python从入门到精通(DAY 2)
2015/12/20 Python
python下调用pytesseract识别某网站验证码的实现方法
2016/06/06 Python
Django内容增加富文本功能的实例
2017/10/17 Python
python中rb含义理解
2020/06/18 Python
Keras自动下载的数据集/模型存放位置介绍
2020/06/19 Python
基于python实现生成指定大小txt文档
2020/07/20 Python
台湾线上百货零售购物平台:friDay购物
2017/08/18 全球购物
俄罗斯品牌服装和鞋子的在线商店:KUPIVIP
2019/10/27 全球购物
精细化工应届生求职信
2013/11/17 职场文书
入党积极分子自我鉴定
2014/02/18 职场文书
羽毛球社团活动总结
2014/06/27 职场文书
使用CSS3实现按钮悬停闪烁动态特效代码
2021/08/30 HTML / CSS