mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-09-14 20:33:05 +02:00
Added option to only move dynamic texts
This commit is contained in:
parent
8c3343795a
commit
78ee65a21b
@ -546,7 +546,15 @@ void DynamicElementTextItem::mousePressEvent(QGraphicsSceneMouseEvent *event)
|
|||||||
m_slave_Xref_item->setDefaultTextColor(Qt::black);
|
m_slave_Xref_item->setDefaultTextColor(Qt::black);
|
||||||
}
|
}
|
||||||
|
|
||||||
DiagramTextItem::mousePressEvent(event);
|
// Shift or no parent initiates movement of dynamic text, otherwise movement of parent element
|
||||||
|
if(event->modifiers() & Qt::ShiftModifier || !m_parent_element)
|
||||||
|
{
|
||||||
|
m_move_parent = false;
|
||||||
|
DiagramTextItem::mousePressEvent(event);
|
||||||
|
} else {
|
||||||
|
m_move_parent = true;
|
||||||
|
parentElement()->mousePressEvent(event);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -557,26 +565,31 @@ void DynamicElementTextItem::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
|||||||
{
|
{
|
||||||
if((event->buttons() & Qt::LeftButton) && (flags() & ItemIsMovable))
|
if((event->buttons() & Qt::LeftButton) && (flags() & ItemIsMovable))
|
||||||
{
|
{
|
||||||
if(diagram() && m_first_move)
|
if(m_move_parent)
|
||||||
diagram()->elementTextsMover().beginMovement(diagram(), this);
|
|
||||||
|
|
||||||
if(m_first_move)
|
|
||||||
{
|
{
|
||||||
m_initial_position = pos();
|
parentElement()->mouseMoveEvent(event);
|
||||||
if(parentElement())
|
} else {
|
||||||
parentElement()->setHighlighted(true);
|
if(diagram() && m_first_move)
|
||||||
|
diagram()->elementTextsMover().beginMovement(diagram(), this);
|
||||||
|
|
||||||
|
if(m_first_move)
|
||||||
|
{
|
||||||
|
m_initial_position = pos();
|
||||||
|
if(parentElement())
|
||||||
|
parentElement()->setHighlighted(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
QPointF current_parent_pos;
|
||||||
|
QPointF button_down_parent_pos;
|
||||||
|
current_parent_pos = mapToParent(mapFromScene(event->scenePos()));
|
||||||
|
button_down_parent_pos = mapToParent(mapFromScene(event->buttonDownScenePos(Qt::LeftButton)));
|
||||||
|
|
||||||
|
QPointF new_pos = m_initial_position + current_parent_pos - button_down_parent_pos;
|
||||||
|
event->modifiers() == Qt::ControlModifier ? setPos(new_pos) : setPos(Diagram::snapToGrid(new_pos));
|
||||||
|
|
||||||
|
if(diagram())
|
||||||
|
diagram()->elementTextsMover().continueMovement(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
QPointF current_parent_pos;
|
|
||||||
QPointF button_down_parent_pos;
|
|
||||||
current_parent_pos = mapToParent(mapFromScene(event->scenePos()));
|
|
||||||
button_down_parent_pos = mapToParent(mapFromScene(event->buttonDownScenePos(Qt::LeftButton)));
|
|
||||||
|
|
||||||
QPointF new_pos = m_initial_position + current_parent_pos - button_down_parent_pos;
|
|
||||||
event->modifiers() == Qt::ControlModifier ? setPos(new_pos) : setPos(Diagram::snapToGrid(new_pos));
|
|
||||||
|
|
||||||
if(diagram())
|
|
||||||
diagram()->elementTextsMover().continueMovement(event);
|
|
||||||
} else {
|
} else {
|
||||||
event->ignore();
|
event->ignore();
|
||||||
}
|
}
|
||||||
@ -591,14 +604,19 @@ void DynamicElementTextItem::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
|||||||
*/
|
*/
|
||||||
void DynamicElementTextItem::mouseReleaseEvent(QGraphicsSceneMouseEvent *event)
|
void DynamicElementTextItem::mouseReleaseEvent(QGraphicsSceneMouseEvent *event)
|
||||||
{
|
{
|
||||||
if (m_parent_element)
|
if(m_move_parent)
|
||||||
m_parent_element->setHighlighted(false);
|
{
|
||||||
|
parentElement()->mouseReleaseEvent(event);
|
||||||
|
} else {
|
||||||
|
if (m_parent_element)
|
||||||
|
m_parent_element->setHighlighted(false);
|
||||||
|
|
||||||
if(m_parent_element && m_parent_element->diagram())
|
if(m_parent_element && m_parent_element->diagram())
|
||||||
m_parent_element.data()->diagram()->elementTextsMover().endMovement();
|
m_parent_element.data()->diagram()->elementTextsMover().endMovement();
|
||||||
|
|
||||||
if(!(event->modifiers() & Qt::ControlModifier))
|
if(!(event->modifiers() & Qt::ControlModifier))
|
||||||
QGraphicsTextItem::mouseReleaseEvent(event);
|
QGraphicsTextItem::mouseReleaseEvent(event);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -170,6 +170,7 @@ class DynamicElementTextItem : public DiagramTextItem
|
|||||||
QPointF m_initial_position;
|
QPointF m_initial_position;
|
||||||
bool m_keep_visual_rotation = true;
|
bool m_keep_visual_rotation = true;
|
||||||
qreal m_visual_rotation_ref = 0;
|
qreal m_visual_rotation_ref = 0;
|
||||||
|
bool m_move_parent = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // DYNAMICELEMENTTEXTITEM_H
|
#endif // DYNAMICELEMENTTEXTITEM_H
|
||||||
|
@ -42,6 +42,7 @@ class ElementTextItemGroup;
|
|||||||
class Element : public QetGraphicsItem
|
class Element : public QetGraphicsItem
|
||||||
{
|
{
|
||||||
friend class DiagramEventAddElement;
|
friend class DiagramEventAddElement;
|
||||||
|
friend class DynamicElementTextItem;
|
||||||
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user