atr-components 0.2.238 → 0.2.239

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,4 @@
1
- import { Component, Input, ViewChild } from '@angular/core';
2
- import { SessionStorageUtil } from "../../../core/utils/sessionstorage.util";
1
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
2
  import * as i0 from "@angular/core";
4
3
  export class ImgCanvasComponent {
5
4
  constructor(elementRef) {
@@ -7,6 +6,8 @@ export class ImgCanvasComponent {
7
6
  this.width = 800;
8
7
  this.height = 800;
9
8
  this.clipArr = [];
9
+ this.rotateNum = 0;
10
+ this.loadOver = new EventEmitter();
10
11
  }
11
12
  set url(url) {
12
13
  if (url && url.indexOf('?v=') < 0) {
@@ -57,7 +58,6 @@ export class ImgCanvasComponent {
57
58
  };
58
59
  }
59
60
  initImg(needSession = true) {
60
- let obj = SessionStorageUtil.get('appImg');
61
61
  this.canvasDom = this.canvas1.nativeElement;
62
62
  // this.canvasDom = document.getElementById(this.canvasId);
63
63
  //检测支持性
@@ -66,23 +66,13 @@ export class ImgCanvasComponent {
66
66
  //获得 2d 上下文对象
67
67
  let context1 = this.canvasDom.getContext('2d');
68
68
  let image = this.imgUrl;
69
- // if (obj && needSession && obj[image]) {
70
- // //图片缓存在session中
71
- // this.img = obj[image]
72
- // this.initBase(context1)
73
- // return;
74
- // }
75
- if (!obj) {
76
- obj = {};
77
- }
78
69
  this.img = new Image(); //创建img元素
79
70
  this.img.setAttribute('crossOrigin', 'anonymous');
80
71
  this.img.src = this.imgUrl; //设置图片源地址
81
72
  // this.img.src = ToolsUtil.getOssUrl(this.imgUrl);//设置图片源地址
82
73
  this.img.onload = () => {
83
- obj[image] = this.img;
84
- SessionStorageUtil.put('appImg', obj);
85
74
  this.initBase(context1);
75
+ this.loadOver.emit({ code: 'loadOver' });
86
76
  };
87
77
  }
88
78
  initBase(context1) {
@@ -117,10 +107,10 @@ export class ImgCanvasComponent {
117
107
  }
118
108
  }
119
109
  ImgCanvasComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ImgCanvasComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
120
- ImgCanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: ImgCanvasComponent, selector: "app-img", inputs: { url: "url", clipArr: "clipArr" }, viewQueries: [{ propertyName: "canvas1", first: true, predicate: ["canvas1"], descendants: true }], ngImport: i0, template: "<canvas #canvas1 style=\"width: 100%;height: 100%\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n", styles: [""] });
110
+ ImgCanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: ImgCanvasComponent, selector: "app-img", inputs: { url: "url", clipArr: "clipArr", rotateNum: "rotateNum" }, outputs: { loadOver: "loadOver" }, viewQueries: [{ propertyName: "canvas1", first: true, predicate: ["canvas1"], descendants: true }], ngImport: i0, template: "<canvas #canvas1 style=\"width: 100%;height: 100%;\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n<ng-content></ng-content>\n", styles: [""] });
121
111
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ImgCanvasComponent, decorators: [{
122
112
  type: Component,
123
- args: [{ selector: 'app-img', template: "<canvas #canvas1 style=\"width: 100%;height: 100%\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n", styles: [""] }]
113
+ args: [{ selector: 'app-img', template: "<canvas #canvas1 style=\"width: 100%;height: 100%;\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n<ng-content></ng-content>\n", styles: [""] }]
124
114
  }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { url: [{
125
115
  type: Input
126
116
  }], canvas1: [{
@@ -128,5 +118,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
128
118
  args: ['canvas1', { static: false }]
129
119
  }], clipArr: [{
130
120
  type: Input
121
+ }], rotateNum: [{
122
+ type: Input
123
+ }], loadOver: [{
124
+ type: Output
131
125
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img-canvas.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/img-canvas/img-canvas.component.ts","../../../../../../projects/components/src/lib/shared/img-canvas/img-canvas.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, Input, OnInit, ViewChild} from '@angular/core';\nimport {SessionStorageUtil} from \"../../../core/utils/sessionstorage.util\";\n\n@Component({\n  selector: 'app-img',\n  templateUrl: './img-canvas.component.html',\n  styleUrls: ['./img-canvas.component.less']\n})\nexport class ImgCanvasComponent implements OnInit, AfterViewInit {\n\n  @Input() set url(url: string) {\n    if (url && url.indexOf('?v=') < 0) {\n      if (url.indexOf(\"?\") < 0) {\n        url += \"?\";\n\n      }\n      url += \"v=\" + new Date().getTime()\n    }\n    this.imgUrl = url;\n  }\n\n  @ViewChild('canvas1', {static: false}) canvas1: any;\n  canvasDom: any\n  width = 800;\n  height = 800;\n  imgUrl: any;\n  img: any;\n  @Input() clipArr: any[] = [];\n\n  constructor(private elementRef: ElementRef) {\n  }\n\n  ngOnInit(): void {\n\n  }\n\n  getCanvasFull() {\n    let imgW = this.img.width//图片的宽\n    let imgH = this.img.height//图片的高\n    let cW = this.width;\n    let cH = this.height;\n    let rateW = imgH / imgW//比例\n    let rateH = imgW / imgH//比例\n    if (imgW > imgH) {\n      imgW = this.width\n      imgH = imgW * rateW;\n      if (imgH > cH) {\n        imgH = cH\n        imgW = imgH * rateH\n      }\n    } else {\n      imgH = this.height\n      imgW = imgH * rateH;\n      if (imgW > cW) {\n        imgW = cW\n        imgH = imgW * rateW\n      }\n    }\n\n    // imgH = this.canvasDom.offsetHeight\n    // imgW = this.canvasDom.offsetWidth\n    // let canvasH = imgH * rate\n    // if (canvasH > this.height) {\n    //   canvasH = this.height\n    //   rate = canvasH / imgH\n    //   canvasW = imgW * rate\n    // }\n    console.log(\"图片宽高\", imgW + \";\" + imgH)\n    return {\n      imgW: imgW,\n      imgH: imgH\n    }\n  }\n\n  initImg(needSession = true) {\n    let obj = SessionStorageUtil.get('appImg')\n    this.canvasDom = this.canvas1.nativeElement;\n    // this.canvasDom = document.getElementById(this.canvasId);\n    //检测支持性\n    if (!this.canvasDom.getContext('2d')) return;\n    //获得 2d 上下文对象\n    let context1 = this.canvasDom.getContext('2d');\n    let image = this.imgUrl\n    // if (obj && needSession && obj[image]) {\n    //   //图片缓存在session中\n    //   this.img = obj[image]\n    //   this.initBase(context1)\n    //   return;\n    // }\n    if(!obj) {\n      obj = {}\n    }\n    this.img = new Image();//创建img元素\n    this.img.setAttribute('crossOrigin', 'anonymous')\n    this.img.src = this.imgUrl;//设置图片源地址\n    // this.img.src = ToolsUtil.getOssUrl(this.imgUrl);//设置图片源地址\n    this.img.onload = () => {\n      obj[image] = this.img\n      SessionStorageUtil.put('appImg', obj)\n      this.initBase(context1)\n    }\n  }\n\n  initBase(context1: any) {\n\n    console.log(\"图片加载完毕\", this.img.height)\n    console.log(\"图片加载完毕\", this.img.width)\n    const {imgW, imgH} = this.getCanvasFull();\n    this.canvasDom.width = this.width;\n    this.canvasDom.height = this.height;\n    if (this.clipArr && this.clipArr.length > 0) {\n      this.goClip(context1)\n    }\n    // 参数 1：要绘制的 img   参数 2、3：绘制的 img 在 canvas 中的坐标 参数4,5是width，height\n    context1.drawImage(this.img, 0, 0, this.width, this.height,);\n    console.log(\"图片加载完毕\", this.canvasDom.width + \",\" + this.canvasDom.height)\n  }\n\n  goClip(context: any) {\n    context.beginPath()\n    context.moveTo(this.clipArr[0].x1, this.clipArr[0].y1);\n    this.clipArr.forEach((item, index) => {\n      if (index > 0) {\n        context.lineTo(item.x1, item.y1)\n      }\n    })\n    context.lineTo(this.clipArr[0].x1, this.clipArr[0].y1);\n    context.clip();\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      console.log('当前组件宽高', this.elementRef.nativeElement.offsetHeight)\n      this.initImg()\n    }, 300)\n  }\n\n}\n","<canvas #canvas1 style=\"width: 100%;height: 100%\">\n    您的浏览器不支持画布！\n</canvas>\n"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img-canvas.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/img-canvas/img-canvas.component.ts","../../../../../../projects/components/src/lib/shared/img-canvas/img-canvas.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {SessionStorageUtil} from \"../../../core/utils/sessionstorage.util\";\n\n@Component({\n  selector: 'app-img',\n  templateUrl: './img-canvas.component.html',\n  styleUrls: ['./img-canvas.component.less']\n})\nexport class ImgCanvasComponent implements OnInit, AfterViewInit {\n\n  @Input() set url(url: string) {\n    if (url && url.indexOf('?v=') < 0) {\n      if (url.indexOf(\"?\") < 0) {\n        url += \"?\";\n\n      }\n      url += \"v=\" + new Date().getTime()\n    }\n    this.imgUrl = url;\n  }\n\n  @ViewChild('canvas1', {static: false}) canvas1: any;\n  canvasDom: any\n  width = 800;\n  height = 800;\n  imgUrl: any;\n  img: any;\n  @Input() clipArr: any[] = [];\n  @Input() rotateNum: any = 0;\n  @Output() loadOver: EventEmitter<any> = new EventEmitter();\n\n  constructor(private elementRef: ElementRef) {\n  }\n\n  ngOnInit(): void {\n\n  }\n\n  getCanvasFull() {\n    let imgW = this.img.width//图片的宽\n    let imgH = this.img.height//图片的高\n    let cW = this.width;\n    let cH = this.height;\n    let rateW = imgH / imgW//比例\n    let rateH = imgW / imgH//比例\n    if (imgW > imgH) {\n      imgW = this.width\n      imgH = imgW * rateW;\n      if (imgH > cH) {\n        imgH = cH\n        imgW = imgH * rateH\n      }\n    } else {\n      imgH = this.height\n      imgW = imgH * rateH;\n      if (imgW > cW) {\n        imgW = cW\n        imgH = imgW * rateW\n      }\n    }\n\n    // imgH = this.canvasDom.offsetHeight\n    // imgW = this.canvasDom.offsetWidth\n    // let canvasH = imgH * rate\n    // if (canvasH > this.height) {\n    //   canvasH = this.height\n    //   rate = canvasH / imgH\n    //   canvasW = imgW * rate\n    // }\n    console.log(\"图片宽高\", imgW + \";\" + imgH)\n    return {\n      imgW: imgW,\n      imgH: imgH\n    }\n  }\n\n  initImg(needSession = true) {\n    this.canvasDom = this.canvas1.nativeElement;\n    // this.canvasDom = document.getElementById(this.canvasId);\n    //检测支持性\n    if (!this.canvasDom.getContext('2d')) return;\n    //获得 2d 上下文对象\n    let context1 = this.canvasDom.getContext('2d');\n    let image = this.imgUrl\n    this.img = new Image();//创建img元素\n    this.img.setAttribute('crossOrigin', 'anonymous')\n    this.img.src = this.imgUrl;//设置图片源地址\n    // this.img.src = ToolsUtil.getOssUrl(this.imgUrl);//设置图片源地址\n    this.img.onload = () => {\n      this.initBase(context1)\n      this.loadOver.emit({code:'loadOver'})\n    }\n  }\n\n  initBase(context1: any) {\n\n    console.log(\"图片加载完毕\", this.img.height)\n    console.log(\"图片加载完毕\", this.img.width)\n    const {imgW, imgH} = this.getCanvasFull();\n    this.canvasDom.width = this.width;\n    this.canvasDom.height = this.height;\n    if (this.clipArr && this.clipArr.length > 0) {\n      this.goClip(context1)\n    }\n    // 参数 1：要绘制的 img   参数 2、3：绘制的 img 在 canvas 中的坐标 参数4,5是width，height\n    context1.drawImage(this.img, 0, 0, this.width, this.height,);\n    console.log(\"图片加载完毕\", this.canvasDom.width + \",\" + this.canvasDom.height)\n  }\n\n  goClip(context: any) {\n    context.beginPath()\n    context.moveTo(this.clipArr[0].x1, this.clipArr[0].y1);\n    this.clipArr.forEach((item, index) => {\n      if (index > 0) {\n        context.lineTo(item.x1, item.y1)\n      }\n    })\n    context.lineTo(this.clipArr[0].x1, this.clipArr[0].y1);\n    context.clip();\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      console.log('当前组件宽高', this.elementRef.nativeElement.offsetHeight)\n      this.initImg()\n    }, 300)\n  }\n\n}\n","<canvas #canvas1 style=\"width: 100%;height: 100%;\">\n  您的浏览器不支持画布！\n</canvas>\n<ng-content></ng-content>\n"]}
@@ -4785,6 +4785,8 @@ class ImgCanvasComponent {
4785
4785
  this.width = 800;
4786
4786
  this.height = 800;
4787
4787
  this.clipArr = [];
4788
+ this.rotateNum = 0;
4789
+ this.loadOver = new EventEmitter();
4788
4790
  }
4789
4791
  set url(url) {
4790
4792
  if (url && url.indexOf('?v=') < 0) {
@@ -4835,7 +4837,6 @@ class ImgCanvasComponent {
4835
4837
  };
4836
4838
  }
4837
4839
  initImg(needSession = true) {
4838
- let obj = SessionStorageUtil.get('appImg');
4839
4840
  this.canvasDom = this.canvas1.nativeElement;
4840
4841
  // this.canvasDom = document.getElementById(this.canvasId);
4841
4842
  //检测支持性
@@ -4844,23 +4845,13 @@ class ImgCanvasComponent {
4844
4845
  //获得 2d 上下文对象
4845
4846
  let context1 = this.canvasDom.getContext('2d');
4846
4847
  let image = this.imgUrl;
4847
- // if (obj && needSession && obj[image]) {
4848
- // //图片缓存在session中
4849
- // this.img = obj[image]
4850
- // this.initBase(context1)
4851
- // return;
4852
- // }
4853
- if (!obj) {
4854
- obj = {};
4855
- }
4856
4848
  this.img = new Image(); //创建img元素
4857
4849
  this.img.setAttribute('crossOrigin', 'anonymous');
4858
4850
  this.img.src = this.imgUrl; //设置图片源地址
4859
4851
  // this.img.src = ToolsUtil.getOssUrl(this.imgUrl);//设置图片源地址
4860
4852
  this.img.onload = () => {
4861
- obj[image] = this.img;
4862
- SessionStorageUtil.put('appImg', obj);
4863
4853
  this.initBase(context1);
4854
+ this.loadOver.emit({ code: 'loadOver' });
4864
4855
  };
4865
4856
  }
4866
4857
  initBase(context1) {
@@ -4895,10 +4886,10 @@ class ImgCanvasComponent {
4895
4886
  }
4896
4887
  }
4897
4888
  ImgCanvasComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ImgCanvasComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
4898
- ImgCanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: ImgCanvasComponent, selector: "app-img", inputs: { url: "url", clipArr: "clipArr" }, viewQueries: [{ propertyName: "canvas1", first: true, predicate: ["canvas1"], descendants: true }], ngImport: i0, template: "<canvas #canvas1 style=\"width: 100%;height: 100%\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n", styles: [""] });
4889
+ ImgCanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: ImgCanvasComponent, selector: "app-img", inputs: { url: "url", clipArr: "clipArr", rotateNum: "rotateNum" }, outputs: { loadOver: "loadOver" }, viewQueries: [{ propertyName: "canvas1", first: true, predicate: ["canvas1"], descendants: true }], ngImport: i0, template: "<canvas #canvas1 style=\"width: 100%;height: 100%;\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n<ng-content></ng-content>\n", styles: [""] });
4899
4890
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ImgCanvasComponent, decorators: [{
4900
4891
  type: Component,
4901
- args: [{ selector: 'app-img', template: "<canvas #canvas1 style=\"width: 100%;height: 100%\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n", styles: [""] }]
4892
+ args: [{ selector: 'app-img', template: "<canvas #canvas1 style=\"width: 100%;height: 100%;\">\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\n</canvas>\n<ng-content></ng-content>\n", styles: [""] }]
4902
4893
  }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { url: [{
4903
4894
  type: Input
4904
4895
  }], canvas1: [{
@@ -4906,6 +4897,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
4906
4897
  args: ['canvas1', { static: false }]
4907
4898
  }], clipArr: [{
4908
4899
  type: Input
4900
+ }], rotateNum: [{
4901
+ type: Input
4902
+ }], loadOver: [{
4903
+ type: Output
4909
4904
  }] } });
4910
4905
 
4911
4906
  const THIRDMODULES = [