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教程:background-clip和background-origin
Oct 17 HTML / CSS
css3圆角样式分享自定义按钮样式
Dec 27 HTML / CSS
利用CSS3实现文本框的清除按钮相关的一些效果
Jun 23 HTML / CSS
深入剖析webstorage[html5的本地数据处理]
Jul 11 HTML / CSS
详解基于 Canvas 手撸一个六边形能力图
Sep 02 HTML / CSS
探讨HTML5移动开发的几大特性(必看)
Dec 30 HTML / CSS
HTML5不支持标签和新增标签详解
Jun 27 HTML / CSS
AmazeUI 评论列表的实现示例
Aug 13 HTML / CSS
HTML5逐步分析实现拖放功能的方法
Sep 30 HTML / CSS
浅谈移动端中的视口(viewport)的具体使用
Apr 13 HTML / CSS
html+css实现分层金字塔的实例
Jun 02 HTML / CSS
分享几个实用的CSS代码块
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
PHP扩展编写点滴 技巧收集
2010/03/09 PHP
PHP crypt()函数的用法讲解
2019/02/15 PHP
Javascript下IE与Firefox下的差异兼容写法总结
2010/06/18 Javascript
JavaScript操作XML 使用百度RSS作为新闻源示例
2012/02/17 Javascript
js获取RadioButtonList的Value/Text及选中值等信息实现代码
2013/03/05 Javascript
基于JavaScript实现瀑布流布局(二)
2016/01/26 Javascript
js判断输入字符串是否为空、空格、null的方法总结
2016/06/14 Javascript
JS动态的把左边列表添加到右边的实现代码(可上下移动)
2016/11/17 Javascript
微信小程序页面传值实例分析
2017/04/19 Javascript
Bootstrap框架建立树形菜单(Tree)的实例代码
2017/10/30 Javascript
3种vue组件的书写形式
2017/11/29 Javascript
详解nodejs通过响应回写的方式渲染页面资源
2018/04/07 NodeJs
vuedraggable+element ui实现页面控件拖拽排序效果
2020/07/29 Javascript
js中事件对象和事件委托的介绍
2019/01/21 Javascript
vue实现的网易云音乐在线播放和下载功能案例
2019/02/18 Javascript
JavaScript实现Tab标签页切换的最简便方式(4种)
2020/06/28 Javascript
vue-simple-uploader上传成功之后的response获取代码
2020/09/07 Javascript
[57:59]EG vs Secret 2018国际邀请赛淘汰赛BO3 第一场 8.22
2018/08/23 DOTA
Python常用正则表达式符号浅析
2014/08/13 Python
Python实现简单登录验证
2016/04/13 Python
Python爬取qq music中的音乐url及批量下载
2017/03/23 Python
Python简单实现查找一个字符串中最长不重复子串的方法
2018/03/26 Python
python自动循环定时开关机(非重启)测试
2019/08/26 Python
python使用numpy实现直方图反向投影示例
2020/01/17 Python
基于python实现上传文件到OSS代码实例
2020/05/09 Python
HTML如何让IMG自动适应DIV容器大小的实现方法
2020/02/25 HTML / CSS
Viking Direct爱尔兰:办公用品和家具
2019/11/21 全球购物
模特职业生涯规划范文
2014/02/26 职场文书
艺术学院毕业生自我评价
2014/03/02 职场文书
家长写给孩子的评语
2014/04/18 职场文书
简单的个人租房协议书范本
2014/11/26 职场文书
护士求职简历自我评价
2015/03/10 职场文书
学习委员竞选稿
2015/11/20 职场文书
致创业的您:这类人不适合餐饮创业
2019/08/19 职场文书
Python数据分析入门之教你怎么搭建环境
2021/05/13 Python
搞笑Gif:这么白这么长的腿像极了一楼的女朋友
2022/03/21 杂记