26 : QObject(parent), _geo_objects(geo_objects)
82 ERR(
"GEOModels::updateGeometry() - Geometry '{:s}' not found.",
169 std::string
const& new_name)
176 const std::string& geoName, std::vector<std::size_t>
const& indexlist,
177 double const proximity, std::string
const& ply_name,
bool const closePly,
178 bool const triangulatePly)
184 std::vector<GeoLib::Polyline*>
const& polylines = *plyVec->
getVector();
185 std::vector<GeoLib::Polyline*> ply_list;
186 std::transform(indexlist.begin(), indexlist.end(),
187 std::back_inserter(ply_list),
188 [polylines](
auto const& ply_index)
189 { return polylines[ply_index]; });
200 std::vector<GeoLib::Polyline*> connected_ply;
202 connected_ply.push_back(new_line);
212 "Creating a surface by triangulation of the polyline "
217 std::vector<GeoLib::Surface*> new_sfc;
218 new_sfc.push_back(sfc.release());
225 "\t Creating a surface by triangulation of the "
232 if (!ply_name.empty())
250 std::size_t
const id,
251 std::string
const& new_name)
269 ERR(
"GEOModels::addNameForElement() - Unknown GEOTYPE {:s}.",
275 const std::string& geo_object_name,
276 const std::string& new_name)
285 for (std::size_t i = 0; i < nPoints; i++)
289 new_name +
"_Point" + std::to_string(ply->getPointID(i)));
296 for (std::size_t i = 0; i < nTriangles; i++)
300 (*tri)[0], new_name +
"_Point" + std::to_string((*tri)[0]));
302 (*tri)[1], new_name +
"_Point" + std::to_string((*tri)[1]));
304 (*tri)[2], new_name +
"_Point" + std::to_string((*tri)[2]));
308 ERR(
"GEOModels::addNameForObjectPoints() - Unknown GEOTYPE {:s}.",
Definition of the GEOModels class.
Definition of the GeoTreeModel class.
void INFO(char const *fmt, Args const &... args)
void ERR(char const *fmt, Args const &... args)
void WARN(char const *fmt, Args const &... args)
Definition of the OGSError class.
Definition of the StationTreeModel class.
GeoLib::GEOObjects & _geo_objects
void stationVectorAdded(StationTreeModel *model, std::string name)
void addStationVec(std::string const &name)
void addNameForObjectPoints(const std::string &geometry_name, const GeoLib::GEOTYPE object_type, const std::string &geo_object_name, const std::string &new_name)
Adds a generic name to all points that are part of the specified geo-object.
void appendSurfaceVec(std::string const &name)
void renameGeometry(std::string const &old_name, std::string const &new_name)
void addSurfaceVec(std::string const &name)
void removePointVec(std::string const &name)
void addPointVec(std::string const &name)
StationTreeModel * _stationModel
void stationVectorRemoved(StationTreeModel *model, std::string name)
void geoDataAdded(GeoTreeModel *, std::string, GeoLib::GEOTYPE)
void removeStationVec(std::string const &name)
void geoDataRemoved(GeoTreeModel *, std::string, GeoLib::GEOTYPE)
void updateGeometry(const std::string &geo_name)
void addNameForElement(std::string const &geometry_name, GeoLib::GEOTYPE const object_type, std::size_t const id, std::string const &new_name)
Adds the name 'new_name' for the geo-object specified by the parameters.
void removePolylineVec(std::string const &name)
GEOModels(GeoLib::GEOObjects &geo_objects, QObject *parent=nullptr)
void connectPolylineSegments(const std::string &geoName, std::vector< std::size_t > const &indexlist, double const proximity, std::string const &ply_name, bool const closePly, bool const triangulatePly)
void appendPolylineVec(std::string const &name)
void removeSurfaceVec(std::string const &name)
virtual void removeGeometry(std::string const &geo_name, GeoLib::GEOTYPE const type)
void addPolylineVec(std::string const &name)
Container class for geometric objects.
bool appendSurfaceVec(const std::vector< Surface * > &surfaces, const std::string &name)
const PointVec * getPointVecObj(const std::string &name) const
bool removePointVec(const std::string &name)
bool removeSurfaceVec(const std::string &name)
std::unique_ptr< Callbacks > _callbacks
SurfaceVec * getSurfaceVecObj(const std::string &name)
Returns the surface vector with the given name.
bool isPntVecUsed(const std::string &name) const
Checks if the point vector with the given name is referenced in a polyline- or surface vector.
const PolylineVec * getPolylineVecObj(const std::string &name) const
bool appendPolylineVec(const std::vector< Polyline * > &polylines, const std::string &name)
const GeoLib::GeoObject * getGeoObject(const std::string &geo_name, GeoLib::GEOTYPE type, const std::string &geo_obj_name) const
Returns the geo object for a geometric item of the given name and type for the associated geometry.
const std::vector< GeoLib::Point * > * getStationVec(const std::string &name) const
Returns the station vector with the given name.
bool removePolylineVec(const std::string &name)
This class manages pointers to Points in a std::vector along with a name. It also handles the deletin...
void setNameForElement(std::size_t id, std::string const &name) override
Sets the given name for the element of the given ID.
Class Polyline consists mainly of a reference to a point vector and a vector that stores the indices ...
static Polyline * constructPolylineFromSegments(const std::vector< Polyline * > &ply_vec, double prox=0.0)
std::size_t getNumberOfPoints() const
A Surface is represented by Triangles. It consists of a reference to a vector of (pointers to) points...
std::size_t getNumberOfTriangles() const
The class TemplateVec takes a unique name and manages a std::vector of pointers to data elements of t...
void setNameOfElementByID(std::size_t id, std::string const &element_name)
Return the name of an element based on its ID.
const std::vector< T * > * getVector() const
virtual void setNameForElement(std::size_t id, std::string const &name)
Sets the given name for the element of the given ID.
Class Triangle consists of a reference to a point vector and a vector that stores the indices in the ...
A model for the GeoTreeView implementing a tree as a double-linked list.
void appendPolylines(const std::string &name, GeoLib::PolylineVec const &polylineVec)
Appends polylines to the "Polyline"-subtree.
void addSurfaceList(QString geoName, GeoLib::SurfaceVec const &surfaceVec)
Adds a subtree "Surfaces" to an existing geometry with the given name.
void addPointList(QString geoName, GeoLib::PointVec const &pointVec)
void renameGeometry(std::string const &old_name, std::string const &new_name)
void appendSurfaces(const std::string &name, GeoLib::SurfaceVec const &surfaceVec)
Appends surfaces to the "Surface"-subtree.
void addPolylineList(QString geoName, GeoLib::PolylineVec const &polylineVec)
Adds a subtree "Polylines" to an existing geometry with the given name.
void removeGeoList(const std::string &name, GeoLib::GEOTYPE type)
static void box(const QString &e)
A model for the StationTreeView implementing a tree as a double-linked list.
void addStationList(QString listName, const std::vector< GeoLib::Point * > *stations)
void removeStationList(QModelIndex index)
std::unique_ptr< GeoLib::Surface > createSurfaceWithEarClipping(GeoLib::Polyline const &line)
std::string convertGeoTypeToString(GEOTYPE geo_type)