burguillos.info/js-src/conquer/map-node.ts

67 lines
1.7 KiB
TypeScript
Raw Normal View History

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
}
}