UNPKG

ngx-particlesjs

Version:

[![npm](https://img.shields.io/npm/v/ngx-particlesjs.svg)](https://www.npmjs.com/package/ngx-particlesjs) [![npm](https://img.shields.io/npm/dm/ngx-particlesjs.svg)](https://www.npmjs.com/package/ngx-particlesjs) [![TypeScript](https://img.shields.io/badg

264 lines (256 loc) 22.4 kB
import { Component, HostListener, Input, ViewChild, NgModule } from '@angular/core'; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ /** * @param {?} origin * @return {?} */ function saveDecimal(origin) { return Math.floor(origin * 100) / 100; } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ class Particle { /** * @param {?} range * @param {?=} speed * @param {?=} size */ constructor(range, speed = 'normal', size = 1.5) { this.max_width = range[0]; this.max_height = range[1]; this.initPosition(); this.initSpeed(speed); this.initSize(size); this.initColor(); } /** * @param {?} range * @return {?} */ onRange(range) { this.max_width = range[0]; this.max_height = range[1]; } /** * @return {?} */ initPosition() { this.x = saveDecimal(Math.random() * this.max_width); this.y = saveDecimal(Math.random() * this.max_height); } /** * @param {?} speed * @return {?} */ initSpeed(speed) { /** @type {?} */ let vi = []; if (typeof speed === 'string') { switch (speed) { case 'fast': vi = [1, 1]; break; case 'normal': vi = [2, 2]; break; case 'slow': vi = [5, 5]; break; default: vi = [2, 2]; } } else { vi = speed; } this.vx = saveDecimal(Math.random() / vi[0]); this.vy = saveDecimal(Math.random() / vi[1]); } /** * @param {?} size * @return {?} */ initSize(size) { this.size = (1 + Math.random()) * size; } /** * @return {?} */ initColor() { this.color = `rgb(${Math.floor(Math.random() * 256)},${Math.floor(Math.random() * 256)},${Math.floor(Math.random() * 256)})`; } /** * @param {?} ctx * @return {?} */ draw(ctx) { ctx.beginPath(); ctx.arc(this.x, this.y, this.size, 0, 2 * Math.PI); ctx.fillStyle = this.color; ctx.strokeStyle = this.color; ctx.closePath(); ctx.fill(); ctx.stroke(); } /** * @return {?} */ update() { this.edge(); this.x = this.x + this.vx; this.y = this.y + this.vy; } /** * @return {?} */ edge() { if (this.x + this.vx > this.max_width || this.x + this.vx < 0) { this.vx = -this.vx; } if (this.y + this.vy > this.max_height || this.y + this.vy < 0) { this.vy = -this.vy; } } } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ class NgxParticlesComponent { constructor() { this.particles = []; this.resizing = false; this.total = 100; this.stageChange = () => { this.initStage(); /** @type {?} */ const range = [this.width, this.height]; for (const x of this.particles) { x.onRange(range); } this.resizing = false; }; this.drawContext = () => { this.ctx.clearRect(0, 0, this.width, this.height); for (const x of this.particles) { x.draw(this.ctx); x.update(); } this.mainAnimationFrame = window.requestAnimationFrame(this.drawContext); this.resizing = false; }; } /** * @return {?} */ ngAfterViewInit() { this.canvas = this.stageRef.nativeElement; this.ctx = this.canvas.getContext('2d', { alpha: false }); this.initStage(); this.initParticle(); this.drawContext(); } /** * @return {?} */ ngOnDestroy() { this.ctx.clearRect(0, 0, this.width, this.height); window.cancelAnimationFrame(this.mainAnimationFrame); window.cancelAnimationFrame(this.changeAnimationFrame); } /** * @return {?} */ onResize() { if (!this.resizing && (!this.default_height || !this.default_width)) { this.resizing = true; if (window.requestAnimationFrame) { window.requestAnimationFrame(this.stageChange); } else { setTimeout(this.stageChange, 66); } } } /** * @return {?} */ initStage() { const { clientWidth, clientHeight } = this.canvas.parentElement; if (this.default_width) { this.canvas.width = this.width = this.default_width; } else { this.canvas.width = this.width = clientWidth; } if (this.default_height) { this.canvas.height = this.height = this.default_height; } else { this.canvas.height = this.height = clientHeight; } } /** * @return {?} */ initParticle() { /** @type {?} */ const range = [this.width, this.height]; for (let i = 0; i < this.total; i++) { this.particles[i] = new Particle(range, (this.args && this.args.speed) ? this.args.speed : 'normal', (this.args && this.args.size) ? this.args.size : 1.5); } } } NgxParticlesComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-particle', template: ` <div id="stage"> <canvas #stageRef></canvas> </div> `, styles: [` #stage { height: 100%; width: 100%; will-change: all; } `] }] } ]; NgxParticlesComponent.propDecorators = { stageRef: [{ type: ViewChild, args: ['stageRef',] }], total: [{ type: Input }], default_width: [{ type: Input }], default_height: [{ type: Input }], args: [{ type: Input }], onResize: [{ type: HostListener, args: ['window:resize',] }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ class NgxParticlesModule { } NgxParticlesModule.decorators = [ { type: NgModule, args: [{ imports: [], declarations: [NgxParticlesComponent], exports: [NgxParticlesComponent] },] } ]; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ export { NgxParticlesModule, NgxParticlesComponent as ɵa }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-particlesjs.js.map","sources":["ng://ngx-particlesjs/lib/common.ts","ng://ngx-particlesjs/lib/particle.ts","ng://ngx-particlesjs/lib/ngx-particles.component.ts","ng://ngx-particlesjs/lib/ngx-particles.module.ts"],"sourcesContent":["export interface ParticleArgs {\r\n  speed?: 'fast' | 'normal' | 'slow' | number[];\r\n  size?: number;\r\n}\r\n\r\nexport function saveDecimal(origin: number) {\r\n  return Math.floor(origin * 100) / 100;\r\n}\r\n","import {saveDecimal} from './common';\r\n\r\nexport class Particle {\r\n  private max_width: number;\r\n  private max_height: number;\r\n\r\n  private x: number;\r\n  private y: number;\r\n\r\n  private vx: number;\r\n  private vy: number;\r\n\r\n  private size: number;\r\n  private color: string;\r\n\r\n  constructor(range: number[], speed: 'fast' | 'normal' | 'slow' | number[] = 'normal', size = 1.5) {\r\n    this.max_width = range[0];\r\n    this.max_height = range[1];\r\n    this.initPosition();\r\n    this.initSpeed(speed);\r\n    this.initSize(size);\r\n    this.initColor();\r\n  }\r\n\r\n  onRange(range: number[]) {\r\n    this.max_width = range[0];\r\n    this.max_height = range[1];\r\n  }\r\n\r\n  private initPosition() {\r\n    this.x = saveDecimal(Math.random() * this.max_width);\r\n    this.y = saveDecimal(Math.random() * this.max_height);\r\n  }\r\n\r\n  private initSpeed(speed: 'fast' | 'normal' | 'slow' | number[]) {\r\n    let vi = [];\r\n    if (typeof speed === 'string') {\r\n      switch (speed) {\r\n        case 'fast':\r\n          vi = [1, 1];\r\n          break;\r\n        case 'normal':\r\n          vi = [2, 2];\r\n          break;\r\n        case 'slow':\r\n          vi = [5, 5];\r\n          break;\r\n        default:\r\n          vi = [2, 2];\r\n      }\r\n    } else {\r\n      vi = speed;\r\n    }\r\n    this.vx = saveDecimal(Math.random() / vi[0]);\r\n    this.vy = saveDecimal(Math.random() / vi[1]);\r\n  }\r\n\r\n  private initSize(size: number) {\r\n    this.size = (1 + Math.random()) * size;\r\n  }\r\n\r\n  private initColor() {\r\n    this.color = `rgb(${Math.floor(Math.random() * 256)},${Math.floor(Math.random() * 256)},${Math.floor(Math.random() * 256)})`;\r\n  }\r\n\r\n  draw(ctx: CanvasRenderingContext2D) {\r\n    ctx.beginPath();\r\n    ctx.arc(this.x, this.y, this.size, 0, 2 * Math.PI);\r\n    ctx.fillStyle = this.color;\r\n    ctx.strokeStyle = this.color;\r\n    ctx.closePath();\r\n    ctx.fill();\r\n    ctx.stroke();\r\n  }\r\n\r\n  update() {\r\n    this.edge();\r\n    this.x = this.x + this.vx;\r\n    this.y = this.y + this.vy;\r\n  }\r\n\r\n  private edge() {\r\n    if (this.x + this.vx > this.max_width || this.x + this.vx < 0) {\r\n      this.vx = -this.vx;\r\n    }\r\n    if (this.y + this.vy > this.max_height || this.y + this.vy < 0) {\r\n      this.vy = -this.vy;\r\n    }\r\n  }\r\n}\r\n","import {AfterViewInit, Component, ElementRef, HostListener, Input, OnDestroy, ViewChild} from '@angular/core';\nimport {Particle} from './particle';\nimport {ParticleArgs} from './common';\n\n@Component({\n  selector: 'ngx-particle',\n  template: `\n    <div id=\"stage\">\n      <canvas #stageRef></canvas>\n    </div>\n  `,\n  styles: [`\n    #stage {\n      height: 100%;\n      width: 100%;\n      will-change: all;\n    }\n  `]\n})\nexport class NgxParticlesComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('stageRef') stageRef: ElementRef;\n\n  private canvas: HTMLCanvasElement;\n  private ctx: CanvasRenderingContext2D;\n  private width: number;\n  private height: number;\n  private particles: Particle[] = [];\n  private mainAnimationFrame: any;\n  private changeAnimationFrame: any;\n  private resizing: any = false;\n\n  @Input() total = 100;\n  @Input() default_width: number;\n  @Input() default_height: number;\n  @Input() args?: ParticleArgs;\n\n  ngAfterViewInit() {\n    this.canvas = this.stageRef.nativeElement;\n    this.ctx = this.canvas.getContext('2d', {alpha: false});\n    this.initStage();\n    this.initParticle();\n    this.drawContext();\n  }\n\n  ngOnDestroy() {\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    window.cancelAnimationFrame(this.mainAnimationFrame);\n    window.cancelAnimationFrame(this.changeAnimationFrame);\n  }\n\n  @HostListener('window:resize')\n  onResize() {\n    if (!this.resizing && (!this.default_height || !this.default_width)) {\n      this.resizing = true;\n      if (window.requestAnimationFrame) {\n        window.requestAnimationFrame(this.stageChange);\n      } else {\n        setTimeout(this.stageChange, 66);\n      }\n    }\n  }\n\n  private initStage() {\n    const {clientWidth, clientHeight} = this.canvas.parentElement;\n    if (this.default_width) {\n      this.canvas.width = this.width = this.default_width;\n    } else {\n      this.canvas.width = this.width = clientWidth;\n    }\n    if (this.default_height) {\n      this.canvas.height = this.height = this.default_height;\n    } else {\n      this.canvas.height = this.height = clientHeight;\n    }\n  }\n\n  private initParticle() {\n    const range = [this.width, this.height];\n    for (let i = 0; i < this.total; i++) {\n      this.particles[i] = new Particle(\n        range,\n        (this.args && this.args.speed) ? this.args.speed : 'normal',\n        (this.args && this.args.size) ? this.args.size : 1.5\n      );\n    }\n  }\n\n  private stageChange = () => {\n    this.initStage();\n    const range = [this.width, this.height];\n    for (const x of this.particles) {\n      x.onRange(range);\n    }\n    this.resizing = false;\n  };\n\n  private drawContext = () => {\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    for (const x of this.particles) {\n      x.draw(this.ctx);\n      x.update();\n    }\n    this.mainAnimationFrame = window.requestAnimationFrame(this.drawContext);\n    this.resizing = false;\n  };\n}\n","import {NgModule} from '@angular/core';\nimport {NgxParticlesComponent} from './ngx-particles.component';\n\n@NgModule({\n  imports: [],\n  declarations: [NgxParticlesComponent],\n  exports: [NgxParticlesComponent]\n})\nexport class NgxParticlesModule {\n}\n"],"names":[],"mappings":"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"}