Forked from
ogs / ogs
1491 commits behind the upstream repository.
-
Dmitri Naumov authoredDmitri Naumov authored
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
BoundaryElementsSearcher.h 2.01 KiB
/**
* \file
* \copyright
* Copyright (c) 2012-2024, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*/
#pragma once
#include <vector>
namespace GeoLib
{
struct GeoObject;
class Point;
class Polyline;
class Surface;
}
namespace MeshLib
{
class Mesh;
class Element;
}
namespace MeshGeoToolsLib
{
class MeshNodeSearcher;
class BoundaryElementsAtPoint;
class BoundaryElementsAlongPolyline;
class BoundaryElementsOnSurface;
/**
* This class searches boundary elements located on a given geometric object, i.e. polyline and surface.
* Note that internal boundaries are currently not supported.
*/
class BoundaryElementsSearcher
{
public:
/**
* Constructor
* @param mesh a mesh object
* @param mshNodeSearcher a MeshNodeSearcher object which is internally used to search mesh nodes
*/
BoundaryElementsSearcher(MeshLib::Mesh const& mesh,
MeshNodeSearcher const& mshNodeSearcher);
/// destructor
virtual ~BoundaryElementsSearcher();
/**
* generate boundary elements on the given geometric object (point, polyline, surface).
*
* @param geoObj a GeoLib::GeoObject where the nearest mesh node is searched for
* @param multiple_nodes_allowed allows for finding multiple nodes within
* the given search radius for a point
* @return a vector of boundary element objects
*/
std::vector<MeshLib::Element*> const& getBoundaryElements(
GeoLib::GeoObject const& geoObj, bool const multiple_nodes_allowed);
MeshLib::Mesh const& mesh;
private:
MeshNodeSearcher const& _mshNodeSearcher;
std::vector<BoundaryElementsAtPoint*> _boundary_elements_at_point;
std::vector<BoundaryElementsAlongPolyline*> _boundary_elements_along_polylines;
std::vector<BoundaryElementsOnSurface*> _boundary_elements_along_surfaces;
};
} // end namespace MeshGeoToolsLib