2021-06-03 11:27:48 -04:00
|
|
|
"""
|
|
|
|
CityGmlBase module abstract class to template the different level of details
|
|
|
|
SPDX - License - Identifier: LGPL - 3.0 - or -later
|
|
|
|
Copyright © 2021 Project Author Guille Gutierrez guillermo.gutierrezmorote@concordia.ca
|
|
|
|
"""
|
|
|
|
|
2021-06-03 10:12:06 -04:00
|
|
|
from abc import ABC
|
2021-06-02 11:16:00 -04:00
|
|
|
import numpy as np
|
|
|
|
from imports.geometry.helpers.geometry_helper import GeometryHelper
|
|
|
|
|
|
|
|
|
2021-06-03 10:12:06 -04:00
|
|
|
class CityGmlBase(ABC):
|
2021-06-03 11:27:48 -04:00
|
|
|
"""
|
|
|
|
CityGmlBase class inherited by the specific level of detail classes.
|
|
|
|
"""
|
2021-06-03 10:12:06 -04:00
|
|
|
def __init__(self):
|
|
|
|
self._surfaces = []
|
|
|
|
|
|
|
|
@property
|
|
|
|
def surfaces(self):
|
2021-06-03 11:27:48 -04:00
|
|
|
"""
|
2021-08-30 14:39:24 -04:00
|
|
|
Get parsed surfaces
|
2021-06-03 11:27:48 -04:00
|
|
|
"""
|
2021-06-03 10:12:06 -04:00
|
|
|
return self._surfaces
|
2021-06-02 11:16:00 -04:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def _remove_last_point(points):
|
|
|
|
array = points.split(' ')
|
|
|
|
res = " "
|
|
|
|
return res.join(array[0:len(array) - 3])
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def _solid_points(coordinates) -> np.ndarray:
|
|
|
|
solid_points = np.fromstring(coordinates, dtype=float, sep=' ')
|
|
|
|
solid_points = GeometryHelper.to_points_matrix(solid_points)
|
2021-06-03 10:12:06 -04:00
|
|
|
return solid_points
|
|
|
|
|
|
|
|
@classmethod
|
2021-08-30 11:38:28 -04:00
|
|
|
def _solid(cls, city_object_member):
|
2021-06-03 10:12:06 -04:00
|
|
|
raise NotImplementedError
|
|
|
|
|
|
|
|
@classmethod
|
2021-08-30 11:38:28 -04:00
|
|
|
def _multi_surface(cls, city_object_member):
|
2021-06-03 10:12:06 -04:00
|
|
|
raise NotImplementedError
|
|
|
|
|
|
|
|
@classmethod
|
2021-08-30 11:38:28 -04:00
|
|
|
def _multi_curve(cls, city_object_member):
|
2021-06-03 10:12:06 -04:00
|
|
|
raise NotImplementedError
|