/* Copyright (c) 2020 Jean-Marc VIGLINO, released under the CeCILL-B license (French BSD license) (http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.txt). */ import ol_particule_Base from './Base.js' /** A cloud particule to display clouds over the map * @constructor * @extends {ol_particule_Base} * @param {*} options * @param {ol.Overlay} options.overlay * @param {ol.pixel} options.coordinate the position of the particule * @param {string} [options.src] bird image src */ var ol_particule_Bird = class olparticuleBird extends ol_particule_Base { constructor(options) { options = options || {}; super(options); this.bird = new Image(); this.bird.addEventListener('load', function() { this.set('size', [this.bird.width || 50, this.bird.height || 50]); console.log(this.bird.width, this.bird.height) }.bind(this)) this.bird.src = options.src || ''; this.set('size', [this.bird.width || 50, this.bird.height || 50]); } /** Draw the particule * @param {CanvasRenderingContext2D } ctx */ draw(ctx) { //ctx.drawImage(this.bird, this.coordinate[0], this.coordinate[1]); var angle = this.getOverlay().get('angle'); ctx.save(); ctx.translate(this.coordinate[0], this.coordinate[1]); ctx.rotate(angle + Math.PI / 2); ctx.scale(.5, .5); ctx.drawImage(this.bird, -this.bird.width / 2, -this.bird.height / 2); ctx.restore(); } /** Update the particule * @param {number} dt timelapes since last call */ update(dt) { var speed = this.getOverlay().get('speed') * dt / this.getOverlay()._fps; var angle = this.getOverlay().get('angle'); this.coordinate[0] += speed * Math.cos(angle); this.coordinate[1] += speed * Math.sin(angle); } } export default ol_particule_Bird