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进行截取替代js的substring
Sep 02 HTML / CSS
CSS3选择器新增问题的实现
Jan 21 HTML / CSS
详解HTML5新增标签
Nov 27 HTML / CSS
Html5 实现微信分享及自定义内容的流程
Aug 20 HTML / CSS
Html5如何唤起百度地图App的方法
Jan 27 HTML / CSS
html5的画布canvas——画出简单的矩形、三角形实例代码
Jun 09 HTML / CSS
HTML5注册表单的自动聚焦与占位文本示例代码
Jul 19 HTML / CSS
使用HTML5的Canvas绘制曲线的简单方法
Sep 08 HTML / CSS
HTML5页面音视频在微信和app下自动播放的实现方法
Oct 20 HTML / CSS
HTML5 通过Vedio标签实现视频循环播放的示例代码
Aug 05 HTML / CSS
AmazeUI 手机版页面的顶部导航条Header与侧边导航栏offCanvas的示例代码
Aug 19 HTML / CSS
使用CSS设置滚动条样式
Jan 18 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
在php中取得image按钮传递的name值
2006/10/09 PHP
用文本文件制作留言板提示(上)
2006/10/09 PHP
解析php通过cookies获取远程网页的指定代码
2013/06/25 PHP
php无限分类使用concat如何实现
2015/11/05 PHP
thinkPHP查询方式小结
2016/01/09 PHP
PHP观察者模式示例【Laravel框架中有用到】
2018/06/15 PHP
JavaScript语法着色引擎(demo及打包文件下载)
2007/06/13 Javascript
javascript与webservice的通信实现代码
2010/12/25 Javascript
关于IE BUG与字符串截取substr的解决办法
2013/04/10 Javascript
Jquery Uploadify多文件上传带进度条且传递自己的参数
2013/08/28 Javascript
JavaScript中property和attribute的区别详细介绍
2015/03/03 Javascript
JavaScript点击按钮后弹出透明浮动层的方法
2015/05/11 Javascript
在AngularJS中使用jQuery的zTree插件的方法
2016/04/21 Javascript
JS和jQuery使用submit方法无法提交表单的原因分析及解决办法
2016/05/17 Javascript
javascript中this关键字详解
2016/12/12 Javascript
jquery实现文字单行横移或翻转(上下、左右跳转)
2017/01/08 Javascript
深入理解Angularjs中$http.post与$.post
2017/05/19 Javascript
jQuery控制input只能输入数字和两位小数的方法
2019/05/16 jQuery
mpvue实现左侧导航与右侧内容的联动
2019/10/21 Javascript
python基础教程之lambda表达式使用方法
2014/02/12 Python
Python中使用asyncio 封装文件读写
2016/09/11 Python
Python 处理数据的实例详解
2017/08/10 Python
转换科学计数法的数值字符串为decimal类型的方法
2018/07/16 Python
Python 调用 zabbix api的方法示例
2019/01/06 Python
Python面向对象程序设计示例小结
2019/01/30 Python
CSS3教程(10):CSS3 HSL声明设置颜色
2009/04/02 HTML / CSS
用HTML5实现手机摇一摇的功能的教程
2012/10/30 HTML / CSS
武汉瑞得软件笔试题
2015/10/27 面试题
幼儿园庆六一游园活动方案
2014/01/29 职场文书
世界红十字日活动总结
2015/02/10 职场文书
出国留学导师推荐信
2015/03/26 职场文书
《海上日出》教学反思
2016/02/23 职场文书
python调试工具Birdseye的使用教程
2021/05/25 Python
Mysql事务索引知识汇总
2022/03/17 MySQL
python神经网络 使用Keras构建RNN训练
2022/05/04 Python
IDEA中sout快捷键无效问题的解决方法
2022/07/23 Java/Android