iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在JavaScript中使用canvas实现一个随机粒子特效
  • 121
分享到

怎么在JavaScript中使用canvas实现一个随机粒子特效

2023-06-14 13:06:31 121人浏览 八月长安
摘要

本篇文章给大家分享的是有关怎么在javascript中使用canvas实现一个随机粒子特效,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java的特点有哪些Java的特点有哪些

本篇文章给大家分享的是有关怎么在javascript中使用canvas实现一个随机粒子特效,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

Java的特点有哪些

Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。2.Java具有简单性、面向对象、分布式安全性、平台独立与可移植性、动态性等特点。3.使用Java可以编写桌面应用程序、WEB应用程序、分布式系统和嵌入式系统应用程序等。

html

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta Http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title></head><body>    <script src="./main.js"></script></body></html>

main.js

// 生成粒子let Particle = function(context, options){    let random = Math.random();    this.context = context;    // 在画布里的x坐标    this.x = options.x;    // 在画布里的y坐标    this.y = options.y;    // 取随机数的1/2,对角度进行随机放大    this.s = 0.5 + Math.random();    // this.s = 1 + Math.random();    // 粒子运动的变化角度    this.a = 0;    // 宽度    this.w = window.innerWidth;    // 高度    this.h = window.innerHeight;    // 半径    this.radius = options.radius || 0.5 + Math.random() * 10;    // 颜色    this.color = options.color || "#E5483F";    // console.log(this.color);    // 指定3秒后调用;    // 如果粒子的半径大于0.5,加入新的粒子。    setTimeout(function(){        if(this.radius > 0.5){            particles.push(                new Particle(context, {                  x: this.x,                  y: this.y,                  color: this.radius / 2 > 1 ? "#d6433b" : "#FFFFFF",                  radius: this.radius / 2.2 })            );        }    }.call(Particle), 3000);};// 渲染图像Particle.prototype.render = function() {        //从(0,0)开始新的路径;        this.context.beginPath();        // 创建曲线弧        this.context.arc(this.x, this.y, this.radius, 0, 2 * Math.PI);        // 绘图的线条宽度        this.context.lineWidth = 2;        //颜色填充         this.context.fillStyle = this.color;        // 填充当前图像的路径        this.context.fill();        // 返回初始点,并且绘制线条到初始位置        this.context.closePath();};Particle.prototype.swapColor = function() {    // 排除白色    if (this.color != "#FFFFFF") {        // 判断左右界面,并且赋颜色的值        if (this.x < this.w / 2) {            // 左半边            this.color = "#36fcfa";                    } else {            // 右半边            this.color = "#E5483F";                    }        }    };Particle.prototype.move = function() {    // 颜色定义    this.swapColor();    // 横坐标按照cos角度进行变换,并且对其进行随机数放大;    // 偏射角度以便两个半界分开    this.x += Math.cos(this.a) * this.s;    this.y += Math.sin(this.a) * this.s;    // this.y += Math.cos(this.a) * this.s;    // this.x += Math.sin(this.a) * this.s;    // 在变化后,对随机角度进行再重取;    this.a += Math.random() * 0.8 - 0.4;    // 判断全为0,粒子横坐标无移动;    if (this.x < 0 || this.x > this.w - this.radius) {      return false;    }    // 粒子纵坐标无移动;    if (this.y < 0 || this.y > this.h - this.radius) {      return false;    }    // 重新绘制图像    this.render();    return true;  };let canvas = document.createElement('canvas');canvas.width = window.innerWidth - 20;canvas.height = window.innerHeight - 30;document.body.insertBefore(canvas, null);let context = canvas.getContext('2d');const conf = {    frequency: 50,    x: canvas.width,    y: canvas.height};let particles = [],    frequency = conf.frequency;setInterval(function(){    popolate();}.bind(null), frequency);function popolate(){    particles.push(        new Particle(context, {          x: conf.x / 2,          y: conf.y / 2        })    );    return particles.length;}function clear() {    context.globalAlpha = 0.04;    context.fillStyle = '#000042';    context.fillRect(0,0,canvas.width, canvas.height);    context.globalAlpha = 1;}function update(){    particles = particles.filter(p => p.move());    clear();    requestAnimationFrame(arguments.callee);}update();

以上就是怎么在JavaScript中使用canvas实现一个随机粒子特效,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网精选频道。

--结束END--

本文标题: 怎么在JavaScript中使用canvas实现一个随机粒子特效

本文链接: https://www.lsjlt.com/news/271354.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++ 生态系统中流行库和框架的贡献指南
    作为 c++++ 开发人员,通过遵循以下步骤即可为流行库和框架做出贡献:选择一个项目并熟悉其代码库。在 issue 跟踪器中寻找适合初学者的问题。创建一个新分支,实现修复并添加测试。提交...
    99+
    2024-05-15
    框架 c++ 流行库 git
  • C++ 生态系统中流行库和框架的社区支持情况
    c++++生态系统中流行库和框架的社区支持情况:boost:活跃的社区提供广泛的文档、教程和讨论区,确保持续的维护和更新。qt:庞大的社区提供丰富的文档、示例和论坛,积极参与开发和维护。...
    99+
    2024-05-15
    生态系统 社区支持 c++ overflow 标准库
  • c++中if elseif使用规则
    c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
    99+
    2024-05-15
    c++
  • c++中的继承怎么写
    继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
    99+
    2024-05-15
    c++
  • c++中如何使用类和对象掌握目标
    在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
    99+
    2024-05-15
    c++
  • c++中优先级是什么意思
    c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
    99+
    2024-05-15
    c++
  • c++中a+是什么意思
    c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
    99+
    2024-05-15
    c++
  • c++中a.b什么意思
    c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
    99+
    2024-05-15
    c++
  • C++ 并发编程库的优缺点
    c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
    99+
    2024-05-15
    c++ 并发编程
  • 如何在 Golang 中备份数据库?
    在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
    99+
    2024-05-15
    golang 数据库备份 mysql git 标准库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作