mirror of https://github.com/CGAL/cgal
Add (buggy) IO for circular arcs
This commit is contained in:
parent
f1b56f9a11
commit
15ad06b081
|
|
@ -0,0 +1,156 @@
|
|||
// Copyright (c) 2008 GeometryFactory Sarl (France).
|
||||
// All rights reserved.
|
||||
//
|
||||
// This file is part of CGAL (www.cgal.org); you may redistribute it under
|
||||
// the terms of the Q Public License version 1.0.
|
||||
// See the file LICENSE.QPL distributed with CGAL.
|
||||
//
|
||||
// Licensees holding a valid commercial license may use this file in
|
||||
// accordance with the commercial license agreement provided with the software.
|
||||
//
|
||||
// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
|
||||
// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
||||
//
|
||||
// $URL$
|
||||
// $Id$
|
||||
//
|
||||
//
|
||||
// Author(s) : Andreas Fabri <Andreas.Fabri@geometryfactory.com>
|
||||
// Laurent Rineau <Laurent.Rineau@geometryfactory.com>
|
||||
|
||||
#ifndef CGAL_QT_CIRCULAR_ARC_GRAPHICS_ITEM_H
|
||||
#define CGAL_QT_CIRCULAR_ARC_GRAPHICS_ITEM_H
|
||||
|
||||
#include <CGAL/Bbox_2.h>
|
||||
#include <CGAL/Qt/PainterOstream.h>
|
||||
#include <CGAL/Qt/GraphicsItem.h>
|
||||
#include <CGAL/Qt/Converter.h>
|
||||
|
||||
#include <QGraphicsScene>
|
||||
#include <QPainter>
|
||||
#include <QStyleOption>
|
||||
|
||||
namespace CGAL {
|
||||
namespace Qt {
|
||||
|
||||
template <typename CK>
|
||||
class CircularArcGraphicsItem : public GraphicsItem
|
||||
{
|
||||
typedef typename CK::Point_2 Point_2;
|
||||
typedef typename CK::Circle_2 Circle_2;
|
||||
typedef typename CK::Circular_arc_2 Circular_arc_2;
|
||||
|
||||
public:
|
||||
CircularArcGraphicsItem();
|
||||
|
||||
void modelChanged();
|
||||
|
||||
public:
|
||||
QRectF boundingRect() const;
|
||||
|
||||
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);
|
||||
|
||||
|
||||
const QPen& verticesPen() const
|
||||
{
|
||||
return vertices_pen;
|
||||
}
|
||||
|
||||
const QPen& edgesPen() const
|
||||
{
|
||||
return edges_pen;
|
||||
}
|
||||
|
||||
void setVerticesPen(const QPen& pen)
|
||||
{
|
||||
vertices_pen = pen;
|
||||
}
|
||||
|
||||
void setEdgesPen(const QPen& pen)
|
||||
{
|
||||
edges_pen = pen;
|
||||
}
|
||||
|
||||
void setArc(const Circular_arc_2& a);
|
||||
|
||||
protected:
|
||||
void updateBoundingBox();
|
||||
|
||||
QPainter* m_painter;
|
||||
PainterOstream<CK> painterostream;
|
||||
|
||||
QRectF bounding_rect;
|
||||
|
||||
QPen edges_pen;
|
||||
|
||||
Circular_arc_2 arc;
|
||||
};
|
||||
|
||||
|
||||
template <typename CK>
|
||||
void
|
||||
CircularArcGraphicsItem<CK>::setArc(const Circular_arc_2& a)
|
||||
{
|
||||
arc = a;
|
||||
updateBoundingBox();
|
||||
update();
|
||||
}
|
||||
|
||||
template <typename CK>
|
||||
CircularArcGraphicsItem<CK>::CircularArcGraphicsItem()
|
||||
: painterostream(0)
|
||||
{
|
||||
this->hide();
|
||||
setZValue(3);
|
||||
}
|
||||
|
||||
template <typename CK>
|
||||
QRectF
|
||||
CircularArcGraphicsItem<CK>::boundingRect() const
|
||||
{
|
||||
return QRectF(-500,-500,1000,1000);
|
||||
Converter<CK> convert;
|
||||
return convert(arc.bbox());
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
template <typename CK>
|
||||
void
|
||||
CircularArcGraphicsItem<CK>::paint(QPainter *painter,
|
||||
const QStyleOptionGraphicsItem *option,
|
||||
QWidget * widget)
|
||||
{
|
||||
std::cout << "CircularArcGraphicsItem<CK>::paint" << std::endl;
|
||||
painter->setPen(this->edgesPen());
|
||||
painterostream = PainterOstream<CK>(painter);
|
||||
|
||||
painterostream << arc;
|
||||
}
|
||||
|
||||
// We let the bounding box only grow, so that when vertices get removed
|
||||
// the maximal bbox gets refreshed in the GraphicsView
|
||||
template <typename CK>
|
||||
void
|
||||
CircularArcGraphicsItem<CK>::updateBoundingBox()
|
||||
{
|
||||
Converter<CK> convert;
|
||||
prepareGeometryChange();
|
||||
bounding_rect = convert(arc.bbox());
|
||||
}
|
||||
|
||||
|
||||
template <typename CK>
|
||||
void
|
||||
CircularArcGraphicsItem<CK>::modelChanged()
|
||||
{
|
||||
updateBoundingBox();
|
||||
update();
|
||||
}
|
||||
|
||||
|
||||
} // namespace Qt
|
||||
} // namespace CGAL
|
||||
|
||||
#endif // CGAL_QT_CIRCULAR_ARC_GRAPHICS_ITEM_H
|
||||
|
|
@ -37,7 +37,7 @@
|
|||
#include <CGAL/array.h>
|
||||
|
||||
namespace CGAL {
|
||||
namespac Qt {
|
||||
namespace Qt {
|
||||
|
||||
template <typename K>
|
||||
class GraphicsViewCircleInput : public GraphicsViewInput
|
||||
|
|
@ -199,6 +199,8 @@ GraphicsViewCircleInput<K>::eventFilter(QObject *obj, QEvent *event)
|
|||
}
|
||||
}
|
||||
|
||||
} // namespace Qt
|
||||
|
||||
} // namespace CGAL
|
||||
|
||||
#endif // CGAL_QT_GRAPHICS_VIEW_CIRCLE_INPUT_H
|
||||
|
|
|
|||
|
|
@ -0,0 +1,180 @@
|
|||
// Copyright (c) 2008 GeometryFactory Sarl (France).
|
||||
// All rights reserved.
|
||||
//
|
||||
// This file is part of CGAL (www.cgal.org); you may redistribute it under
|
||||
// the terms of the Q Public License version 1.0.
|
||||
// See the file LICENSE.QPL distributed with CGAL.
|
||||
//
|
||||
// Licensees holding a valid commercial license may use this file in
|
||||
// accordance with the commercial license agreement provided with the software.
|
||||
//
|
||||
// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
|
||||
// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
||||
//
|
||||
// $URL$
|
||||
// $Id$
|
||||
//
|
||||
//
|
||||
// Author(s) : Andreas Fabri <Andreas.Fabri@geometryfactory.com>
|
||||
// Laurent Rineau <Laurent.Rineau@geometryfactory.com>
|
||||
|
||||
#ifndef CGAL_QT_GRAPHICS_VIEW_CIRCULAR_ARC_INPUT_H
|
||||
#define CGAL_QT_GRAPHICS_VIEW_CIRCULAR_ARC_INPUT_H
|
||||
|
||||
#include <QGraphicsView>
|
||||
#include <QRectF>
|
||||
#include <QPointF>
|
||||
#include <QGraphicsItem>
|
||||
#include <QGraphicsEllipseItem>
|
||||
#include <QGraphicsLineItem>
|
||||
#include <QGraphicsScene>
|
||||
#include <QGraphicsSceneMouseEvent>
|
||||
#include <QPainter>
|
||||
#include <QStyleOption>
|
||||
|
||||
#include <CGAL/Qt/Converter.h>
|
||||
#include <CGAL/Qt/GraphicsViewInput.h>
|
||||
#include <CGAL/Qt/CircularArcGraphicsItem.h>
|
||||
|
||||
#include <CGAL/array.h>
|
||||
|
||||
namespace CGAL {
|
||||
namespace Qt {
|
||||
|
||||
template <typename K>
|
||||
class GraphicsViewCircularArcInput : public GraphicsViewInput
|
||||
{
|
||||
public:
|
||||
GraphicsViewCircularArcInput(QObject *parent, QGraphicsScene* s);
|
||||
|
||||
protected:
|
||||
|
||||
virtual void mousePressEvent(QGraphicsSceneMouseEvent *event);
|
||||
virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *event);
|
||||
virtual void keyPressEvent(QKeyEvent *event);
|
||||
|
||||
bool eventFilter(QObject *obj, QEvent *event);
|
||||
|
||||
|
||||
|
||||
|
||||
private:
|
||||
typedef typename K::Circular_arc_2 Circular_arc_2;
|
||||
typedef typename K::Point_2 Point_2;
|
||||
int count;
|
||||
QGraphicsLineItem *qline;
|
||||
CircularArcGraphicsItem<K> *qcarc;
|
||||
QPointF qp, qq, qr;
|
||||
Point_2 p, q, r;
|
||||
QGraphicsScene *scene_;
|
||||
Converter<K> convert;
|
||||
};
|
||||
|
||||
|
||||
template <typename K>
|
||||
GraphicsViewCircularArcInput<K>::GraphicsViewCircularArcInput(QObject *parent, QGraphicsScene* s)
|
||||
: GraphicsViewInput(parent), qline(new QGraphicsLineItem()), qcarc(new CircularArcGraphicsItem<K>()), scene_(s), count(0)
|
||||
{
|
||||
qline->hide();
|
||||
qcarc->hide();
|
||||
s->addItem(qline);
|
||||
s->addItem(qcarc);
|
||||
}
|
||||
|
||||
|
||||
template <typename K>
|
||||
void
|
||||
GraphicsViewCircularArcInput<K>::mousePressEvent(QGraphicsSceneMouseEvent *event)
|
||||
{
|
||||
if(count == 0){
|
||||
qp = event->scenePos();
|
||||
p = convert(qp);
|
||||
qline->setLine(QLineF(qp, qp));
|
||||
qline->show();
|
||||
count = 1;
|
||||
} else if(count == 1){
|
||||
qq = event->scenePos();
|
||||
qline->setLine(QLineF(qp, qq));
|
||||
q = convert(qq);
|
||||
count = 2;
|
||||
} else if(count == 2){
|
||||
qr = event->scenePos();
|
||||
r = convert(qr);
|
||||
typename K::Collinear_2 collinear;
|
||||
if(! collinear(p,q,r)){
|
||||
qcarc->hide();
|
||||
emit generate(CGAL::make_object(Circular_arc_2(p,q,r)));
|
||||
count = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
template <typename K>
|
||||
void
|
||||
GraphicsViewCircularArcInput<K>::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
||||
{
|
||||
if(count == 0){
|
||||
qcarc->hide();
|
||||
qline->hide();
|
||||
return;
|
||||
} else if(count == 1) {
|
||||
qq = event->scenePos();
|
||||
q = convert(qq);
|
||||
qline->setLine(QLineF(qp, qq));
|
||||
} else if(count == 2){
|
||||
qline->hide();
|
||||
qr = event->scenePos();
|
||||
r = convert(qr);
|
||||
typename K::Collinear_2 collinear;
|
||||
if(collinear(p,q,r)){
|
||||
qcarc->hide();
|
||||
return;
|
||||
} else {
|
||||
if(CGAL::orientation(p, q, r) != CGAL::COUNTERCLOCKWISE) std::swap(p, r);
|
||||
qcarc->setArc(Circular_arc_2(p,q,r));
|
||||
qcarc->show();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
template <typename K>
|
||||
void
|
||||
GraphicsViewCircularArcInput<K>::keyPressEvent ( QKeyEvent * event )
|
||||
{
|
||||
if(event->key() == ::Qt::Key_Delete){
|
||||
if(count>0){
|
||||
--count;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
template <typename K>
|
||||
bool
|
||||
GraphicsViewCircularArcInput<K>::eventFilter(QObject *obj, QEvent *event)
|
||||
{
|
||||
if (event->type() == QEvent::GraphicsSceneMousePress) {
|
||||
QGraphicsSceneMouseEvent *mouseEvent = static_cast<QGraphicsSceneMouseEvent *>(event);
|
||||
mousePressEvent(mouseEvent);
|
||||
return true;
|
||||
} else if (event->type() == QEvent::GraphicsSceneMouseMove) {
|
||||
QGraphicsSceneMouseEvent *mouseEvent = static_cast<QGraphicsSceneMouseEvent *>(event);
|
||||
mouseMoveEvent(mouseEvent);
|
||||
return true;
|
||||
} else if (event->type() == QEvent::KeyPress) {
|
||||
QKeyEvent *keyEvent = static_cast<QKeyEvent *>(event);
|
||||
keyPressEvent(keyEvent);
|
||||
return true;
|
||||
} else{
|
||||
// standard event processing
|
||||
return QObject::eventFilter(obj, event);
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace Qt
|
||||
} // namespace CGAL
|
||||
|
||||
#endif // CGAL_QT_GRAPHICS_VIEW_CIRCULAR_ARC_INPUT_H
|
||||
|
|
@ -82,9 +82,42 @@ public:
|
|||
|
||||
PainterOstream& operator<<(const Circle_2<K>& c)
|
||||
{
|
||||
qp->drawRect(convert(c.bbox()));
|
||||
qp->drawEllipse(convert(c.bbox()));
|
||||
return *this;
|
||||
}
|
||||
|
||||
PainterOstream& operator<<(const Circular_arc_2<K>& arc)
|
||||
{
|
||||
const typename K::Circle_2 & circ = arc.supporting_circle();
|
||||
const typename K::Point_2 & center = circ.center();
|
||||
const typename K::Circular_arc_point_2 & source = arc.source();
|
||||
const typename K::Circular_arc_point_2 & target = arc.target();
|
||||
double radius = std::sqrt(CGAL::to_double(circ.squared_radius()));
|
||||
|
||||
|
||||
double a = std::atan2( to_double(source.y() - center.y()),
|
||||
to_double(source.x() - center.x()));
|
||||
double a2p = std::atan2( to_double(target.y() - center.y()),
|
||||
to_double(target.x() - center.x()));
|
||||
|
||||
std::cout << "a = " << a << " a2p = " << a2p << std::endl;
|
||||
if (a2p <= a)
|
||||
a2p += 2 * CGAL_PI;
|
||||
|
||||
double alen2 = a - a2p;
|
||||
|
||||
double diff = 180/CGAL_PI*16;
|
||||
|
||||
std::cout << "start " << (int)(a * diff) << std::endl;
|
||||
std::cout << "angle " << (int)(alen2 * diff) << std::endl;
|
||||
|
||||
// qp->drawEllipse(convert(circ.bbox()));
|
||||
qp->drawArc(convert(circ.bbox()),
|
||||
(int)(a * diff),
|
||||
(int)(alen2 * diff));
|
||||
return *this;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
} // namespace Qt
|
||||
|
|
|
|||
Loading…
Reference in New Issue