Canvas 让你的屏幕下一场 Hacker 流星雨吧

IE这种上古神器居然还有人在用??今天来分享一个很狂拽酷炫吊炸天的特效,其装逼效果不亚于上面那张入侵五角大楼导弹制导系统的概念图(手动滑稽),实现起来很简单,跟着动手一起来吧

正如标题所提到的,我们使用到了canvas元素,你可以理解为是一张画布,有了画布之后,我们就要在画布上进行绘制,而canvas元素本身是不具备绘图能力的,所以我们要借助 JavaScript 来完成绘制工作

HTML 的结构我们只需要一个标签就够了,若是在低版本的浏览器中,我们还是要提醒一下浏览器需要升级了

<canvas id="canvas"> 

IE这种上古神器居然还有人在用?

</canvas>

设置全局 CSS 样式,很简单,代码如下:

*{margin:0px;padding:0px;}

body{overflow:hidden;}

获取浏览器屏幕并设置其宽高,设置一个包含 256 个空元素的数组,.join("1")用 1 来把数组里的元素拼接为字符串,.split("")过滤掉数组里的空元素

const canvas = document.getElementById("canvas"),

ctx    = canvas.getContext("2d"),

s      = window.screen,

w      = canvas.width = s.width,

h      = canvas.height = s.height;

let  words  = Array(256).join("1").split("");

随后绘制矩形,设置填充的颜色及文本

setInterval( () => {

ctx.fillStyle = "rgba(0, 0, 0, 0.05)";

ctx.fillRect(0, 0, w, h);

ctx.fillStyle = "#20af0e";

//数组元素的映射

words.map( (y,n) => {

//生成A-Z a-z之间的值

text = String.fromCharCode(Math.ceil(65 + Math.random() * 57))

x = n * 10;

ctx.fillText(text, x, y);

words[n] = (y > 758 + Math.random() * 484 )? 0 : y + 10;

});

},50);

运行结果

运行结果

这里我们还可以将填充绘图的颜色修改成随机颜色,而颜色值是十六进制数,其范围是 000000 - FFFFFF,转换为十进制是 0 - 16777215,所以我们通过随机数生成在这个范围内的色值,当然最后还是要转成十六进制,不要忘记在色值前面加#号 ,一共有三种方法,代码如下所示:

// 方法一

function color1(){

let color = "";

const colors = [0,1,2,3,4,5,6,7,8,9,"a","b","c","d","e","f"];

for(let i = 0; i < 6; i++){

const n = Math.ceil(Math.random() * 15);

color += "" + colors[n];

if(i == 5){

return "#" + color;

}

}

}

// 方法二

function color2(){

let color = Math.ceil(Math.random() * 16777215).toString(16);

while(color.length < 6) {

color = "0" + color;

}

return "#" + color;

}

// 方法三

function color3(){

return "#" + ( color => {

return new Array(7 - color.length).join("0") + color;

})((Math.random() * 0x1000000 << 0).toString(16))

}

运行结果

本篇的内容到这里就全部结束了,源码我已经发到了 GitHubHacker meteor shower上了,有需要的同学可自行下载

End of File

行文过程中出现错误或不妥之处在所难免,希望大家能够给予指正,以免误导更多人,最后,如果你觉得我的文章写的还不错,希望能够点一下喜欢关注,为了我能早日成为简书签约作者献上一发助攻吧,谢谢!^ ^

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容

  • 一:canvas简介 1.1什么是canvas? ①:canvas是HTML5提供的一种新标签 ②:HTML5 ...
    GreenHand1阅读 4,667评论 2 32
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,724评论 0 33
  • 辞去工作已经快四个月了,这期间,去帮一个学校招生度过了一个半月。剩下的时间就是睡觉,看电影,玩游戏,和朋...
    亦艰亦坚亦简阅读 355评论 13 20
  • 题目描述输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1...
    哦漏昵称已被占用阅读 224评论 0 0
  • 很久以来,在大我七岁的老公面前我都是个索爱的孩子。那时候我们的互动就是我提需求,他负责满足。可是总有不安,觉得这不...
    自在凤儿阅读 199评论 0 1