Revision d56ec86d6132baeb1bb95040515471fa0ff9d35e authored by Thomas Fischer on 06 May 2021, 13:13:06 UTC, committed by Thomas Fischer on 10 May 2021, 08:53:30 UTC
1 parent 8b08b8e
MeshNodesOnPoint.h
/**
* \file
* \copyright
* Copyright (c) 2012-2021, 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>
#include "GeoLib/Point.h"
#include "GeoLib/Grid.h"
#include "MeshGeoToolsLib/SearchAllNodes.h"
#include "MeshLib/Node.h"
namespace MeshLib
{
class Mesh;
}
namespace MeshGeoToolsLib
{
/**
* This class computes the ids of the mesh nodes located at a given point.
*/
class MeshNodesOnPoint
{
public:
/**
* Constructor of object, that search mesh nodes at a GeoLib::Point point
* within a given search radius.
* @param mesh Mesh object whose nodes are searched
* @param mesh_grid Grid object constructed with mesh nodes
* @param pnt a point
* @param epsilon_radius Search radius
* @param search_all_nodes whether this searches all nodes or only base
* nodes
*/
MeshNodesOnPoint(MeshLib::Mesh const& mesh,
GeoLib::Grid<MeshLib::Node> const& mesh_grid,
GeoLib::Point const& pnt, double epsilon_radius,
SearchAllNodes search_all_nodes);
/// return the mesh object
MeshLib::Mesh const& getMesh() const { return _mesh; }
/**
* Access the vector of mesh node ids.
* @return The vector of mesh node ids calculated in the constructor
*/
std::vector<std::size_t> const& getNodeIDs() const { return _msh_node_ids; }
/**
* Deploying this method the user can get access to the underlying
* GeoLib::Point.
* @return the underlying GeoLib::Point
*/
GeoLib::Point const& getPoint() const { return _pnt; }
private:
MeshLib::Mesh const& _mesh;
GeoLib::Point const& _pnt;
std::vector<std::size_t> _msh_node_ids;
};
} // end namespace MeshGeoToolsLib
Computing file changes ...