source: imaps-frontend/node_modules/konva/lib/shapes/Sprite.js@ 0c6b92a

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

Pred finalna verzija

  • Property mode set to 100644
File size: 3.9 KB
RevLine 
[d565449]1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.Sprite = void 0;
4const Factory_1 = require("../Factory");
5const Shape_1 = require("../Shape");
6const Animation_1 = require("../Animation");
7const Validators_1 = require("../Validators");
8const Global_1 = require("../Global");
9class Sprite extends Shape_1.Shape {
10 constructor(config) {
11 super(config);
12 this._updated = true;
13 this.anim = new Animation_1.Animation(() => {
[0c6b92a]14 const updated = this._updated;
[d565449]15 this._updated = false;
16 return updated;
17 });
18 this.on('animationChange.konva', function () {
19 this.frameIndex(0);
20 });
21 this.on('frameIndexChange.konva', function () {
22 this._updated = true;
23 });
24 this.on('frameRateChange.konva', function () {
25 if (!this.anim.isRunning()) {
26 return;
27 }
28 clearInterval(this.interval);
29 this._setInterval();
30 });
31 }
32 _sceneFunc(context) {
[0c6b92a]33 const anim = this.animation(), index = this.frameIndex(), ix4 = index * 4, set = this.animations()[anim], offsets = this.frameOffsets(), x = set[ix4 + 0], y = set[ix4 + 1], width = set[ix4 + 2], height = set[ix4 + 3], image = this.image();
[d565449]34 if (this.hasFill() || this.hasStroke()) {
35 context.beginPath();
36 context.rect(0, 0, width, height);
37 context.closePath();
38 context.fillStrokeShape(this);
39 }
40 if (image) {
41 if (offsets) {
[0c6b92a]42 const offset = offsets[anim], ix2 = index * 2;
[d565449]43 context.drawImage(image, x, y, width, height, offset[ix2 + 0], offset[ix2 + 1], width, height);
44 }
45 else {
46 context.drawImage(image, x, y, width, height, 0, 0, width, height);
47 }
48 }
49 }
50 _hitFunc(context) {
[0c6b92a]51 const anim = this.animation(), index = this.frameIndex(), ix4 = index * 4, set = this.animations()[anim], offsets = this.frameOffsets(), width = set[ix4 + 2], height = set[ix4 + 3];
[d565449]52 context.beginPath();
53 if (offsets) {
[0c6b92a]54 const offset = offsets[anim];
55 const ix2 = index * 2;
[d565449]56 context.rect(offset[ix2 + 0], offset[ix2 + 1], width, height);
57 }
58 else {
59 context.rect(0, 0, width, height);
60 }
61 context.closePath();
62 context.fillShape(this);
63 }
64 _useBufferCanvas() {
65 return super._useBufferCanvas(true);
66 }
67 _setInterval() {
[0c6b92a]68 const that = this;
[d565449]69 this.interval = setInterval(function () {
70 that._updateIndex();
71 }, 1000 / this.frameRate());
72 }
73 start() {
74 if (this.isRunning()) {
75 return;
76 }
[0c6b92a]77 const layer = this.getLayer();
[d565449]78 this.anim.setLayers(layer);
79 this._setInterval();
80 this.anim.start();
81 }
82 stop() {
83 this.anim.stop();
84 clearInterval(this.interval);
85 }
86 isRunning() {
87 return this.anim.isRunning();
88 }
89 _updateIndex() {
[0c6b92a]90 const index = this.frameIndex(), animation = this.animation(), animations = this.animations(), anim = animations[animation], len = anim.length / 4;
[d565449]91 if (index < len - 1) {
92 this.frameIndex(index + 1);
93 }
94 else {
95 this.frameIndex(0);
96 }
97 }
98}
99exports.Sprite = Sprite;
100Sprite.prototype.className = 'Sprite';
101(0, Global_1._registerNode)(Sprite);
102Factory_1.Factory.addGetterSetter(Sprite, 'animation');
103Factory_1.Factory.addGetterSetter(Sprite, 'animations');
104Factory_1.Factory.addGetterSetter(Sprite, 'frameOffsets');
105Factory_1.Factory.addGetterSetter(Sprite, 'image');
106Factory_1.Factory.addGetterSetter(Sprite, 'frameIndex', 0, (0, Validators_1.getNumberValidator)());
107Factory_1.Factory.addGetterSetter(Sprite, 'frameRate', 17, (0, Validators_1.getNumberValidator)());
108Factory_1.Factory.backCompat(Sprite, {
109 index: 'frameIndex',
110 getIndex: 'getFrameIndex',
111 setIndex: 'setFrameIndex',
112});
Note: See TracBrowser for help on using the repository browser.