You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

84 lines
2.9 KiB

// This file is part of libigl, a simple c++ geometry processing library.
//
// Copyright (C) 2022 Vladimir S. FONOV <vladimir.fonov@gmail.com>
// Copyright (C) 2023 Alec Jacobson <alecjacobson@gmail.com>
//
// This Source Code Form is subject to the terms of the Mozilla Public License
// v. 2.0. If a copy of the MPL was not distributed with this file, You can
// obtain one at http://mozilla.org/MPL/2.0/
#pragma once
#ifndef FAST_FIND_MESH_INTERSECT_H
#define FAST_FIND_MESH_INTERSECT_H
#include "igl_inline.h"
#include <Eigen/Core>
namespace igl
{
template <typename DerivedV, int DIM> class AABB;
/// Identify triangles where two meshes interesect
/// using AABBTree and tri_tri_intersection_test_3d.
///
/// @param[in] V1 #V1 by 3 list representing vertices on the first mesh
/// @param[in] F1 #F1 by 3 list representing triangles on the first mesh
/// @param[in] V2 #V2 by 3 list representing vertices on the second mesh
/// @param[in] F2 #F2 by 3 list representing triangles on the second mesh
/// @param[out] IF #IF by 2 list of intersecting triangle pairs, so that
/// F1(IF(i,0),:) intersects F2(IF(i,1),:)
/// @param[out] EV #EV by 3 list of vertices definining intersection segments
/// for non-coplanar intersections
/// @param[out] EE #EE by 2 list of edges indices into rows of EV
/// @param[out] EI #EI by 1 list of indices into rows IF indicating source of
/// intersection.
///
/// \see copyleft::cgal::intersect_other
template <
typename DerivedV1,
typename DerivedF1,
typename DerivedV2,
typename DerivedF2,
typename DerivedIF,
typename DerivedEV,
typename DerivedEE,
typename DerivedEI>
IGL_INLINE bool fast_find_intersections(
const AABB<DerivedV1,3> & tree,
const Eigen::MatrixBase<DerivedV1> & V1,
const Eigen::MatrixBase<DerivedF1> & F1,
const Eigen::MatrixBase<DerivedV2> & V2,
const Eigen::MatrixBase<DerivedF2> & F2,
const bool detect_only,
const bool first_only,
Eigen::PlainObjectBase<DerivedIF> & IF,
Eigen::PlainObjectBase<DerivedEV> & EV,
Eigen::PlainObjectBase<DerivedEE> & EE,
Eigen::PlainObjectBase<DerivedEI> & EI);
/// \overload
/// \brief Tree built internally.
template <
typename DerivedV1,
typename DerivedF1,
typename DerivedV2,
typename DerivedF2,
typename DerivedIF,
typename DerivedEV,
typename DerivedEE,
typename DerivedEI>
IGL_INLINE bool fast_find_intersections(
const Eigen::MatrixBase<DerivedV1> & V1,
const Eigen::MatrixBase<DerivedF1> & F1,
const Eigen::MatrixBase<DerivedV2> & V2,
const Eigen::MatrixBase<DerivedF2> & F2,
const bool detect_only,
const bool first_only,
Eigen::PlainObjectBase<DerivedIF> & IF,
Eigen::PlainObjectBase<DerivedEV> & EV,
Eigen::PlainObjectBase<DerivedEE> & EE,
Eigen::PlainObjectBase<DerivedEI> & EI);
};
#ifndef IGL_STATIC_LIBRARY
# include "fast_find_intersections.cpp"
#endif
#endif