@lxlib/chart
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.
362 lines • 30 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: water-wave.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Input, NgZone, Renderer2, ViewChild, ViewEncapsulation, } from '@angular/core';
import { InputNumber } from '@lxlib/util';
import { fromEvent } from 'rxjs';
import { debounceTime } from 'rxjs/operators';
var G2WaterWaveComponent = /** @class */ (function () {
// #endregion
function G2WaterWaveComponent(el, renderer, ngZone, cdr) {
this.el = el;
this.renderer = renderer;
this.ngZone = ngZone;
this.cdr = cdr;
this.resize$ = null;
// #region fields
this.delay = 0;
this.color = '#1890FF';
this.height = 160;
}
/**
* @private
* @param {?} type
* @return {?}
*/
G2WaterWaveComponent.prototype.renderChart = /**
* @private
* @param {?} type
* @return {?}
*/
function (type) {
if (!this.resize$)
return;
this.updateRadio();
var _a = this, percent = _a.percent, color = _a.color, node = _a.node;
/** @type {?} */
var data = Math.min(Math.max(percent / 100, 0), 100);
/** @type {?} */
var self = this;
cancelAnimationFrame(this.timer);
/** @type {?} */
var canvas = (/** @type {?} */ (node.nativeElement));
/** @type {?} */
var ctx = (/** @type {?} */ (canvas.getContext('2d')));
/** @type {?} */
var canvasWidth = canvas.width;
/** @type {?} */
var canvasHeight = canvas.height;
/** @type {?} */
var radius = canvasWidth / 2;
/** @type {?} */
var lineWidth = 2;
/** @type {?} */
var cR = radius - lineWidth;
ctx.beginPath();
ctx.lineWidth = lineWidth * 2;
/** @type {?} */
var axisLength = canvasWidth - lineWidth;
/** @type {?} */
var unit = axisLength / 8;
/** @type {?} */
var range = 0.2;
// 振幅
/** @type {?} */
var currRange = range;
/** @type {?} */
var xOffset = lineWidth;
/** @type {?} */
var sp = 0;
// 周期偏移量
/** @type {?} */
var currData = 0;
/** @type {?} */
var waveupsp = 0.005;
// 水波上涨速度
/** @type {?} */
var arcStack = [];
/** @type {?} */
var bR = radius - lineWidth;
/** @type {?} */
var circleOffset = -(Math.PI / 2);
/** @type {?} */
var circleLock = true;
// tslint:disable-next-line:binary-expression-operand-order
for (var i = circleOffset; i < circleOffset + 2 * Math.PI; i += 1 / (8 * Math.PI)) {
arcStack.push([radius + bR * Math.cos(i), radius + bR * Math.sin(i)]);
}
/** @type {?} */
var cStartPoint = (/** @type {?} */ (arcStack.shift()));
ctx.strokeStyle = color;
ctx.moveTo(cStartPoint[0], cStartPoint[1]);
/**
* @return {?}
*/
function drawSin() {
ctx.beginPath();
ctx.save();
/** @type {?} */
var sinStack = [];
for (var i = xOffset; i <= xOffset + axisLength; i += 20 / axisLength) {
/** @type {?} */
var x = sp + (xOffset + i) / unit;
/** @type {?} */
var y = Math.sin(x) * currRange;
/** @type {?} */
var dx = i;
// tslint:disable-next-line:binary-expression-operand-order
/** @type {?} */
var dy = 2 * cR * (1 - currData) + (radius - cR) - unit * y;
ctx.lineTo(dx, dy);
sinStack.push([dx, dy]);
}
/** @type {?} */
var startPoint = (/** @type {?} */ (sinStack.shift()));
ctx.lineTo(xOffset + axisLength, canvasHeight);
ctx.lineTo(xOffset, canvasHeight);
ctx.lineTo(startPoint[0], startPoint[1]);
/** @type {?} */
var gradient = ctx.createLinearGradient(0, 0, 0, canvasHeight);
gradient.addColorStop(0, '#ffffff');
gradient.addColorStop(1, color);
ctx.fillStyle = gradient;
ctx.fill();
ctx.restore();
}
/**
* @return {?}
*/
function render() {
ctx.clearRect(0, 0, canvasWidth, canvasHeight);
if (circleLock && type !== 'update') {
if ((/** @type {?} */ (arcStack)).length) {
/** @type {?} */
var temp = (/** @type {?} */ ((/** @type {?} */ (arcStack)).shift()));
ctx.lineTo(temp[0], temp[1]);
ctx.stroke();
}
else {
circleLock = false;
ctx.lineTo(cStartPoint[0], cStartPoint[1]);
ctx.stroke();
arcStack = null;
ctx.globalCompositeOperation = 'destination-over';
ctx.beginPath();
ctx.lineWidth = lineWidth;
// tslint:disable-next-line:binary-expression-operand-order
ctx.arc(radius, radius, bR, 0, 2 * Math.PI, true);
ctx.beginPath();
ctx.save();
// tslint:disable-next-line:binary-expression-operand-order
ctx.arc(radius, radius, radius - 3 * lineWidth, 0, 2 * Math.PI, true);
ctx.restore();
ctx.clip();
ctx.fillStyle = color;
}
}
else {
if (data >= 0.85) {
if (currRange > range / 4) {
/** @type {?} */
var t = range * 0.01;
currRange -= t;
}
}
else if (data <= 0.1) {
if (currRange < range * 1.5) {
/** @type {?} */
var t = range * 0.01;
currRange += t;
}
}
else {
if (currRange <= range) {
/** @type {?} */
var t = range * 0.01;
currRange += t;
}
if (currRange >= range) {
/** @type {?} */
var t = range * 0.01;
currRange -= t;
}
}
if (data - currData > 0) {
currData += waveupsp;
}
if (data - currData < 0) {
currData -= waveupsp;
}
sp += 0.07;
drawSin();
}
self.timer = requestAnimationFrame(render);
}
render();
};
/**
* @private
* @return {?}
*/
G2WaterWaveComponent.prototype.updateRadio = /**
* @private
* @return {?}
*/
function () {
var offsetWidth = this.el.nativeElement.parentNode.offsetWidth;
/** @type {?} */
var radio = offsetWidth < this.height ? offsetWidth / this.height : 1;
this.renderer.setStyle(this.el.nativeElement, 'transform', "scale(" + radio + ")");
};
/**
* @private
* @return {?}
*/
G2WaterWaveComponent.prototype.installResizeEvent = /**
* @private
* @return {?}
*/
function () {
var _this = this;
this.resize$ = fromEvent(window, 'resize')
.pipe(debounceTime(200))
.subscribe((/**
* @return {?}
*/
function () { return _this.updateRadio(); }));
};
/**
* @return {?}
*/
G2WaterWaveComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.installResizeEvent();
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return setTimeout((/**
* @return {?}
*/
function () { return _this.renderChart(''); }), _this.delay); }));
};
/**
* @return {?}
*/
G2WaterWaveComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.renderChart('update'); }));
this.cdr.detectChanges();
};
/**
* @return {?}
*/
G2WaterWaveComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this.timer) {
cancelAnimationFrame(this.timer);
}
(/** @type {?} */ (this.resize$)).unsubscribe();
};
G2WaterWaveComponent.decorators = [
{ type: Component, args: [{
selector: 'g2-water-wave',
exportAs: 'g2WaterWave',
template: "<div [ngStyle]=\"{'height.px': height, 'width.px': height, 'overflow': 'hidden'}\">\n <canvas #container class=\"g2-water-wave__canvas\" width=\"{{height*2}}\" height=\"{{height*2}}\"></canvas>\n</div>\n<div class=\"g2-water-wave__desc\" [ngStyle]=\"{'width.px': height}\">\n <span *ngIf=\"title\" class=\"g2-water-wave__desc-title\">\n <ng-container *nzStringTemplateOutlet=\"title\">{{title}}</ng-container>\n </span>\n <h4 class=\"g2-water-wave__desc-percent\">{{percent}}%</h4>\n</div>\n",
host: { '[class.g2-water-wave]': 'true' },
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
G2WaterWaveComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 },
{ type: NgZone },
{ type: ChangeDetectorRef }
]; };
G2WaterWaveComponent.propDecorators = {
node: [{ type: ViewChild, args: ['container', { static: true },] }],
delay: [{ type: Input }],
title: [{ type: Input }],
color: [{ type: Input }],
height: [{ type: Input }],
percent: [{ type: Input }]
};
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2WaterWaveComponent.prototype, "delay", void 0);
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2WaterWaveComponent.prototype, "height", void 0);
__decorate([
InputNumber(),
__metadata("design:type", Number)
], G2WaterWaveComponent.prototype, "percent", void 0);
return G2WaterWaveComponent;
}());
export { G2WaterWaveComponent };
if (false) {
/**
* @type {?}
* @private
*/
G2WaterWaveComponent.prototype.resize$;
/**
* @type {?}
* @private
*/
G2WaterWaveComponent.prototype.node;
/**
* @type {?}
* @private
*/
G2WaterWaveComponent.prototype.timer;
/** @type {?} */
G2WaterWaveComponent.prototype.delay;
/** @type {?} */
G2WaterWaveComponent.prototype.title;
/** @type {?} */
G2WaterWaveComponent.prototype.color;
/** @type {?} */
G2WaterWaveComponent.prototype.height;
/** @type {?} */
G2WaterWaveComponent.prototype.percent;
/**
* @type {?}
* @private
*/
G2WaterWaveComponent.prototype.el;
/**
* @type {?}
* @private
*/
G2WaterWaveComponent.prototype.renderer;
/**
* @type {?}
* @private
*/
G2WaterWaveComponent.prototype.ngZone;
/**
* @type {?}
* @private
*/
G2WaterWaveComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"water-wave.component.js","sourceRoot":"ng://@lxlib/chart/water-wave/","sources":["water-wave.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { InputNumber } from '@lxlib/util';\nimport { fromEvent, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\n\n@Component({\n  selector: 'g2-water-wave',\n  exportAs: 'g2WaterWave',\n  templateUrl: './water-wave.component.html',\n  host: { '[class.g2-water-wave]': 'true' },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class G2WaterWaveComponent implements OnDestroy, OnChanges, OnInit {\n  private resize$: Subscription | null = null;\n  @ViewChild('container', { static: true }) private node: ElementRef;\n  private timer: number;\n\n  // #region fields\n\n  @Input() @InputNumber() delay = 0;\n  @Input() title: string | TemplateRef<void>;\n  @Input() color = '#1890FF';\n  @Input() @InputNumber() height = 160;\n  @Input() @InputNumber() percent: number;\n\n  // #endregion\n\n  constructor(private el: ElementRef, private renderer: Renderer2, private ngZone: NgZone, private cdr: ChangeDetectorRef) { }\n\n  private renderChart(type: string) {\n    if (!this.resize$) return;\n\n    this.updateRadio();\n\n    const { percent, color, node } = this;\n\n    const data = Math.min(Math.max(percent / 100, 0), 100);\n    const self = this;\n    cancelAnimationFrame(this.timer);\n\n    const canvas = node.nativeElement as HTMLCanvasElement;\n    const ctx = canvas.getContext('2d') as CanvasRenderingContext2D;\n    const canvasWidth = canvas.width;\n    const canvasHeight = canvas.height;\n    const radius = canvasWidth / 2;\n    const lineWidth = 2;\n    const cR = radius - lineWidth;\n\n    ctx.beginPath();\n    ctx.lineWidth = lineWidth * 2;\n\n    const axisLength = canvasWidth - lineWidth;\n    const unit = axisLength / 8;\n    const range = 0.2; // 振幅\n    let currRange = range;\n    const xOffset = lineWidth;\n    let sp = 0; // 周期偏移量\n    let currData = 0;\n    const waveupsp = 0.005; // 水波上涨速度\n\n    let arcStack: [[number, number]?] | null = [];\n    const bR = radius - lineWidth;\n    const circleOffset = -(Math.PI / 2);\n    let circleLock = true;\n\n    // tslint:disable-next-line:binary-expression-operand-order\n    for (let i = circleOffset; i < circleOffset + 2 * Math.PI; i += 1 / (8 * Math.PI)) {\n      arcStack.push([radius + bR * Math.cos(i), radius + bR * Math.sin(i)]);\n    }\n\n    const cStartPoint = arcStack.shift() as [number, number];\n    ctx.strokeStyle = color;\n    ctx.moveTo(cStartPoint[0], cStartPoint[1]);\n\n    function drawSin() {\n      ctx.beginPath();\n      ctx.save();\n\n      const sinStack: [[number, number]?] = [];\n      for (let i = xOffset; i <= xOffset + axisLength; i += 20 / axisLength) {\n        const x = sp + (xOffset + i) / unit;\n        const y = Math.sin(x) * currRange;\n        const dx = i;\n        // tslint:disable-next-line:binary-expression-operand-order\n        const dy = 2 * cR * (1 - currData) + (radius - cR) - unit * y;\n\n        ctx.lineTo(dx, dy);\n        sinStack.push([dx, dy]);\n      }\n\n      const startPoint = sinStack.shift() as [number, number];\n\n      ctx.lineTo(xOffset + axisLength, canvasHeight);\n      ctx.lineTo(xOffset, canvasHeight);\n      ctx.lineTo(startPoint[0], startPoint[1]);\n\n      const gradient = ctx.createLinearGradient(0, 0, 0, canvasHeight);\n      gradient.addColorStop(0, '#ffffff');\n      gradient.addColorStop(1, color);\n      ctx.fillStyle = gradient;\n      ctx.fill();\n      ctx.restore();\n    }\n\n    function render() {\n      ctx.clearRect(0, 0, canvasWidth, canvasHeight);\n      if (circleLock && type !== 'update') {\n        if (arcStack!.length) {\n          const temp = arcStack!.shift() as [number, number];\n          ctx.lineTo(temp[0], temp[1]);\n          ctx.stroke();\n        } else {\n          circleLock = false;\n          ctx.lineTo(cStartPoint[0], cStartPoint[1]);\n          ctx.stroke();\n          arcStack = null;\n\n          ctx.globalCompositeOperation = 'destination-over';\n          ctx.beginPath();\n          ctx.lineWidth = lineWidth;\n          // tslint:disable-next-line:binary-expression-operand-order\n          ctx.arc(radius, radius, bR, 0, 2 * Math.PI, true);\n\n          ctx.beginPath();\n          ctx.save();\n          // tslint:disable-next-line:binary-expression-operand-order\n          ctx.arc(radius, radius, radius - 3 * lineWidth, 0, 2 * Math.PI, true);\n\n          ctx.restore();\n          ctx.clip();\n          ctx.fillStyle = color;\n        }\n      } else {\n        if (data >= 0.85) {\n          if (currRange > range / 4) {\n            const t = range * 0.01;\n            currRange -= t;\n          }\n        } else if (data <= 0.1) {\n          if (currRange < range * 1.5) {\n            const t = range * 0.01;\n            currRange += t;\n          }\n        } else {\n          if (currRange <= range) {\n            const t = range * 0.01;\n            currRange += t;\n          }\n          if (currRange >= range) {\n            const t = range * 0.01;\n            currRange -= t;\n          }\n        }\n        if (data - currData > 0) {\n          currData += waveupsp;\n        }\n        if (data - currData < 0) {\n          currData -= waveupsp;\n        }\n\n        sp += 0.07;\n        drawSin();\n      }\n      self.timer = requestAnimationFrame(render);\n    }\n\n    render();\n  }\n\n  private updateRadio() {\n    const { offsetWidth } = this.el.nativeElement.parentNode;\n    const radio = offsetWidth < this.height ? offsetWidth / this.height : 1;\n    this.renderer.setStyle(this.el.nativeElement, 'transform', `scale(${radio})`);\n  }\n\n  private installResizeEvent() {\n    this.resize$ = fromEvent(window, 'resize')\n      .pipe(debounceTime(200))\n      .subscribe(() => this.updateRadio());\n  }\n\n  ngOnInit(): void {\n    this.installResizeEvent();\n    this.ngZone.runOutsideAngular(() => setTimeout(() => this.renderChart(''), this.delay));\n  }\n\n  ngOnChanges(): void {\n    this.ngZone.runOutsideAngular(() => this.renderChart('update'));\n    this.cdr.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    if (this.timer) {\n      cancelAnimationFrame(this.timer);\n    }\n    this.resize$!.unsubscribe();\n  }\n}\n"]}