header files that helps constructing visual

hulls
This commit is contained in:
Peter Hachenberger 2006-03-16 19:25:22 +00:00
parent 6723bef013
commit 6da8a70a8a
2 changed files with 221 additions and 0 deletions

1
.gitattributes vendored
View File

@ -1163,6 +1163,7 @@ Nef_3/Visual_hull/Nef_3/mpi.off -text
Nef_3/Visual_hull/Nef_3/mpi_triang.off -text
Nef_3/Visual_hull/Nef_3/octahedron.off -text
Nef_3/demo/Nef_3/cube.off -text
Nef_3/demo/Nef_3/include/CGAL/Nef_3/visual_hull_creator.h -text
Nef_3/demo/Nef_3/visual_hull.C -text
Nef_3/doc_tex/Nef_3/fig/closeup.eps -text svneol=unset#unset
Nef_3/doc_tex/Nef_3/fig/closeup.gif -text svneol=unset#unset

View File

@ -0,0 +1,220 @@
#ifndef CGAL_NEF_VISUAL_HULL_CREATOR_H
#define CGAL_NEF_VISUAL_HULL_CREATOR_H
#include <CGAL/Object.h>
#include <CGAL/intersections.h>
#include <CGAL/Polyhedron_3.h>
#include <CGAL/IO/Polyhedron_iostream.h>
#include <CGAL/IO/Nef_polyhedron_iostream_3.h>
#include <CGAL/Modifier_base.h>
CGAL_BEGIN_NAMESPACE
template <typename SNC_>
class visual_hull_creator : public CGAL::Modifier_base<SNC_> {
typedef SNC_ SNC_structure;
typedef typename SNC_structure::Kernel Kernel;
typedef CGAL::Polyhedron_3<Kernel> Polyhedron;
typedef CGAL::SNC_decorator<SNC_structure> SNC_decorator;
typedef SNC_decorator Base;
typedef typename SNC_decorator::SNC_constructor SNC_constructor;
typedef typename SNC_structure::SM_decorator SM_decorator;
typedef typename SNC_structure::Vertex_handle Vertex_handle;
typedef typename SNC_structure::SVertex_iterator SVertex_iterator;
typedef typename SNC_structure::Point_3 Point_3;
typedef typename SNC_structure::Plane_3 Plane_3;
typedef typename SNC_structure::Vector_3 Vector_3;
typedef typename SNC_structure::Ray_3 Ray_3;
typedef typename SNC_structure::Sphere_point Sphere_point;
Point_3 room_min, room_max;
Point_3 c_pos;
Vertex_handle camera;
Plane_3 cut;
SNC_structure* sncp;
std::list<std::list<Point_3> > polygon_list;
private:
Plane_3 find_cutoff_plane() {
bool compute_halfsphere[3][2];
for(int i=0; i<6; i++)
compute_halfsphere[i/2][i%2] = false;
SVertex_iterator sv;
SM_decorator SD(&*camera);
CGAL_forall_svertices(sv,SD) {
if(!compute_halfsphere[0][0])
if(sv->point().hx()>0)
compute_halfsphere[0][0] = true;
if(!compute_halfsphere[0][1])
if(sv->point().hx()<0)
compute_halfsphere[0][1] = true;
if(!compute_halfsphere[1][0])
if(sv->point().hy()>0)
compute_halfsphere[1][0] = true;
if(!compute_halfsphere[1][1])
if(sv->point().hy()<0)
compute_halfsphere[1][1] = true;
if(!compute_halfsphere[2][0])
if(sv->point().hz()>0)
compute_halfsphere[2][0] = true;
if(!compute_halfsphere[2][1])
if(sv->point().hz()<0)
compute_halfsphere[2][1] = true;
}
if(!compute_halfsphere[0][1])
return Plane_3(Point_3(room_max.hx(),0,0,room_max.hw()),Vector_3(1,0,0));
if(!compute_halfsphere[0][0])
return Plane_3(Point_3(room_min.hx(),0,0,room_min.hw()),Vector_3(-1,0,0));
if(!compute_halfsphere[1][1])
return Plane_3(Point_3(0,room_min.hy(),0,room_max.hw()),Vector_3(0,1,0));
if(!compute_halfsphere[1][0])
return Plane_3(Point_3(0,room_min.hy(),0,room_min.hw()),Vector_3(0,-1,0));
if(!compute_halfsphere[2][1])
return Plane_3(Point_3(0,0,room_max.hz(),room_max.hw()),Vector_3(0,0,1));
if(!compute_halfsphere[2][0])
return Plane_3(Point_3(0,0,room_min.hz(),room_min.hw()),Vector_3(0,0,-1));
CGAL_assertion_msg(false,"wrong sphere map");
return Plane_3();
}
public:
visual_hull_creator(Point_3 min, Point_3 max, Point_3 position,
std::list<std::list<Point_3> > p) :
room_min(min), room_max(max), c_pos(position), polygon_list(p) { }
void operator()(SNC_structure& snc) {
sncp = &snc;
snc.clear();
camera = sncp->new_vertex(c_pos);
camera->mark() = true;
typename std::list< std::list<Point_3> >::iterator li;
for(li=polygon_list.begin(); li!=polygon_list.end(); ++li)
if(li==polygon_list.begin()) {
add_outer_cycle_to_camera(li->begin(), li->end());
} else {
add_inner_cycle_to_camera(li->begin(), li->end());
}
for(li=polygon_list.begin(); li!=polygon_list.end(); ++li)
if(li==polygon_list.begin()) {
create_outer_cycles_opposites(li->begin(), li->end());
} else {
create_inner_cycles_opposites(li->begin(), li->end());
}
}
template<typename Forward_iterator>
void add_outer_cycle_to_camera(Forward_iterator begin, Forward_iterator end) {
SNC_constructor C(*sncp);
std::list<Sphere_point> spoints;
Forward_iterator si, si_prev, si_next;
for(si=begin;si!=end;++si) {
spoints.push_back(Sphere_point(*si-camera->point()));
}
C.add_outer_sedge_cycle(camera, spoints.begin(), spoints.end(),false);
}
template<typename Forward_iterator>
void create_outer_cycles_opposites(Forward_iterator begin, Forward_iterator end) {
SNC_constructor C(*sncp);
std::list<Sphere_point> spoints;
cut = find_cutoff_plane();
std::list<Point_3> points_on_plane;
Forward_iterator pi;
for(pi=begin;pi!=end;++pi) {
Ray_3 r(camera->point(), *pi-camera->point());
CGAL::Object io=CGAL::intersection(r,cut);
Point_3 ip;
assign(ip,io);
points_on_plane.push_back(ip);
}
typename std::list<Point_3>::iterator si,si_next,si_prev;
si_next = points_on_plane.begin();
si_prev = points_on_plane.end();
--si_prev;
for(si=points_on_plane.begin();si!=points_on_plane.end();++si) {
++si_next;
if(si_next==points_on_plane.end()) si_next=points_on_plane.begin();
spoints.clear();
spoints.push_back(*si_prev-*si);
spoints.push_back(*si_next-*si);
spoints.push_back(camera->point()-*si);
bool orient(CGAL::orientation(*si_prev,
*si,
*si_next,camera->point()) == CGAL::POSITIVE);
C.add_outer_sedge_cycle(sncp->new_vertex(*si),spoints.begin(), spoints.end(),orient);
++si_prev;
if(si_prev==points_on_plane.end()) si_prev=points_on_plane.begin();
}
}
template<typename Forward_iterator>
void add_inner_cycle_to_camera(Forward_iterator begin, Forward_iterator end) {
SNC_constructor C(*sncp);
std::list<Sphere_point> spoints;
Forward_iterator si, si_prev, si_next;
for(si=begin;si!=end;++si) {
spoints.push_back(Sphere_point(*si-camera->point()));
}
C.add_inner_sedge_cycle(camera, spoints.begin(), spoints.end(),false,true);
}
template<typename Forward_iterator>
void create_inner_cycles_opposites(Forward_iterator begin, Forward_iterator end) {
SNC_constructor C(*sncp);
std::list<Sphere_point> spoints;
std::list<Point_3> points_on_plane;
Forward_iterator pi;
for(pi=begin;pi!=end;++pi) {
Ray_3 r(camera->point(), *pi-camera->point());
CGAL::Object io=CGAL::intersection(r,cut);
Point_3 ip;
assign(ip,io);
points_on_plane.push_back(ip);
}
typename std::list<Point_3>::iterator si,si_next,si_prev;
si_next = points_on_plane.begin();
si_prev = points_on_plane.end();
--si_prev;
for(si=points_on_plane.begin();si!=points_on_plane.end();++si) {
++si_next;
if(si_next==points_on_plane.end()) si_next=points_on_plane.begin();
spoints.clear();
spoints.push_back(*si_prev-*si);
spoints.push_back(*si_next-*si);
spoints.push_back(camera->point()-*si);
bool orient(CGAL::orientation(*si_prev,
*si,
*si_next,camera->point()) == CGAL::NEGATIVE);
C.add_inner_sedge_cycle(sncp->new_vertex(*si),spoints.begin(), spoints.end(),orient,false);
++si_prev;
if(si_prev==points_on_plane.end()) si_prev=points_on_plane.begin();
}
}
};
CGAL_END_NAMESPACE
#endif // CGAL_NEF_VISUAL_HULL_CREATOR_H