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 相关文章推荐
10 套华丽的CSS3 按钮小结
Oct 03 HTML / CSS
用CSS3打造HTML5的Logo(实现代码)
Jun 16 HTML / CSS
CSS3制作hover下划线动画
Mar 27 HTML / CSS
html5嵌入内容_动力节点Java学院整理
Jul 07 HTML / CSS
HTML5的hidden属性兼容老浏览器的方法
Apr 23 HTML / CSS
利用HTML5 Canvas制作一个简单的打飞机游戏
May 11 HTML / CSS
使用html5 canvas 画时钟代码实例分享
Nov 11 HTML / CSS
详解移动端html5页面长按实现高亮全选文本内容的兼容解决方案
Dec 03 HTML / CSS
HTML5为输入框添加语音输入功能的实现方法
Feb 06 HTML / CSS
深入理解HTML5定时器requestAnimationFrame的使用
Dec 12 HTML / CSS
canvas 橡皮筋式线条绘图应用方法
Feb 13 HTML / CSS
使用postMessage让 iframe自适应高度的方法示例
Oct 08 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使用数据库永久连接方式操作MySQL的是与非
2013/06/05 PHP
2个比较经典的PHP加密解密函数分享
2014/07/01 PHP
PHP管理依赖(dependency)关系工具 Composer 安装与使用
2014/08/18 PHP
Laravel中Facade的加载过程与原理详解
2017/09/22 PHP
PHP实现倒计时功能
2020/11/16 PHP
seaJs的模块定义和模块加载浅析
2014/06/06 Javascript
简单的jquery左侧导航栏和页面选中效果
2014/08/21 Javascript
15款jQuery分布引导插件分享
2015/02/04 Javascript
js实现网站最上边可关闭的浮动广告条代码
2015/09/04 Javascript
JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
2016/01/26 Javascript
详解VueJs前后端分离跨域问题
2017/05/24 Javascript
JS通过调用微信API实现微信支付功能的方法示例
2017/06/29 Javascript
Angular.js组件之input mask对input输入进行格式化详解
2017/07/10 Javascript
原生JS实现DOM加载完成马上执行JS代码的方法
2018/09/07 Javascript
Vue动画事件详解及过渡动画实例
2019/02/09 Javascript
微信小程序实现拨打电话功能的示例代码
2020/06/28 Javascript
[02:38]DOTA2亚洲邀请赛小组赛精彩集锦:Wings完美团击溃对手
2017/03/29 DOTA
Python yield 使用方法浅析
2017/05/20 Python
win10下python3.5.2和tensorflow安装环境搭建教程
2018/09/19 Python
PyQt5 在label显示的图片中绘制矩形的方法
2019/06/17 Python
python找出因数与质因数的方法
2019/07/25 Python
pytorch下大型数据集(大型图片)的导入方式
2020/01/08 Python
Pytorch 卷积中的 Input Shape用法
2020/06/29 Python
HTML5中使用postMessage实现两个网页间传递数据
2016/06/22 HTML / CSS
联想中国官方商城:Lenovo China
2017/10/18 全球购物
马来西亚在线健康商店:Medipal Malaysia
2020/04/13 全球购物
英语演讲稿范文
2014/01/03 职场文书
员工考核管理制度
2014/02/02 职场文书
2014年组织部工作总结
2014/11/14 职场文书
先进人物事迹材料
2014/12/29 职场文书
亚布力滑雪场导游词
2015/02/09 职场文书
幼儿教师师德师风自我评价
2015/03/05 职场文书
接待员岗位职责范本
2015/04/15 职场文书
西柏坡观后感
2015/06/08 职场文书
Python 机器学习工具包SKlearn的安装与使用
2021/05/14 Python
SpringMVC 整合SSM框架详解
2021/08/30 Java/Android