cgal/Surface_mesh_topology/examples/Surface_mesh_topology/draw_facewidth.h

88 lines
2.7 KiB
C++

#ifndef DRAW_FACEWIDTH_H
#define DRAW_FACEWIDTH_H
#include <iostream>
#ifdef CGAL_USE_BASIC_VIEWER
#include <CGAL/draw_linear_cell_complex.h>
template<typename ALCC>
struct Facewidth_draw_functor : public CGAL::DefaultDrawingFunctorLCC
{
Facewidth_draw_functor(typename ALCC::size_type amark1, typename ALCC::size_type amark2) :
m_vertex_mark(amark1), m_face_mark(amark2)
{}
template<typename LCC>
bool colored_vertex(const LCC& alcc, typename LCC::Dart_const_descriptor dh) const
{ return alcc.is_marked(dh, m_vertex_mark); }
template<typename LCC>
CGAL::IO::Color vertex_color(const LCC& /* alcc */,
typename LCC::Dart_const_descriptor /* dh */) const
{ return CGAL::IO::Color(0, 255, 0); }
template<typename LCC>
bool colored_edge(const LCC& /*alcc*/, typename LCC::Dart_const_descriptor /*dh*/) const
{ return false; }
template<typename LCC>
CGAL::IO::Color edge_color(const LCC& /* alcc*/,
typename LCC::Dart_const_descriptor /* dh */) const
{ return CGAL::IO::Color(0, 0, 255); }
template<typename LCC>
bool colored_face(const LCC& /* alcc */,
typename LCC::Dart_const_descriptor /* dh */) const
{return true;}
template<typename LCC>
CGAL::IO::Color face_color(const LCC& alcc, typename LCC::Dart_const_descriptor dh) const
{ return alcc.is_marked(dh, m_face_mark)?CGAL::IO::Color(255, 0, 0)
:CGAL::IO::Color(211, 211, 211); }
template<typename LCC>
bool colored_volume(const LCC& /* alcc */,
typename LCC::Dart_const_descriptor /* dh */) const
{ return false; }
typename ALCC::size_type m_vertex_mark, m_face_mark;
};
template<typename LCC>
void draw_facewidth(const LCC& lcc,
const std::vector<typename LCC::Dart_const_descriptor>& cycle)
{
typename LCC::size_type vertex_mark = lcc.get_new_mark();
typename LCC::size_type face_mark = lcc.get_new_mark();
for (std::size_t i=0; i<cycle.size(); ++i)
{
// Color the vertex
if (!lcc.is_marked(cycle[i], vertex_mark))
{ lcc.template mark_cell<0>(cycle[i], vertex_mark); }
// Color the face
if (!lcc.is_marked(cycle[i], face_mark))
{ lcc.template mark_cell<2>(cycle[i], face_mark); }
}
Facewidth_draw_functor<LCC> df(vertex_mark, face_mark);
CGAL::draw(lcc, "Face width", false, df);
lcc.free_mark(vertex_mark);
lcc.free_mark(face_mark);
}
#else // CGAL_USE_BASIC_VIEWER
template<typename LCC>
void draw_facewidth(const LCC&,
const std::vector<typename LCC::Dart_const_descriptor>&)
{
std::cerr<<"Impossible to draw, CGAL_USE_BASIC_VIEWER is not defined."<<std::endl;
}
#endif // CGAL_USE_BASIC_VIEWER
#endif // DRAW_FACEWIDTH_H