HTML5 canvas 瀑布流文字效果的示例代码


Posted in HTML / CSS onJanuary 31, 2018

今天,小编将与大家分享web前端特效荟萃系列第十三期,喜欢把玩儿炫酷效果的小伙伴快快看过来^_^ ,希望大家喜欢呦~

HTML5 canvas 瀑布流文字效果的示例代码

给大家分享一个使用HTML5 canvas 形成的瀑布流文字效果,非常酷炫!相关代码如下:

<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>cloth</title>
  <style>
    *{
  padding: 0;
  margin: 0;
}
body{
 background:#000;
}   
  </style>
</head>
<body>
  <div id="container">
 <canvas id="c"></canvas>
</div>
<script type="text/javascript" src="http://cdn.gbtags.com/jquery/1.11.1/jquery.min.js"></script>
<script>
    var c = document.getElementById("c");
var ctx = c.getContext("2d");

//制作全屏
c.height = window.innerHeight;
c.width = window.innerWidth;

//汉字从Unicode字符集
var chinese = "igeekbar~";
//将字符串转换为一个数组中的单个字符
chinese = chinese.split("");

var font_size = 20;
var columns = c.width/font_size; //雨的列数
//每列的一个数组
var drops = [];
//下面是×坐标
//1 = y 在下降(最初是相同的)
for(var x = 0; x < columns; x++)
 drops[x] = 1; 

//画
function draw()
{
 //黑BG的帆布
 //半透明BG显示轨迹
 ctx.fillStyle = "rgba(0, 0, 0, 0.05)";
 ctx.fillRect(0, 0, c.width, c.height);
 
 ctx.fillStyle = "#0F0"; //字体颜色
 ctx.font = font_size + "px arial";
 //循环字体
 for(var i = 0; i < drops.length; i++)
 {
  //随机汉字打印
  var text = chinese[Math.floor(Math.random()*chinese.length)];
  //x = i*font_size, y = value of drops[i]*font_size
  ctx.fillText(text, i*font_size, drops[i]*font_size);
  
  //在屏幕上划线后,把它的顶部随机发送到顶部
  //将一个随机性添加到复位中,使分散在轴上的下降
  if(drops[i]*font_size > c.height && Math.random() > 0.975)
   drops[i] = 0;
  
  //增加的Y坐标
  drops[i]++;
 }
}

setInterval(draw, 33);
</script>
</body>
</html>

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

HTML / CSS 相关文章推荐
纯CSS3制作的鼠标悬停时边框旋转
Jan 03 HTML / CSS
css3如何绘制一个圆圆的loading转圈动画
Jan 09 HTML / CSS
CSS3解析抖音LOGO制作的方法步骤
Apr 11 HTML / CSS
CSS3实现网站商品展示效果图
Jan 18 HTML / CSS
html5应用缓存_动力节点Java学院整理
Jul 13 HTML / CSS
基于HTML5代码实现折叠菜单附源码下载
Nov 27 HTML / CSS
HTML5语义化元素你真的用对了吗
Aug 22 HTML / CSS
Html5实现首页动态视频背景的示例代码
Sep 25 HTML / CSS
h5移动端调用支付宝、微信支付的实现
Jun 08 HTML / CSS
深入理解CSS 中 transform matrix矩阵变换问题
Aug 30 HTML / CSS
企业开发CSS命名BEM代码规范实践
Feb 12 HTML / CSS
css样式important规则的正确使用方式
Jun 10 HTML / CSS
HTML5 WebSocket实现点对点聊天的示例代码
Jan 31 #HTML / CSS
详解html2canvas截图不能截取圆角图片的解决方案
Jan 30 #HTML / CSS
HTML5 Canvas实现360度全景图的示例代码
Jan 29 #HTML / CSS
详解canvas多边形(蜘蛛图)的画法示例
Jan 29 #HTML / CSS
HTML5 source标签:媒介元素定义媒介资源
Jan 29 #HTML / CSS
HTML5仿微信聊天界面、微信朋友圈实例代码
Jan 29 #HTML / CSS
详解HTML5 data-* 自定义属性
Jan 24 #HTML / CSS
You might like
Apache2中实现多网站域名绑定的实现方法
2011/06/01 PHP
PHP实现笛卡尔积算法的实例讲解
2019/12/22 PHP
PHP SESSION跨页面传递失败解决方案
2020/12/11 PHP
escape、encodeURI、encodeURIComponent等方法的区别比较
2006/12/27 Javascript
用jscript实现新建word文档
2007/06/15 Javascript
使用jQuery全局事件ajaxStart为特定请求实现提示效果的代码
2010/12/30 Javascript
javascript学习笔记(一) 在html中使用javascript
2012/06/18 Javascript
JavaScript 学习笔记之一jQuery写法图片等比缩放以及预加载
2012/06/28 Javascript
单击按钮显示隐藏子菜单经典案例
2013/01/04 Javascript
JS冒泡事件的快速解决方法
2013/12/16 Javascript
JavaScript实现Flash炫光波动特效
2015/05/14 Javascript
Jquery数字上下滚动动态切换插件
2015/08/08 Javascript
jQuery插件cxSelect多级联动下拉菜单实例解析
2016/06/24 Javascript
javascript中Date对象的使用总结
2016/11/21 Javascript
JavaScript中undefined和null的区别
2017/05/03 Javascript
Vue动态实现评分效果
2017/05/24 Javascript
对angularJs中ng-style动态改变样式的实例讲解
2018/09/30 Javascript
JS跨域请求的问题解析
2018/12/03 Javascript
实现vuex与组件data之间的数据同步更新方式
2019/11/12 Javascript
uni-app如何实现增量更新功能
2020/01/03 Javascript
nodejs对mongodb数据库的增加修删该查实例代码
2020/01/05 NodeJs
vue3.0 项目搭建和使用流程
2021/03/04 Vue.js
python的几种开发工具介绍
2007/03/07 Python
Python读取图片为16进制表示简单代码
2018/01/19 Python
使用pandas将numpy中的数组数据保存到csv文件的方法
2018/06/14 Python
Python通过递归获取目录下指定文件代码实例
2019/11/07 Python
Python实现将蓝底照片转化为白底照片功能完整实例
2019/12/13 Python
python opencv 实现对图像边缘扩充
2020/01/19 Python
学生档案自我鉴定
2013/10/07 职场文书
餐厅总经理岗位职责
2013/12/31 职场文书
校友会欢迎辞
2014/01/13 职场文书
同学聚会老师邀请函
2014/01/28 职场文书
课外活动总结
2015/02/04 职场文书
怒海潜将观后感
2015/06/11 职场文书
幼儿园保教工作总结2015
2015/10/15 职场文书
2016年机关单位节能宣传周活动总结
2016/04/05 职场文书