【Canvas与艺术】砂落字现

【注意】

本作代码需要在服务器端执行,不可用浏览器直接打开运行。

如何安装服务器端请参考:https://www.cnblogs.com/heyang78/p/3339235.html

【原理】

雨粒子落下时,如果当前点不是黑点,则化身为金字的一个像素点。

【效果】

【代码】

<!DOCTYPE html>
<html lang="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<head><title>砂落字现粒子特效</title></head><body οnlοad="draw()"><img id="maxim" src="71.maxim.png" style="display:none"/><canvas id="hideCanvas"  style="display:none"></canvas><canvas id="myCanvas" width="100px" height="100px" style="border:0px dashed black;">出现文字表示您的浏览器不支持HTML5</canvas></body>
</html>
<script type="text/javascript">
<!--
/*****************************************************************
* 将全体代码(从<!DOCTYPE到script>)拷贝下来,粘贴到文本编辑器中,
* 另存为.html文件,再用chrome浏览器打开,就能看到实现效果。
******************************************************************/// 画布宽
var Width=1200;// 画布高
var Height=512;// 绘图上下文
var context;// 舞台对象
var stage;// 肇始函数
function draw(){// 获得imgvar img = document.getElementById("maxim");// 用于从中取图片数据的隐藏canvasvar hideCanvas=document.getElementById('hideCanvas');  hideCanvas.width=img.width;hideCanvas.height=img.height; hideCtx=hideCanvas.getContext('2d');  hideCtx.drawImage(img,0,0);// 真正用于画图的Canvasvar canvas=document.getElementById('myCanvas');    Width=img.width;Height=img.height;canvas.width=Width;canvas.height=Height;    context=canvas.getContext('2d');    // 准备stage=new Stage(10000);    stage.init();// 开幕animate();
};// 循环播放动画
function animate(){    // 直接清屏则无拖尾效果//context.clearRect(0,0,Width,Height);    // 加上半透明蒙层带上的拖尾效果context.fillStyle = 'rgb(0,0,0,.07)'   context.rect(0, 0, Width, Height) context.fill()  stage.update();stage.paintBg(context);stage.paintFg(context);     if(true){window.requestAnimationFrame(animate);}
}// 舞台类
function Stage(count){// 雨粒子数组this.rainArr=new Array(count);// 金粒子数组this.goldenArr=new Array(count);// 初始化this.init=function(){for(var i=0;i<this.rainArr.length;i++){var item={};item.x=Math.random()*Width;item.y=Math.random()*Height;item.vy=Math.random()*10+1;this.rainArr[i]=item;}}// 更新粒子的位置this.update=function(){this.rainArr.forEach(function (item, i) {// 下坠item.y+=item.vy;// 取当前点的像素let data = hideCtx.getImageData(item.x,item.y,1,1).data;// 如果RGB不都等于0,说明当前坐标是金字位置if(data[0]!=0 || data[1]!=0 || data[2]!=0){var pt={};pt.x=item.x;pt.y=item.y;stage.goldenArr.push(pt);// 保存此点// 原像素点置黑,此举是为了金沙能继续下落var blackImageData=new ImageData(1,1);blackImageData.data[0]=0;blackImageData.data[1]=0;blackImageData.data[2]=0;hideCtx.putImageData(blackImageData,item.x,item.y);// 显影归零item.y=0;item.x=Math.random()*Width;}// 越界归零if(item.y>Height){item.y=0;item.x=Math.random()*Width;}})        };//  画背景this.paintBg=function(ctx){// 背景黑色ctx.fillStyle="black";ctx.fillRect(0,0,Width,Height);ctx.fillStyle="White";ctx.fillText("砂落字现 by:逆火",Width-100,Height-20);};// 画前景this.paintFg=function(ctx){this.rainArr.forEach(function (item, i) {ctx.fillStyle="yellow";ctx.fillRect(item.x,item.y,2,2);})    this.goldenArr.forEach(function (pt, i) {ctx.fillStyle="yellow";ctx.fillRect(pt.x,pt.y,1,1);})};
}/*----------------------------------
自开天辟地以来,
炼狱与世人同在,
时间与牛马同行,
周而复始,昼夜不息...
----------------------------------*/
//-->
</script>

【需要用到的底图】

请将上图另存为 71.maxim.png,与代码配合使用。

【参考资料】

https://www.cnblogs.com/heyang78/p/7599468.html

Javascript中的图像数据对象:Image、ImageData 和 ImageBitmap_js image-CSDN博客

END

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2871350.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

28.网络游戏逆向分析与漏洞攻防-网络通信数据包分析工具-数据推测结果用提示框的形式显示

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果 内容参考于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;27.数据推测功能…

ASPICE-SYSSWE

文章主要内容&#xff1a; Automotive SPICE 过程参考模型 SYS.1 需求挖掘 过程ID SYS.1 过程名称 需求挖掘 过程目的 需求挖掘过程的目的是:在产品和/或服务的整个生命周期内收集、处理和跟踪不断变化的利益相关方的需要和需求&#xff0c;从而建立一个需求基线&#x…

【方法封装】时间格式化输出,获取请求设备和IP

目录 时间类 1.1 获取当前时间&#xff0c;以特定格式化形式输出 1.2 自定义时间&#xff0c;以特定格式化输出 1.3 获取当前时间&#xff0c;自定义格式化 1.4 自定义时间&#xff0c;自定义格式化 设备类 根据请求头信息&#xff0c;获取用户发起请求的设备 请求IP类 …

走进volatile的世界,探索它与可见性,有序性,原子性之间的爱恨情仇!

写在开头 在之前的几篇博文中&#xff0c;我们都提到了 volatile 关键字&#xff0c;这个单词中文释义为&#xff1a;不稳定的&#xff0c;易挥发的&#xff0c;在Java中代表变量修饰符&#xff0c;用来修饰会被不同线程访问和修改的变量&#xff0c;对于方法&#xff0c;代码…

在Windows系统上搭建MongoDB-这篇文章刚刚好

在Windows系统上搭建MongoDB集群 文章目录 1.下载MongoDB2.集群描述3.构建集群文件目录4.新建配置文件5.启动MongoDB服务6.配置集群7.集群测试8.设置密码和开启认证一、安装MongoDB 1.下载MongoDB 去MongoDB官网下载解压版免安装的压缩包。 https://www.mongodb.com/try/do…

.rmallox勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复

导言&#xff1a; 近年来&#xff0c;勒索病毒的威胁日益增加&#xff0c;其中一种名为.rmallox的勒索病毒备受关注。这种病毒通过加密文件并勒索赎金来威胁受害者。本文将介绍.rmallox勒索病毒的特点&#xff0c;以及如何恢复被其加密的数据文件&#xff0c;并提供预防措施&a…

网络安全JavaSE第二天(持续更新)

3. 基本数据与运算 3.6 运算符 3.6.1 算术运算符 在 Java 中&#xff0c;算术运算符包含&#xff1a;、-、*、/、% public class ArithmeticOperator { public static void main(String[] args) { int a 10; // 定义了一个整型类型的变量 a&#xff0c;它的值是 10 int b …

误删电脑C盘要重装系统吗 误删电脑C盘文件怎么恢复 误删c盘系统文件怎么修复 不小心删除C盘的东西恢复

C盘通常是操作系统(如Windows)的默认安装目录。它包含了操作系统的核心文件、驱动程序及系统所需的各种支持文件。这些文件对于计算机的正常运行至关重要。如果我们不小心将C盘的重要文件删除&#xff0c;会导致应用无法打开。本篇文章&#xff0c;我们将学习误删电脑C盘要重装…

再见 Pandas,又一数据处理神器

cuDF介绍 cuDF是一个基于Apache Arrow列内存格式的Python GPU DataFrame库&#xff0c;用于加载、连接、聚合、过滤和其他数据操作。cuDF还提供了类似于pandas的API。 GitHub&#xff1a; https://github.com/rapidsai/cudf Documentation&#xff1a; https://docs.rapids.a…

Alma Linux - Primavera P6 EPPM 安装及分享

引言 继上一期发布的Rocky Linux版环境发布之后&#xff0c;近日我又制作了基于Alma Enterprise Linux 的P6虚拟机环境&#xff0c;同样里面包含了全套P6 最新版应用服务 此虚拟机仅用于演示、培训和测试目的。如您在生产环境中使用此虚拟机&#xff0c;请先与Oracle Primaver…

四连通与八连通的区别 -- 图例讲解

概念 四连通区域&#xff1a;指从某个点出发&#xff0c;只能通过上、下、左、右四个方向的运动到达区域内的其他点&#xff0c;且不能跨越区域的边界。 八连通区域&#xff1a;除了上、下、左、右四个方向&#xff0c;还可以沿对角线方向&#xff08;左上、右上、左下、右下…

Python 查找并高亮PDF中的指定文本

在处理大量PDF文档时&#xff0c;有时我们需要快速找到特定的文本信息。本文将提供以下三个Python示例来帮助你在PDF文件中快速查找并高亮指定的文本。 查找并高亮PDF中所有的指定文本查找并高亮PDF某个区域内的指定文本使用正则表达式搜索指定文本并高亮 本文将用到国产第三方…

Spring Web MVC入门(3)

学习Spring MVC 请求 传递JSON数据 JSON概念 JSON: JavaScript Object Natation JSON是一种轻量的数据交互格式, 采用完全独立于编程语言的文本格式来存储和标识数据. 简单来说, JSON是一种数据格式, 有自己的格式和语法, 使用文本来表示对象或数组的信息, 因此JSON的本质…

C++之deque与vector、list对比分析

一.deque讲解 对于vector和list&#xff0c;前一个是顺序表&#xff0c;后一个是带头双向循环链表&#xff0c;前面我们已经实现过&#xff0c;这里就不再讲解了&#xff0c;直接上deque了。 deque&#xff1a;双端队列 常见接口大家可以查看下面链接&#xff1a; deque - …

Java多线程实战-CountDownLatch模拟压测实现

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Java全栈-专栏 &#x1f3f7;️本系列源码仓库&#xff1a;多线程并发编程学习的多个代码片段(github) &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正…

深度学习 精选笔记(13.2)深度卷积神经网络-AlexNet模型

学习参考&#xff1a; 动手学深度学习2.0Deep-Learning-with-TensorFlow-bookpytorchlightning ①如有冒犯、请联系侵删。 ②已写完的笔记文章会不定时一直修订修改(删、改、增)&#xff0c;以达到集多方教程的精华于一文的目的。 ③非常推荐上面&#xff08;学习参考&#x…

单片机学到什么程度才可以去工作?

单片机学到什么程度才可以去工作? 如果没有名校或学位的加持&#xff0c;你还得再努力一把&#xff0c;才能从激烈的竞争中胜出。以下这些技能可以给你加分&#xff0c;你看情况学&#xff0c;不同行业对这些组件会有取舍: . Cortex-M内核:理解MCU内核各部件的工作机制&#…

如何优化使用Nginx

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容数据压缩负载均衡安装OpenResty或ngx_http_lua_module配置Nginx以启用Lua编写Lua脚本配置upstream块以使用Lua变量测试配置 合并请求1. 确保SSI模块已启用2. 配置Nginx以使用SSI3. 使用SSI指令4. 重新加载或重启Nginx 集成…

Python爬虫与数据可视化源码免费领取

引言 作为一名在软件技术领域深耕多年的专业人士&#xff0c;我不仅在软件开发和项目部署方面积累了丰富的实践经验&#xff0c;更以卓越的技术实力获得了&#x1f3c5;30项软件著作权证书的殊荣。这些成就不仅是对我的技术专长的肯定&#xff0c;也是对我的创新精神和专业承诺…

【leetcode-53最大子数组和】

题目&#xff1a; 给你一个整数数组 nums &#xff0c;请你找出一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。子数组是数组中的一个连续部分。 示例 1&#xff1a; 输入&#xff1a;nums [-2,1,-3,4,-1,2,1,-5,4] …