// Copyright (c) 2008 GeometryFactory Sarl (France). // All rights reserved. // // This file is part of CGAL (www.cgal.org). // // $URL: https://github.com/CGAL/cgal/blob/v5.1/GraphicsView/include/CGAL/Qt/ConstrainedTriangulationGraphicsItem.h $ // $Id: ConstrainedTriangulationGraphicsItem.h 0779373 2020-03-26T13:31:46+01:00 Sébastien Loriot // SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-Commercial // // // Author(s) : Andreas Fabri // Laurent Rineau #ifndef CGAL_QT_CONSTRAINED_TRIANGULATION_GRAPHICS_ITEM_H #define CGAL_QT_CONSTRAINED_TRIANGULATION_GRAPHICS_ITEM_H #include #include #include namespace CGAL { namespace Qt { template class ConstrainedTriangulationGraphicsItem : public TriangulationGraphicsItem { typedef typename T::Geom_traits Geom_traits; public: ConstrainedTriangulationGraphicsItem(T * t_) : TriangulationGraphicsItem(t_), visible_constraints(true) { constraints_pen = this->edgesPen(); constraints_pen.setColor(::Qt::red); } void operator()(typename T::Face_handle fh); const QPen& constraintsPen() const { return constraints_pen; } QPen& constraintsPen() { return constraints_pen; } void setConstraintsPen(const QPen& pen) { constraints_pen = pen; } bool visibleConstraints() const { return visible_constraints; } void setVisibleConstraints(const bool b) { visible_constraints = b; this->update(); } protected: void drawAll(QPainter *painter); QPen constraints_pen; private: bool visible_constraints; }; template void ConstrainedTriangulationGraphicsItem::drawAll(QPainter *painter) { this->painterostream = PainterOstream(painter); for(typename T::Finite_edges_iterator eit = this->t->finite_edges_begin(); eit != this->t->finite_edges_end(); ++eit){ if(this->visibleConstraints() && this->t->is_constrained(*eit)){ painter->setPen(constraintsPen()); this->painterostream << this->t->segment(*eit); } else if( this->visibleEdges() ){ painter->setPen(this->edgesPen()); this->painterostream << this->t->segment(*eit); } } this->paintVertices(painter); } template void ConstrainedTriangulationGraphicsItem::operator()(typename T::Face_handle fh) { for (int i=0; i<3; i++) { if ( fh < fh->neighbor(i) || this->t->is_infinite(fh->neighbor(i)) ) { if(this->visibleConstraints() && this->t->is_constrained(typename T::Edge(fh,i))){ this->m_painter->setPen(constraintsPen()); this->painterostream << this->t->segment(fh,i); } else if( this->visibleEdges() ){ this->m_painter->setPen(this->edgesPen()); this->painterostream << this->t->segment(fh,i); } } if(this->visibleVertices()) { this->paintOneVertex(fh->vertex(i)->point()); } } } } // namespace Qt } // namespace CGAL #endif // CGAL_Q_CONSTRAINED_TRIANGULATION_GRAPHICS_ITEM_H