|
@ -38,21 +38,23 @@ class Snowflake { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
export class Snow { |
|
|
export class Snow { |
|
|
private readonly _canvas: any; |
|
|
|
|
|
private readonly _ctx: any; |
|
|
|
|
|
|
|
|
private readonly _canvas: HTMLCanvasElement | undefined; |
|
|
|
|
|
private readonly _ctx: CanvasRenderingContext2D | undefined; |
|
|
private _height: number = 0; |
|
|
private _height: number = 0; |
|
|
private _width: number = 0; |
|
|
private _width: number = 0; |
|
|
private readonly _snowflakes: Snowflake[] = []; |
|
|
private readonly _snowflakes: Snowflake[] = []; |
|
|
|
|
|
|
|
|
private readonly _clearBound: any; |
|
|
|
|
|
private readonly _updateBound: any; |
|
|
|
|
|
|
|
|
private readonly _clearBound: () => void; |
|
|
|
|
|
private readonly _updateBound: () => void; |
|
|
|
|
|
|
|
|
constructor(public snowing: boolean = true) { |
|
|
constructor(public snowing: boolean = true) { |
|
|
this._clearBound = this.clear.bind(this); |
|
|
this._clearBound = this.clear.bind(this); |
|
|
this._updateBound = this.update.bind(this); |
|
|
this._updateBound = this.update.bind(this); |
|
|
|
|
|
|
|
|
this._canvas = document.querySelector('canvas.snow'); |
|
|
|
|
|
this._ctx = this._canvas.getContext('2d'); |
|
|
|
|
|
|
|
|
this._canvas = document.querySelector<HTMLCanvasElement>('canvas.snow') ?? undefined; |
|
|
|
|
|
this._ctx = this._canvas?.getContext('2d') ?? undefined; |
|
|
|
|
|
|
|
|
|
|
|
if (this._ctx == null) return; |
|
|
|
|
|
|
|
|
const trigger = document.querySelector('.snow__trigger'); |
|
|
const trigger = document.querySelector('.snow__trigger'); |
|
|
if (trigger != null) { |
|
|
if (trigger != null) { |
|
@ -65,7 +67,7 @@ export class Snow { |
|
|
this.onToggle(snowing); |
|
|
this.onToggle(snowing); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
onToggle(snowing: boolean) { |
|
|
|
|
|
|
|
|
onToggle(snowing: boolean): void { |
|
|
this.snowing = snowing; |
|
|
this.snowing = snowing; |
|
|
document.body.classList.toggle('snowing', this.snowing); |
|
|
document.body.classList.toggle('snowing', this.snowing); |
|
|
|
|
|
|
|
@ -75,19 +77,23 @@ export class Snow { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
onResize() { |
|
|
|
|
|
|
|
|
onResize(): void { |
|
|
|
|
|
if (this._canvas == null) return; |
|
|
|
|
|
|
|
|
this._height = window.innerHeight; |
|
|
this._height = window.innerHeight; |
|
|
this._width = window.innerWidth; |
|
|
this._width = window.innerWidth; |
|
|
this._canvas.width = this._width; |
|
|
this._canvas.width = this._width; |
|
|
this._canvas.height = this._height; |
|
|
this._canvas.height = this._height; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
clear() { |
|
|
|
|
|
|
|
|
clear(): void { |
|
|
|
|
|
if (this._canvas == null || this._ctx == null) return; |
|
|
|
|
|
|
|
|
this._ctx.clearRect(0, 0, this._canvas.width, this._canvas.height); |
|
|
this._ctx.clearRect(0, 0, this._canvas.width, this._canvas.height); |
|
|
this._snowflakes.length = 0; |
|
|
this._snowflakes.length = 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
createSnowflakes() { |
|
|
|
|
|
|
|
|
createSnowflakes() class="o">: void { |
|
|
const flakes = window.innerWidth / 4; |
|
|
const flakes = window.innerWidth / 4; |
|
|
|
|
|
|
|
|
for (let i = 0; i < flakes; i++) { |
|
|
for (let i = 0; i < flakes; i++) { |
|
@ -95,7 +101,9 @@ export class Snow { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
update() { |
|
|
|
|
|
|
|
|
update(): void { |
|
|
|
|
|
if (this._ctx == null) return; |
|
|
|
|
|
|
|
|
this._ctx.clearRect(0, 0, this._width, this._height); |
|
|
this._ctx.clearRect(0, 0, this._width, this._height); |
|
|
|
|
|
|
|
|
const color = document.body.classList.contains('vscode-light') ? '#424242' : '#fff'; |
|
|
const color = document.body.classList.contains('vscode-light') ? '#424242' : '#fff'; |
|
|