VisionFlowPro/ShapeDrawer/ShapeItemRect1.cpp

85 lines
2.3 KiB
C++
Raw Permalink Normal View History

2023-02-28 14:50:28 +08:00
#include "ShapeItemRect1.h"
ShapeItemRect1::ShapeItemRect1(ShapeMode shape_mode) :
ShapeItemBase(EShapeType::sRectangle1Add)
{
m_shape_mode = shape_mode;
shapeInit();
}
ShapeItemRect1::~ShapeItemRect1()
{
}
void ShapeItemRect1::calculateShape()
{
if (this->sender() == nullptr)
{
sizeChanged();
}
else
{
activeHandle = dynamic_cast<ShapeControlItem*>(this->sender());
if (activeHandle->getType() == cCenter)
{
//this->moveBy(activeHandle->getDx(), activeHandle->getDy());
}
else if (activeHandle->getType() == cRotate)
{
}
else {
sizeChanged();
}
}
}
void ShapeItemRect1::shapeInit()
{
ControlList.append(new ShapeControlItem(this, ControlItemType::cCenter, QPointF(50, 50)));
ControlList.append(new ShapeControlItem(this, ControlItemType::cEdgeNode, QPointF(10, 10)));
ControlList.append(new ShapeControlItem(this, ControlItemType::cEdgeNode, QPointF(90, 10)));
ControlList.append(new ShapeControlItem(this, ControlItemType::cEdgeNode, QPointF(90, 90)));
ControlList.append(new ShapeControlItem(this, ControlItemType::cEdgeNode, QPointF(10, 90)));
itemPolygon.append(QPointF(ControlList[1]->x(), ControlList[1]->y()));
itemPolygon.append(QPointF(ControlList[2]->x(), ControlList[2]->y()));
itemPolygon.append(QPointF(ControlList[3]->x(), ControlList[3]->y()));
itemPolygon.append(QPointF(ControlList[4]->x(), ControlList[4]->y()));
ControlList[2]->setVisible(false);
ControlList[4]->setVisible(false);
for (auto elem : ControlList)
{
connect(elem, SIGNAL(PositionChanged()), this, SLOT(calculateShape()));
}
calculateShape();
}
void ShapeItemRect1::sizeChanged()
{
activeHandle = dynamic_cast<ShapeControlItem*>(this->sender());
ControlList[0]->setX(0.5 * (ControlList[1]->x() + ControlList[3]->x()));
ControlList[0]->setY(0.5 * (ControlList[1]->y() + ControlList[3]->y()));
ControlList[2]->setX(ControlList[3]->x());
ControlList[2]->setY(ControlList[1]->y());
ControlList[4]->setX(ControlList[1]->x());
ControlList[4]->setY(ControlList[3]->y());
itemPolygon[0] = ControlList[1]->getCenterPointF();
itemPolygon[1] = ControlList[2]->getCenterPointF();
itemPolygon[2] = ControlList[3]->getCenterPointF();
itemPolygon[3] = ControlList[4]->getCenterPointF();
ItemPath.clear();
ItemPath.addPolygon(itemPolygon);
ItemPath.closeSubpath();
ItemShape.clear();
ItemShape.addRect(ItemPath.boundingRect());
}