dust3d/thirdparty/cgal/CGAL-5.1/include/CGAL/Qt/VoronoiGraphicsItem.h

125 lines
2.5 KiB
C
Raw Normal View History

// Copyright (c) 2008 GeometryFactory Sarl (France).
// All rights reserved.
//
// This file is part of CGAL (www.cgal.org).
//
2020-10-13 12:44:25 +00:00
// $URL: https://github.com/CGAL/cgal/blob/v5.1/GraphicsView/include/CGAL/Qt/VoronoiGraphicsItem.h $
// $Id: VoronoiGraphicsItem.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 <Andreas.Fabri@geometryfactory.com>
// Laurent Rineau <Laurent.Rineau@geometryfactory.com>
#ifndef CGAL_QT_VORONOI_GRAPHICS_ITEM_H
#define CGAL_QT_VORONOI_GRAPHICS_ITEM_H
#include <CGAL/license/GraphicsView.h>
#include <CGAL/Qt/GraphicsItem.h>
#include <CGAL/Qt/PainterOstream.h>
#include <CGAL/Qt/utility.h>
#include <QGraphicsScene>
#include <QGraphicsSceneMouseEvent>
#include <QPainter>
#include <QStyleOption>
#include <CGAL/intersection_2.h>
class QGraphicsSceneMouseEvent;
namespace CGAL {
namespace Qt {
template <typename DT>
class VoronoiGraphicsItem : public GraphicsItem
{
public:
VoronoiGraphicsItem(DT * dt_);
2020-10-13 12:44:25 +00:00
QRectF
boundingRect() const;
2020-10-13 12:44:25 +00:00
void
paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);
2020-10-13 12:44:25 +00:00
void
modelChanged();
const QPen& edgesPen() const
{
return edges_pen;
}
void setEdgesPen(const QPen& pen)
{
edges_pen = pen;
}
private:
DT * dt;
QPen edges_pen;
};
template <typename DT>
VoronoiGraphicsItem<DT>::VoronoiGraphicsItem(DT * dt_)
: dt(dt_)
{
setZValue(3);
}
template <typename DT>
2020-10-13 12:44:25 +00:00
QRectF
VoronoiGraphicsItem<DT>::boundingRect() const
{
QRectF rect = CGAL::Qt::viewportsBbox(scene());
return rect;
}
template <typename DT>
2020-10-13 12:44:25 +00:00
void
VoronoiGraphicsItem<DT>::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget * /*w*/)
{
QRectF rect = option->exposedRect;
PainterOstream<typename DT::Geom_traits> pos(painter, rect);
2020-10-13 12:44:25 +00:00
painter->setPen(edgesPen());
for(typename DT::Finite_edges_iterator eit = dt->finite_edges_begin();
eit != dt->finite_edges_end();
eit++){
CGAL::Object o = dt->dual(eit);
typename DT::Segment s;
typename DT::Geom_traits::Ray_2 r;
typename DT::Geom_traits::Line_2 l;
if(CGAL::assign(s,o)){
pos << s;
} else if(CGAL::assign(r,o)) {
pos << r;
}else if(CGAL::assign(l,o)) {
pos << l;
2020-10-13 12:44:25 +00:00
}
}
}
template <typename T>
2020-10-13 12:44:25 +00:00
void
VoronoiGraphicsItem<T>::modelChanged()
{
update();
}
} // namespace Qt
} // namespace CGAL
#endif // CGAL_QT_VORONOI_GRAPHICS_ITEM_H