diff options
author | Abyss777 <abyss@fox5.ru> | 2016-11-14 17:41:45 +0500 |
---|---|---|
committer | Abyss777 <abyss@fox5.ru> | 2016-11-14 17:41:45 +0500 |
commit | fcd47ae26b362891514d58a02377d7fbf696b961 (patch) | |
tree | e5c6bff81c7a600341ed677a94f1a0fe729725b4 /web/app/DeviceImages.js | |
parent | cac80442ee6ce9ed72007733346f17fa410d1674 (diff) | |
download | trackermap-web-fcd47ae26b362891514d58a02377d7fbf696b961.tar.gz trackermap-web-fcd47ae26b362891514d58a02377d7fbf696b961.tar.bz2 trackermap-web-fcd47ae26b362891514d58a02377d7fbf696b961.zip |
Remove marker style recreation on marker rotate and color change
Diffstat (limited to 'web/app/DeviceImages.js')
-rw-r--r-- | web/app/DeviceImages.js | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/web/app/DeviceImages.js b/web/app/DeviceImages.js index 96f00980..d976a2b3 100644 --- a/web/app/DeviceImages.js +++ b/web/app/DeviceImages.js @@ -62,6 +62,11 @@ Ext.define('Traccar.DeviceImages', { return svg; }, + formatSrc: function (svg) { + return 'data:image/svg+xml;charset=utf-8,' + + encodeURIComponent(new XMLSerializer().serializeToString(svg.documentElement)); + }, + getImageIcon: function (color, zoom, angle, category) { var image, svg, width, height; @@ -71,14 +76,26 @@ Ext.define('Traccar.DeviceImages', { image = new ol.style.Icon({ imgSize: [width, height], - src: 'data:image/svg+xml;charset=utf-8,' + encodeURIComponent(new XMLSerializer().serializeToString(svg.documentElement)) + src: this.formatSrc(svg) }); - image.load(); image.fill = color; image.zoom = zoom; image.angle = angle; image.category = category; return image; + }, + + rotateImageIcon: function (image, angle) { + var svg = Traccar.DeviceImages.getImageSvg(image.fill, image.zoom, angle, image.category); + image.getImage().src = this.formatSrc(svg); + image.angle = angle; + }, + + changeImageColor: function (image, color, category) { + var svg = Traccar.DeviceImages.getImageSvg(color, image.zoom, image.angle, category); + image.getImage().src = this.formatSrc(svg); + image.fill = color; + image.category = category; } }); |