|
@@ -1,11 +1,13 @@
|
|
#include "ControlOperationPage.h"
|
|
#include "ControlOperationPage.h"
|
|
#include "ui_ControlOperationPage.h"
|
|
#include "ui_ControlOperationPage.h"
|
|
|
|
|
|
-ControlOperationPage::ControlOperationPage(QWidget *parent)
|
|
|
|
|
|
+ControlOperationPage::ControlOperationPage(QWidget* parent)
|
|
: QWidget(parent)
|
|
: QWidget(parent)
|
|
, ui(new Ui::ControlOperationPage)
|
|
, ui(new Ui::ControlOperationPage)
|
|
{
|
|
{
|
|
ui->setupUi(this);
|
|
ui->setupUi(this);
|
|
|
|
+
|
|
|
|
+ HideLayout(false);
|
|
}
|
|
}
|
|
|
|
|
|
ControlOperationPage::~ControlOperationPage()
|
|
ControlOperationPage::~ControlOperationPage()
|
|
@@ -13,20 +15,20 @@ ControlOperationPage::~ControlOperationPage()
|
|
delete ui;
|
|
delete ui;
|
|
}
|
|
}
|
|
|
|
|
|
-void ControlOperationPage::updateOperateWidget(const QPixmap& pixmap, const QStringList& textList){
|
|
|
|
|
|
+void ControlOperationPage::updateOperateWidget(const QPixmap& pixmap, const QStringList& textList) {
|
|
QSize size = ui->Operatewidget->size();
|
|
QSize size = ui->Operatewidget->size();
|
|
QPixmap scaledPixmap = pixmap.scaled(size, Qt::KeepAspectRatio, Qt::SmoothTransformation);
|
|
QPixmap scaledPixmap = pixmap.scaled(size, Qt::KeepAspectRatio, Qt::SmoothTransformation);
|
|
|
|
|
|
- clearLayout();
|
|
|
|
|
|
+ clearLayout();
|
|
|
|
|
|
- ui->Operatewidget->setPixmap(scaledPixmap);
|
|
|
|
- m_currentPixmap = scaledPixmap;
|
|
|
|
- m_scaleFactor = 1.0;
|
|
|
|
- m_previousScaleFactor = 1.0;
|
|
|
|
- ui->label_Percentage->setText("100%");
|
|
|
|
- ui->DataSources->clear();
|
|
|
|
- ui->DataSources->addItems(textList);
|
|
|
|
- m_currentMode = ModeImage;
|
|
|
|
|
|
+ ui->Operatewidget->setPixmap(scaledPixmap);
|
|
|
|
+ m_currentPixmap = scaledPixmap;
|
|
|
|
+ m_scaleFactor = 1.0;
|
|
|
|
+ m_previousScaleFactor = 1.0;
|
|
|
|
+ ui->label_Percentage->setText("100%");
|
|
|
|
+ ui->DataSources->clear();
|
|
|
|
+ ui->DataSources->addItems(textList);
|
|
|
|
+ m_currentMode = ModeImage;
|
|
|
|
|
|
}
|
|
}
|
|
// 清除大窗口上当前的布局
|
|
// 清除大窗口上当前的布局
|
|
@@ -34,7 +36,7 @@ void ControlOperationPage::clearLayout() {
|
|
// 获取当前布局
|
|
// 获取当前布局
|
|
QLayout* layout = ui->Operatewidget->layout();
|
|
QLayout* layout = ui->Operatewidget->layout();
|
|
if (layout) {
|
|
if (layout) {
|
|
- QLayoutItem *child;
|
|
|
|
|
|
+ QLayoutItem* child;
|
|
while ((child = layout->takeAt(0)) != nullptr) {
|
|
while ((child = layout->takeAt(0)) != nullptr) {
|
|
if (child->widget() != nullptr) {
|
|
if (child->widget() != nullptr) {
|
|
delete child->widget(); // 删除控件
|
|
delete child->widget(); // 删除控件
|
|
@@ -61,7 +63,8 @@ void ControlOperationPage::on_ZoomOutButton_clicked() {
|
|
void ControlOperationPage::updateScale(double newScaleFactor) {
|
|
void ControlOperationPage::updateScale(double newScaleFactor) {
|
|
if (newScaleFactor >= 1.0) {
|
|
if (newScaleFactor >= 1.0) {
|
|
m_scaleFactor = newScaleFactor;
|
|
m_scaleFactor = newScaleFactor;
|
|
- } else {
|
|
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
m_scaleFactor = 1.0; // 最小缩放比例为 1.0
|
|
m_scaleFactor = 1.0; // 最小缩放比例为 1.0
|
|
}
|
|
}
|
|
|
|
|
|
@@ -78,7 +81,8 @@ void ControlOperationPage::applyScale() {
|
|
QPixmap scaledImage = m_currentPixmap.scaled(newWidth, newHeight, Qt::KeepAspectRatio, Qt::SmoothTransformation);
|
|
QPixmap scaledImage = m_currentPixmap.scaled(newWidth, newHeight, Qt::KeepAspectRatio, Qt::SmoothTransformation);
|
|
ui->Operatewidget->setPixmapAndPoint(scaledImage, m_previousScaleFactor, m_scaleFactor, m_mousePos);
|
|
ui->Operatewidget->setPixmapAndPoint(scaledImage, m_previousScaleFactor, m_scaleFactor, m_mousePos);
|
|
m_previousScaleFactor = m_scaleFactor;
|
|
m_previousScaleFactor = m_scaleFactor;
|
|
- } else if (m_currentMode == ModeView && m_currentView) {
|
|
|
|
|
|
+ }
|
|
|
|
+ else if (m_currentMode == ModeView && m_currentView) {
|
|
// View 模式:缩放 view
|
|
// View 模式:缩放 view
|
|
QTransform transform;
|
|
QTransform transform;
|
|
transform.scale(m_scaleFactor, m_scaleFactor);
|
|
transform.scale(m_scaleFactor, m_scaleFactor);
|
|
@@ -91,11 +95,12 @@ void ControlOperationPage::applyScale() {
|
|
ui->label_Percentage->setText(QString("%1%").arg(percentageStr));
|
|
ui->label_Percentage->setText(QString("%1%").arg(percentageStr));
|
|
}
|
|
}
|
|
|
|
|
|
-void ControlOperationPage::handleDoubleClick(){
|
|
|
|
|
|
+void ControlOperationPage::handleDoubleClick() {
|
|
if (m_currentMode == ModeImage) {
|
|
if (m_currentMode == ModeImage) {
|
|
QPixmap scaledImage = m_currentPixmap.scaled(m_currentPixmap.width(), m_currentPixmap.height(), Qt::KeepAspectRatio, Qt::SmoothTransformation);
|
|
QPixmap scaledImage = m_currentPixmap.scaled(m_currentPixmap.width(), m_currentPixmap.height(), Qt::KeepAspectRatio, Qt::SmoothTransformation);
|
|
ui->Operatewidget->setPixmap(scaledImage); // 这里传递缩放后的图片
|
|
ui->Operatewidget->setPixmap(scaledImage); // 这里传递缩放后的图片
|
|
- } else if (m_currentMode == ModeView && m_currentView) {
|
|
|
|
|
|
+ }
|
|
|
|
+ else if (m_currentMode == ModeView && m_currentView) {
|
|
QTransform transform;
|
|
QTransform transform;
|
|
transform.scale(1, 1);
|
|
transform.scale(1, 1);
|
|
m_currentView->setTransform(transform);
|
|
m_currentView->setTransform(transform);
|
|
@@ -106,60 +111,62 @@ void ControlOperationPage::handleDoubleClick(){
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
-void ControlOperationPage::updateMaterialWidget( kinds materialWndType) {
|
|
|
|
-
|
|
|
|
- clearLayout();
|
|
|
|
-
|
|
|
|
- switch (materialWndType) {
|
|
|
|
- case wafer_kind: KindsofWidget(wafer_kind); break;
|
|
|
|
- case waffle_kind: KindsofWidget(waffle_kind); break;
|
|
|
|
- case materialbox_kind: KindsofWidget(materialbox_kind); break;
|
|
|
|
- case bond_kind:KindsofWidget(bond_kind);break;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
|
|
+void ControlOperationPage::updateMaterialWidget(kinds materialWndType)
|
|
|
|
+{
|
|
|
|
+ clearLayout();
|
|
|
|
+
|
|
|
|
+ switch (materialWndType)
|
|
|
|
+ {
|
|
|
|
+ case wafer_kind: KindsofWidget(wafer_kind); break;
|
|
|
|
+ case waffle_kind: KindsofWidget(waffle_kind); break;
|
|
|
|
+ case materialbox_kind: KindsofWidget(materialbox_kind); break;
|
|
|
|
+ case bond_kind:KindsofWidget(bond_kind); break;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
-void ControlOperationPage::KindsofWidget(kinds kind) {
|
|
|
|
-
|
|
|
|
-
|
|
|
|
- ui->Operatewidget->clearPixmap();
|
|
|
|
- QVBoxLayout *layout = new QVBoxLayout(ui->Operatewidget);
|
|
|
|
- layout->setContentsMargins(0, 0, 0, 0);
|
|
|
|
- m_currentMode = ModeView;
|
|
|
|
- if(kind == wafer_kind){
|
|
|
|
- m_wafer->initFrom(ui->Operatewidget);
|
|
|
|
- layout->addWidget(m_wafer->view);
|
|
|
|
- m_currentView = m_wafer->view;
|
|
|
|
- }else if(kind == waffle_kind){
|
|
|
|
- m_waffle->initFrom(ui->Operatewidget);
|
|
|
|
- layout->addWidget(m_waffle->view);
|
|
|
|
- m_currentView = m_waffle->view;
|
|
|
|
- }else if(kind == materialbox_kind){
|
|
|
|
- m_materialbox->initFrom(ui->Operatewidget);
|
|
|
|
- layout->addWidget(m_materialbox->view);
|
|
|
|
- m_currentView = m_materialbox->view;
|
|
|
|
- }else{
|
|
|
|
-
|
|
|
|
- }
|
|
|
|
|
|
+void ControlOperationPage::KindsofWidget(kinds kind)
|
|
|
|
+{
|
|
|
|
+ ui->Operatewidget->clearPixmap();
|
|
|
|
+ QVBoxLayout* layout = new QVBoxLayout(ui->Operatewidget);
|
|
|
|
+ layout->setContentsMargins(0, 0, 0, 0);
|
|
|
|
+ m_currentMode = ModeView;
|
|
|
|
+ if (kind == wafer_kind)
|
|
|
|
+ {
|
|
|
|
+ m_wafer->initFrom(ui->Operatewidget);
|
|
|
|
+ layout->addWidget(m_wafer->view);
|
|
|
|
+ m_currentView = m_wafer->view;
|
|
|
|
+ }
|
|
|
|
+ else if (kind == waffle_kind)
|
|
|
|
+ {
|
|
|
|
+ m_waffle->initFrom(ui->Operatewidget);
|
|
|
|
+ layout->addWidget(m_waffle->view);
|
|
|
|
+ m_currentView = m_waffle->view;
|
|
|
|
+ }
|
|
|
|
+ else if (kind == materialbox_kind)
|
|
|
|
+ {
|
|
|
|
+ m_materialbox->initFrom(ui->Operatewidget);
|
|
|
|
+ layout->addWidget(m_materialbox->view);
|
|
|
|
+ m_currentView = m_materialbox->view;
|
|
|
|
+ }
|
|
|
|
|
|
- ui->Operatewidget->setLayout(layout);
|
|
|
|
- m_currentMode = ModeView;
|
|
|
|
|
|
+ ui->Operatewidget->setLayout(layout);
|
|
|
|
+ m_currentMode = ModeView;
|
|
|
|
|
|
- m_scaleFactor = 1.0;
|
|
|
|
- applyScale();
|
|
|
|
|
|
+ m_scaleFactor = 1.0;
|
|
|
|
+ applyScale();
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
-void ControlOperationPage::setWafer(Wafer *wafer){
|
|
|
|
|
|
+void ControlOperationPage::setWafer(Wafer* wafer) {
|
|
m_wafer = wafer;
|
|
m_wafer = wafer;
|
|
updateMaterialWidget(wafer_kind);
|
|
updateMaterialWidget(wafer_kind);
|
|
-
|
|
|
|
|
|
+
|
|
}
|
|
}
|
|
-void ControlOperationPage::setWaffle(Waffle *waffle){
|
|
|
|
|
|
+void ControlOperationPage::setWaffle(Waffle* waffle) {
|
|
m_waffle = waffle;
|
|
m_waffle = waffle;
|
|
updateMaterialWidget(waffle_kind);
|
|
updateMaterialWidget(waffle_kind);
|
|
}
|
|
}
|
|
-void ControlOperationPage::setMaterialBox(MaterialBox *materialbox){
|
|
|
|
|
|
+void ControlOperationPage::setMaterialBox(MaterialBox* materialbox) {
|
|
m_materialbox = materialbox;
|
|
m_materialbox = materialbox;
|
|
updateMaterialWidget(materialbox_kind);
|
|
updateMaterialWidget(materialbox_kind);
|
|
}
|
|
}
|
|
@@ -167,11 +174,25 @@ void ControlOperationPage::setMaterialBox(MaterialBox *materialbox){
|
|
// m_bond = bond;
|
|
// m_bond = bond;
|
|
//}
|
|
//}
|
|
|
|
|
|
-void ControlOperationPage::initForm() {
|
|
|
|
|
|
+void ControlOperationPage::initForm()
|
|
|
|
+{
|
|
|
|
+ {
|
|
|
|
+ // 后面在做
|
|
|
|
+ //if (m_pMainCameraBind != nullptr)
|
|
|
|
+ //{
|
|
|
|
+ // DeduplicationBox(ui->axisComboBox, m_pMainCameraBind->m_vecCAxis, 0);
|
|
|
|
+ // DeduplicationBox(ui->axisTypeComboBox, m_pMainCameraBind->m_vecCAxis, 1);
|
|
|
|
+ //}
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
connect(ui->Operatewidget, &ImageWidget::sendDoubleClicksignal, this, &ControlOperationPage::handleDoubleClick);
|
|
connect(ui->Operatewidget, &ImageWidget::sendDoubleClicksignal, this, &ControlOperationPage::handleDoubleClick);
|
|
ui->Operatewidget->setMouseTracking(true);
|
|
ui->Operatewidget->setMouseTracking(true);
|
|
}
|
|
}
|
|
-ImageWidget* ControlOperationPage::getOperatewidget() {
|
|
|
|
|
|
+
|
|
|
|
+ImageWidget* ControlOperationPage::getOperatewidget()
|
|
|
|
+{
|
|
return ui->Operatewidget;
|
|
return ui->Operatewidget;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -197,4 +218,94 @@ void ControlOperationPage::resizeSingleUI() {
|
|
|
|
|
|
void ControlOperationPage::resizeChartsAndCamerasUI() {
|
|
void ControlOperationPage::resizeChartsAndCamerasUI() {
|
|
|
|
|
|
-}
|
|
|
|
|
|
+}
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void ControlOperationPage::on_switchJoystickBut_clicked()
|
|
|
|
+{
|
|
|
|
+ ResetIdleTimer(true);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void ControlOperationPage::timerEvent(QTimerEvent* event)
|
|
|
|
+{
|
|
|
|
+ int nID = event->timerId();
|
|
|
|
+ if (nID == m_idleTimer)
|
|
|
|
+ {
|
|
|
|
+ ResetIdleTimer(false);
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void ControlOperationPage::HideLayout(bool bShow)
|
|
|
|
+{
|
|
|
|
+ for (int i = 0; i < ui->horizontalLayout->count(); ++i)
|
|
|
|
+ {
|
|
|
|
+ QWidget* widget = ui->horizontalLayout->itemAt(i)->widget();
|
|
|
|
+ if (widget)
|
|
|
|
+ {
|
|
|
|
+ if (bShow)
|
|
|
|
+ {
|
|
|
|
+ widget->show();
|
|
|
|
+ }
|
|
|
|
+ else
|
|
|
|
+ {
|
|
|
|
+ widget->hide();
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void ControlOperationPage::ResetIdleTimer(bool bStart /*= false*/)
|
|
|
|
+{
|
|
|
|
+ if (bStart)
|
|
|
|
+ {
|
|
|
|
+ if (isActiveWindow())
|
|
|
|
+ {
|
|
|
|
+ m_idleTimer = startTimer(3000);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else
|
|
|
|
+ {
|
|
|
|
+ killTimer(m_idleTimer);
|
|
|
|
+ m_idleTimer = -1;
|
|
|
|
+ }
|
|
|
|
+ HideLayout(bStart);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+template<class T>
|
|
|
|
+void ControlOperationPage::DeduplicationBox(QComboBox* pCom, const T& veTemp, int nIndex)
|
|
|
|
+{
|
|
|
|
+ QStringList items;
|
|
|
|
+ for (int i = 0; i < pCom->count(); ++i)
|
|
|
|
+ {
|
|
|
|
+ items << pCom->itemText(i);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for (auto& a : veTemp)
|
|
|
|
+ {
|
|
|
|
+ QString strName;
|
|
|
|
+ if (nIndex == 0)
|
|
|
|
+ {
|
|
|
|
+ strName = a->GetModuleType().c_str();
|
|
|
|
+ }
|
|
|
|
+ else if (nIndex == 1)
|
|
|
|
+ {
|
|
|
|
+ strName = a->GetStringAxisType().c_str();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ bool bMa = false; // 是否匹配
|
|
|
|
+ for (auto b : items)
|
|
|
|
+ {
|
|
|
|
+ if (b == strName)
|
|
|
|
+ {
|
|
|
|
+ bMa = true;
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (!bMa)
|
|
|
|
+ {
|
|
|
|
+ pCom->addItem(strName);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|