51 lines
2.1 KiB
TypeScript
51 lines
2.1 KiB
TypeScript
import { Component, Input, OnDestroy, OnInit, EventEmitter, Output } from '@angular/core';
|
|
import { interaction } from 'openlayers';
|
|
import { MapComponent } from '../map.component';
|
|
|
|
@Component({
|
|
selector: 'aol-interaction-draw',
|
|
template: ''
|
|
})
|
|
export class DrawInteractionComponent implements OnInit, OnDestroy {
|
|
instance: interaction.Draw;
|
|
|
|
@Input() clickTolerance?: number;
|
|
@Input() features?: ol.Collection<ol.Feature>;
|
|
@Input() source?: ol.source.Vector;
|
|
@Input() snapTolerance?: number;
|
|
@Input() type: ol.geom.GeometryType;
|
|
@Input() maxPoints?: number;
|
|
@Input() minPoints?: number;
|
|
@Input() finishCondition?: ol.EventsConditionType;
|
|
@Input() style?: (ol.style.Style | ol.style.Style[] | ol.StyleFunction);
|
|
@Input() geometryFunction?: ol.DrawGeometryFunctionType;
|
|
@Input() geometryName?: string;
|
|
@Input() condition?: ol.EventsConditionType;
|
|
@Input() freehandCondition?: ol.EventsConditionType;
|
|
@Input() freehand?: boolean;
|
|
@Input() wrapX?: boolean;
|
|
|
|
@Output() onChange = new EventEmitter<ol.interaction.Draw.Event>();
|
|
@Output() onChangeActive = new EventEmitter<ol.interaction.Draw.Event>();
|
|
@Output() onDrawEnd = new EventEmitter<ol.interaction.Draw.Event>();
|
|
@Output() onDrawStart = new EventEmitter<ol.interaction.Draw.Event>();
|
|
@Output() onPropertyChange = new EventEmitter<ol.interaction.Draw.Event>();
|
|
|
|
constructor(private map: MapComponent) {
|
|
}
|
|
|
|
ngOnInit() {
|
|
this.instance = new interaction.Draw(this);
|
|
this.instance.on('change', (event: ol.interaction.Draw.Event) => this.onChange.emit(event));
|
|
this.instance.on('change:active', (event: ol.interaction.Draw.Event) => this.onChangeActive.emit(event));
|
|
this.instance.on('drawend', (event: ol.interaction.Draw.Event) => this.onDrawEnd.emit(event));
|
|
this.instance.on('drawstart', (event: ol.interaction.Draw.Event) => this.onDrawStart.emit(event));
|
|
this.instance.on('propertychange', (event: ol.interaction.Draw.Event) => this.onPropertyChange.emit(event));
|
|
this.map.instance.addInteraction(this.instance);
|
|
}
|
|
|
|
ngOnDestroy() {
|
|
this.map.instance.removeInteraction(this.instance);
|
|
}
|
|
}
|