source: imaps-frontend/node_modules/konva/lib/Canvas.js@ 79a0317

main
Last change on this file since 79a0317 was 0c6b92a, checked in by stefan toskovski <stefantoska84@…>, 6 weeks ago

Pred finalna verzija

  • Property mode set to 100644
File size: 4.0 KB
Line 
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.HitCanvas = exports.SceneCanvas = exports.Canvas = void 0;
4const Util_1 = require("./Util");
5const Context_1 = require("./Context");
6const Global_1 = require("./Global");
7const Factory_1 = require("./Factory");
8const Validators_1 = require("./Validators");
9let _pixelRatio;
10function getDevicePixelRatio() {
11 if (_pixelRatio) {
12 return _pixelRatio;
13 }
14 const canvas = Util_1.Util.createCanvasElement();
15 const context = canvas.getContext('2d');
16 _pixelRatio = (function () {
17 const devicePixelRatio = Global_1.Konva._global.devicePixelRatio || 1, backingStoreRatio = context.webkitBackingStorePixelRatio ||
18 context.mozBackingStorePixelRatio ||
19 context.msBackingStorePixelRatio ||
20 context.oBackingStorePixelRatio ||
21 context.backingStorePixelRatio ||
22 1;
23 return devicePixelRatio / backingStoreRatio;
24 })();
25 Util_1.Util.releaseCanvas(canvas);
26 return _pixelRatio;
27}
28class Canvas {
29 constructor(config) {
30 this.pixelRatio = 1;
31 this.width = 0;
32 this.height = 0;
33 this.isCache = false;
34 const conf = config || {};
35 const pixelRatio = conf.pixelRatio || Global_1.Konva.pixelRatio || getDevicePixelRatio();
36 this.pixelRatio = pixelRatio;
37 this._canvas = Util_1.Util.createCanvasElement();
38 this._canvas.style.padding = '0';
39 this._canvas.style.margin = '0';
40 this._canvas.style.border = '0';
41 this._canvas.style.background = 'transparent';
42 this._canvas.style.position = 'absolute';
43 this._canvas.style.top = '0';
44 this._canvas.style.left = '0';
45 }
46 getContext() {
47 return this.context;
48 }
49 getPixelRatio() {
50 return this.pixelRatio;
51 }
52 setPixelRatio(pixelRatio) {
53 const previousRatio = this.pixelRatio;
54 this.pixelRatio = pixelRatio;
55 this.setSize(this.getWidth() / previousRatio, this.getHeight() / previousRatio);
56 }
57 setWidth(width) {
58 this.width = this._canvas.width = width * this.pixelRatio;
59 this._canvas.style.width = width + 'px';
60 const pixelRatio = this.pixelRatio, _context = this.getContext()._context;
61 _context.scale(pixelRatio, pixelRatio);
62 }
63 setHeight(height) {
64 this.height = this._canvas.height = height * this.pixelRatio;
65 this._canvas.style.height = height + 'px';
66 const pixelRatio = this.pixelRatio, _context = this.getContext()._context;
67 _context.scale(pixelRatio, pixelRatio);
68 }
69 getWidth() {
70 return this.width;
71 }
72 getHeight() {
73 return this.height;
74 }
75 setSize(width, height) {
76 this.setWidth(width || 0);
77 this.setHeight(height || 0);
78 }
79 toDataURL(mimeType, quality) {
80 try {
81 return this._canvas.toDataURL(mimeType, quality);
82 }
83 catch (e) {
84 try {
85 return this._canvas.toDataURL();
86 }
87 catch (err) {
88 Util_1.Util.error('Unable to get data URL. ' +
89 err.message +
90 ' For more info read https://konvajs.org/docs/posts/Tainted_Canvas.html.');
91 return '';
92 }
93 }
94 }
95}
96exports.Canvas = Canvas;
97Factory_1.Factory.addGetterSetter(Canvas, 'pixelRatio', undefined, (0, Validators_1.getNumberValidator)());
98class SceneCanvas extends Canvas {
99 constructor(config = { width: 0, height: 0, willReadFrequently: false }) {
100 super(config);
101 this.context = new Context_1.SceneContext(this, {
102 willReadFrequently: config.willReadFrequently,
103 });
104 this.setSize(config.width, config.height);
105 }
106}
107exports.SceneCanvas = SceneCanvas;
108class HitCanvas extends Canvas {
109 constructor(config = { width: 0, height: 0 }) {
110 super(config);
111 this.hitCanvas = true;
112 this.context = new Context_1.HitContext(this);
113 this.setSize(config.width, config.height);
114 }
115}
116exports.HitCanvas = HitCanvas;
Note: See TracBrowser for help on using the repository browser.