|
|
@ -17,7 +17,8 @@ GraphWidget::GraphWidget(QWidget *parent) :
|
|
|
|
m_showingNodeNumbers(false),
|
|
|
|
m_showingNodeNumbers(false),
|
|
|
|
m_hintNode(0),
|
|
|
|
m_hintNode(0),
|
|
|
|
m_editingNode(false),
|
|
|
|
m_editingNode(false),
|
|
|
|
m_edgeAdding(false)
|
|
|
|
m_edgeAdding(false),
|
|
|
|
|
|
|
|
m_edgeDeleting(false)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
m_scene = new QGraphicsScene(this);
|
|
|
|
m_scene = new QGraphicsScene(this);
|
|
|
|
m_scene->setItemIndexMethod(QGraphicsScene::NoIndex);
|
|
|
|
m_scene->setItemIndexMethod(QGraphicsScene::NoIndex);
|
|
|
@ -158,6 +159,13 @@ void GraphWidget::keyPressEvent(QKeyEvent *event)
|
|
|
|
tr("Edge adding cancelled"),
|
|
|
|
tr("Edge adding cancelled"),
|
|
|
|
5000); // millisec
|
|
|
|
5000); // millisec
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (m_edgeDeleting)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
m_edgeDeleting = false;
|
|
|
|
|
|
|
|
dynamic_cast<MainWindow *>(m_parent)->getStatusBar()->showMessage(
|
|
|
|
|
|
|
|
tr("Edge deleting cancelled"),
|
|
|
|
|
|
|
|
5000); // millisec
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(m_showingNodeNumbers)
|
|
|
|
else if(m_showingNodeNumbers)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
m_hintNumber.clear();
|
|
|
|
m_hintNumber.clear();
|
|
|
@ -284,6 +292,12 @@ void GraphWidget::keyPressEvent(QKeyEvent *event)
|
|
|
|
if (m_edgeAdding)
|
|
|
|
if (m_edgeAdding)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
m_scene->addItem(new Edge(m_activeNode, m_hintNode));
|
|
|
|
m_scene->addItem(new Edge(m_activeNode, m_hintNode));
|
|
|
|
|
|
|
|
m_edgeAdding = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m_edgeDeleting)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
m_activeNode->removeEdge(m_hintNode);
|
|
|
|
|
|
|
|
m_edgeDeleting = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else // selecting
|
|
|
|
else // selecting
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -344,7 +358,7 @@ void GraphWidget::keyPressEvent(QKeyEvent *event)
|
|
|
|
if (m_activeNode)
|
|
|
|
if (m_activeNode)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
dynamic_cast<MainWindow *>(m_parent)->getStatusBar()->showMessage(
|
|
|
|
dynamic_cast<MainWindow *>(m_parent)->getStatusBar()->showMessage(
|
|
|
|
tr("Add node: select destination node"),
|
|
|
|
tr("Add edge: select destination node"),
|
|
|
|
5000); // millisec
|
|
|
|
5000); // millisec
|
|
|
|
|
|
|
|
|
|
|
|
m_edgeAdding = true;
|
|
|
|
m_edgeAdding = true;
|
|
|
@ -358,6 +372,26 @@ void GraphWidget::keyPressEvent(QKeyEvent *event)
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// add edge to active node
|
|
|
|
|
|
|
|
case Qt::Key_D:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (m_activeNode)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
dynamic_cast<MainWindow *>(m_parent)->getStatusBar()->showMessage(
|
|
|
|
|
|
|
|
tr("Delete edge: select destination node"),
|
|
|
|
|
|
|
|
5000); // millisec
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
m_edgeDeleting = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
dynamic_cast<MainWindow *>(m_parent)->getStatusBar()->showMessage(
|
|
|
|
|
|
|
|
tr("No active node."),
|
|
|
|
|
|
|
|
5000); // millisec
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
QGraphicsView::keyPressEvent(event);
|
|
|
|
QGraphicsView::keyPressEvent(event);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -466,6 +500,11 @@ void GraphWidget::showingNodeNumbersBeginWithNumber(const int &number,
|
|
|
|
m_scene->addItem(new Edge(m_activeNode, m_hintNode));
|
|
|
|
m_scene->addItem(new Edge(m_activeNode, m_hintNode));
|
|
|
|
m_edgeAdding = false;
|
|
|
|
m_edgeAdding = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m_edgeDeleting)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
m_activeNode->removeEdge(m_hintNode);
|
|
|
|
|
|
|
|
m_edgeDeleting = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
else // selecting
|
|
|
|
else // selecting
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (m_activeNode)
|
|
|
|
if (m_activeNode)
|
|
|
@ -502,6 +541,11 @@ void GraphWidget::nodeSelected(Node *node)
|
|
|
|
m_scene->addItem(new Edge(m_activeNode, node));
|
|
|
|
m_scene->addItem(new Edge(m_activeNode, node));
|
|
|
|
m_edgeAdding = false;
|
|
|
|
m_edgeAdding = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m_edgeDeleting)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
m_activeNode->removeEdge(node);
|
|
|
|
|
|
|
|
m_edgeDeleting = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
setActiveNode(node);
|
|
|
|
setActiveNode(node);
|
|
|
|