diff --git a/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformalVoronoiMesh/conformalVoronoiMeshIO.C b/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformalVoronoiMesh/conformalVoronoiMeshIO.C index 0de3572e0007fdad50f4a7d79cbb5f6d76be4c7e..50d0288718aa11a30c6c6d191404387b1f8aff04 100644 --- a/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformalVoronoiMesh/conformalVoronoiMeshIO.C +++ b/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformalVoronoiMesh/conformalVoronoiMeshIO.C @@ -40,6 +40,7 @@ License #include "polyModifyFace.H" #include "syncTools.H" #include "regionSplit.H" +#include "OBJstream.H" // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * // diff --git a/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.C b/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.C index 351b85c952dd13a9f9875c3e6a86f3c346ea8c57..43d9c770134a330f62629b67c488b32a91a1173d 100644 --- a/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.C +++ b/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.C @@ -872,6 +872,42 @@ void Foam::conformationSurfaces::findSurfaceAnyIntersection } +void Foam::conformationSurfaces::findSurfaceAllIntersections +( + const point& start, + const point& end, + List<pointIndexHit>& surfHit, + labelList& hitSurface +) const +{ + labelListList hitSurfaces; + List<List<pointIndexHit> > hitInfo; + + searchableSurfacesQueries::findAllIntersections + ( + allGeometry_, + surfaces_, + pointField(1, start), + pointField(1, end), + hitSurfaces, + hitInfo + ); + + surfHit = hitInfo[0]; + + hitSurface.setSize(hitSurfaces[0].size()); + + forAll(hitSurfaces[0], surfI) + { + // hitSurfaces has returned the index of the entry in surfaces_ that was + // found, not the index of the surface in allGeometry_, translating this + // to allGeometry_ + + hitSurface[surfI] = surfaces_[hitSurfaces[0][surfI]]; + } +} + + void Foam::conformationSurfaces::findSurfaceNearestIntersection ( const point& start, diff --git a/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.H b/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.H index 68c5fd28b92e93c159622fa21ca2883da222cbd0..12932255da25a69e5effc0b1bbd81c223dac35be 100644 --- a/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.H +++ b/applications/utilities/mesh/generation/foamyHexMesh/conformalVoronoiMesh/conformationSurfaces/conformationSurfaces.H @@ -257,6 +257,14 @@ public: label& hitSurface ) const; + void findSurfaceAllIntersections + ( + const point& start, + const point& end, + List<pointIndexHit>& surfHit, + labelList& hitSurface + ) const; + //- Finding the nearestIntersection of the surface to start void findSurfaceNearestIntersection (