JS画布动态实现黑客帝国背景效果


Posted in Javascript onNovember 08, 2020

本文实例为大家分享了JS画布动态实现黑客帝国背景效果的具体代码,供大家参考,具体内容如下

效果图

JS画布动态实现黑客帝国背景效果

完整代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <style>
    *{
      padding:0;
      margin:0;
    }
    body{
      overflow: hidden;
    }
  </style>
</head>
<body>
    <canvas id="mom" style="background:#111"></canvas>
  <script>
   window.onload = function(){
    //获取画布对象
    var canvas = document.getElementById("mom");
    //获取画布的上下文
    //getContext() 方法返回一个用于在画布上绘图的环境。
    var context =canvas.getContext("2d");
    //获取浏览器屏幕的宽度和高度
    var W = window.innerWidth;
    var H = window.innerHeight;
    //设置canvas的宽度和高度
    canvas.width = W;
    canvas.height = H;
    //每个文字的字体大小
    var fontSize = 16;
    //计算列
    var colunms = Math.floor(W /fontSize);
    //记录每列文字的y轴坐标
    var drops = [];
    //给每一个文字初始化一个起始点的位置
    //计算每一个文字所谓坐标 存储y轴的坐标 
    for(var i=0;i<colunms;i++){
      drops.push(0);
    }
    //运动的文字
    var str ="JavaScript function(){}";
    //4:fillText(str,x,y);原理就是去更改y的坐标位置
    //绘画的函数
    function draw(){
      context.fillStyle = "rgba(0,0,0,0.05)";
      //fillRect() 方法绘制“已填色”的矩形。默认的填充颜色是黑色。
      context.fillRect(0,0,W,H);
      //给字体设置样式
      context.font = "700 "+fontSize+"px 微软雅黑";
      //给字体添加颜色
      context.fillStyle ="#00cc33";//可以rgb,hsl, 标准色,十六进制颜色
      //写入画布中
      for(var i=0;i<colunms;i++){
        var index = Math.floor(Math.random() * str.length);//设置文字出发时间随机 Math.floor(Math.random()*str.length)让数组里面的文字索引随机出现 
        var x = i*fontSize;
        var y = drops[i] *fontSize;//也让y轴方向也向下掉一个文字的距离
        context.fillText(str[index],x,y);
        // //如果要改变时间,肯定就是改变每次他的起点
        if(y >= canvas.height && Math.random()>0.99){
          drops[i] = 0;
        }
        drops[i]++;//让数组里面的值每次加一,用于上面的y轴下掉 
      }
    };
    //随机颜色
    function randColor(){
      var r = Math.floor(Math.random() * 256);
      var g = Math.floor(Math.random() * 256);
      var b = Math.floor(Math.random() * 256);
      return "rgb("+r+","+g+","+b+")";
    }
    draw();
    setInterval(draw,20);
  };
  </script>
</body>
</html>

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

Javascript 相关文章推荐
学习ExtJS 访问容器对象
Oct 07 Javascript
AngularJS基础教程之简单介绍
Sep 27 Javascript
JavaScript+html5 canvas实现本地截图教程
Apr 16 Javascript
JS弹出层遮罩,隐藏背景页面滚动条细节优化分析
Apr 29 Javascript
基于angularjs实现图片放大镜效果
Aug 31 Javascript
node使用promise替代回调函数
May 07 Javascript
Angular5中状态管理的实现
Sep 03 Javascript
Node.js+Express+Mysql 实现增删改查
Apr 03 Javascript
JS中实现浅拷贝和深拷贝的代码详解
Jun 05 Javascript
vue中filters 传入两个参数 / 使用两个filters的实现方法
Jul 15 Javascript
JS面向对象实现飞机大战
Aug 26 Javascript
解决vue项目中遇到 Cannot find module ‘chalk‘ 报错的问题
Nov 05 Javascript
vue.js页面加载执行created,mounted的先后顺序说明
Nov 07 #Javascript
Node.js path模块,获取文件后缀名操作
Nov 07 #Javascript
解决vue props传Array/Object类型值,子组件报错的情况
Nov 07 #Javascript
解决Vue watch里调用方法的坑
Nov 07 #Javascript
浅谈vue.watch的触发条件是什么
Nov 07 #Javascript
html+vue.js 实现漂亮分页功能可兼容IE
Nov 07 #Javascript
解决vue watch数据的方法被调用了两次的问题
Nov 07 #Javascript
You might like
php生成WAP页面
2006/10/09 PHP
php在线生成ico文件的代码
2007/10/09 PHP
PHP 配置文件中open_basedir选项作用
2009/07/19 PHP
深入eAccelerator与memcached的区别详解
2013/06/06 PHP
什么是PHP文件?如何打开PHP文件?
2017/06/27 PHP
thinkphp5框架API token身份验证功能示例
2019/05/21 PHP
PHP 99乘法表的几种实现代码
2020/10/13 PHP
javascript高级程序设计第二版第十二章事件要点总结(常用的跨浏览器检测方法)
2012/08/22 Javascript
javascript陷阱 一不小心你就中招了(字符运算)
2013/11/10 Javascript
jQuery 事件的命名空间简单了解
2013/11/22 Javascript
node.js中的path.resolve方法使用说明
2014/12/08 Javascript
用户代理字符串userAgent可实现的四个识别
2015/09/20 Javascript
javascript实现C语言经典程序题
2015/11/29 Javascript
基于jquery实现下拉框美化特效
2016/02/02 Javascript
浅谈JQ中mouseover和mouseenter的区别
2016/09/13 Javascript
详解AngularJS 路由 resolve用法
2017/04/24 Javascript
自制简易打赏功能的实例
2017/09/02 Javascript
Bootstrap一款超好用的前端框架
2017/09/25 Javascript
Vue.js中使用iView日期选择器并设置开始时间结束时间校验功能
2018/08/12 Javascript
[52:15]2014 DOTA2国际邀请赛中国区预选赛5.21 HGT VS LGD-GAMING
2014/05/23 DOTA
Python MD5文件生成码
2009/01/12 Python
python实现简单图片物体标注工具
2019/03/18 Python
python Django中models进行模糊查询的示例
2019/07/18 Python
python文档字符串(函数使用说明)使用详解
2019/07/30 Python
Python PIL图片添加字体的例子
2019/08/22 Python
python 三种方法实现对Excel表格的读写
2020/11/19 Python
Pycharm配置lua编译环境过程图解
2020/11/28 Python
高中毕业生生活的自我评价
2013/12/08 职场文书
促销活动方案模板
2014/02/24 职场文书
政风行风评议心得体会
2014/10/21 职场文书
2014年幼儿园德育工作总结
2014/12/17 职场文书
雷锋的故事观后感
2015/06/10 职场文书
安全生产奖惩制度
2015/08/06 职场文书
使用pytorch实现线性回归
2021/04/11 Python
剧场版《转生恶役只好拔除破灭旗标》公开最新视觉图 2023年上映
2022/04/02 日漫
Ubuntu安装Mysql+启用远程连接的完整过程
2022/06/21 Servers