2023-12-31 20:43:53 +01:00
|
|
|
import { JsonObject, JsonProperty } from 'typescript-json-serializer';
|
2023-11-28 21:10:12 +01:00
|
|
|
import Style from 'ol/style/Style'
|
|
|
|
import Feature from 'ol/Feature'
|
2023-12-31 20:43:53 +01:00
|
|
|
import CircleStyle from 'ol/style/Circle'
|
|
|
|
import Point from 'ol/geom/Point'
|
|
|
|
import Fill from 'ol/style/Fill'
|
|
|
|
import Stroke from 'ol/style/Stroke'
|
2023-11-28 21:10:12 +01:00
|
|
|
|
2023-12-31 20:43:53 +01:00
|
|
|
@JsonObject()
|
2023-11-28 21:10:12 +01:00
|
|
|
export default class MapNode {
|
2023-12-31 20:43:53 +01:00
|
|
|
private feature: Feature | null = null;
|
|
|
|
|
|
|
|
|
|
|
|
constructor(
|
|
|
|
@JsonProperty() private uuid: string,
|
|
|
|
@JsonProperty() private coordinate_1: number,
|
|
|
|
@JsonProperty() private coordinate_2: number,
|
|
|
|
@JsonProperty() private type: string,
|
|
|
|
@JsonProperty() private name: string,
|
|
|
|
@JsonProperty() private description: string,
|
|
|
|
@JsonProperty() private kind: string,
|
|
|
|
) {
|
|
|
|
}
|
|
|
|
|
|
|
|
public getType(): string {
|
|
|
|
return this.type;
|
|
|
|
}
|
|
|
|
|
|
|
|
public getName(): string {
|
|
|
|
return this.name;
|
|
|
|
}
|
|
|
|
|
|
|
|
public getDescription(): string {
|
|
|
|
return this.description;
|
2023-11-28 21:10:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public getId(): string {
|
2023-12-31 20:43:53 +01:00
|
|
|
return 'node-' + this.uuid;
|
2023-11-28 21:10:12 +01:00
|
|
|
}
|
|
|
|
|
2023-12-31 20:43:53 +01:00
|
|
|
public getFeature(): Feature {
|
|
|
|
if (this.feature === null) {
|
|
|
|
console.log(this.coordinate_1);
|
|
|
|
console.log(this.coordinate_2);
|
|
|
|
this.feature = new Feature({
|
|
|
|
geometry: new Point([this.coordinate_1, this.coordinate_2]),
|
|
|
|
type: 'node-' + this.uuid,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return this.feature;
|
2023-11-28 21:10:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public getStyle(): Style {
|
2023-12-31 20:43:53 +01:00
|
|
|
return new Style({
|
|
|
|
image: new CircleStyle({
|
|
|
|
radius: 14,
|
|
|
|
fill: new Fill({color: 'white'}),
|
|
|
|
stroke: new Stroke({
|
|
|
|
color: 'gray',
|
|
|
|
width: 2,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
});
|
2023-11-28 21:10:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|