ol-ext
Version:
A set of cool extensions for OpenLayers (ol) in node modules structure
55 lines (50 loc) • 4.42 kB
JavaScript
/*
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