mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2024-11-15 10:08:34 +05:00
Implement Cancel Compute (begin)
This commit is contained in:
parent
5142df035d
commit
911977bc89
@ -85,6 +85,8 @@
|
|||||||
#include <QHBoxLayout>
|
#include <QHBoxLayout>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
#include <QButtonGroup>
|
#include <QButtonGroup>
|
||||||
|
#include <QCloseEvent>
|
||||||
|
#include <QTimerEvent>
|
||||||
|
|
||||||
// VTK includes
|
// VTK includes
|
||||||
#include <vtkProperty.h>
|
#include <vtkProperty.h>
|
||||||
@ -670,6 +672,87 @@ void SMESHGUI_BaseComputeOp::startOperation()
|
|||||||
SMESHGUI_Operation::startOperation();
|
SMESHGUI_Operation::startOperation();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
SMESHGUI_ComputeDlg_QThread::SMESHGUI_ComputeDlg_QThread(SMESH::SMESH_Gen_var gen,
|
||||||
|
SMESH::SMESH_Mesh_var mesh,
|
||||||
|
GEOM::GEOM_Object_var mainShape)
|
||||||
|
{
|
||||||
|
myResult = false;
|
||||||
|
myGen = gen;
|
||||||
|
myMesh = mesh;
|
||||||
|
myMainShape = mainShape;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SMESHGUI_ComputeDlg_QThread::run()
|
||||||
|
{
|
||||||
|
myResult = myGen->Compute(myMesh, myMainShape);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SMESHGUI_ComputeDlg_QThread::result()
|
||||||
|
{
|
||||||
|
return myResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SMESHGUI_ComputeDlg_QThread::cancel()
|
||||||
|
{
|
||||||
|
myGen->CancelCompute(myMesh, myMainShape);
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
SMESHGUI_ComputeDlg_QThreadQDialog::SMESHGUI_ComputeDlg_QThreadQDialog(QWidget *parent,
|
||||||
|
SMESH::SMESH_Gen_var gen,
|
||||||
|
SMESH::SMESH_Mesh_var mesh,
|
||||||
|
GEOM::GEOM_Object_var mainShape)
|
||||||
|
: QDialog(parent),
|
||||||
|
qthread(gen, mesh, mainShape)
|
||||||
|
{
|
||||||
|
// --
|
||||||
|
setWindowTitle(tr("Compute"));
|
||||||
|
cancelButton = new QPushButton(tr("Cancel"));
|
||||||
|
cancelButton->setDefault(true);
|
||||||
|
connect(cancelButton, SIGNAL(clicked()), this, SLOT(onCancel()));
|
||||||
|
QHBoxLayout *layout = new QHBoxLayout;
|
||||||
|
layout->addWidget(cancelButton);
|
||||||
|
setLayout(layout);
|
||||||
|
resize(200, 50);
|
||||||
|
// --
|
||||||
|
startTimer(30); // 30 millisecs
|
||||||
|
qthread.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SMESHGUI_ComputeDlg_QThreadQDialog::result()
|
||||||
|
{
|
||||||
|
return qthread.result();
|
||||||
|
}
|
||||||
|
|
||||||
|
void SMESHGUI_ComputeDlg_QThreadQDialog::onCancel()
|
||||||
|
{
|
||||||
|
qthread.cancel();
|
||||||
|
}
|
||||||
|
|
||||||
|
void SMESHGUI_ComputeDlg_QThreadQDialog::timerEvent(QTimerEvent *event)
|
||||||
|
{
|
||||||
|
if(qthread.isFinished())
|
||||||
|
{
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
event->accept();
|
||||||
|
}
|
||||||
|
|
||||||
|
void SMESHGUI_ComputeDlg_QThreadQDialog::closeEvent(QCloseEvent *event)
|
||||||
|
{
|
||||||
|
if(qthread.isRunning())
|
||||||
|
{
|
||||||
|
event->ignore();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
event->accept();
|
||||||
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief computeMesh()
|
* \brief computeMesh()
|
||||||
@ -711,7 +794,15 @@ void SMESHGUI_BaseComputeOp::computeMesh()
|
|||||||
OCC_CATCH_SIGNALS;
|
OCC_CATCH_SIGNALS;
|
||||||
#endif
|
#endif
|
||||||
//SMESH::UpdateNulData(myIObject, true);
|
//SMESH::UpdateNulData(myIObject, true);
|
||||||
if (gen->Compute(myMesh, myMainShape))
|
bool res;
|
||||||
|
#ifdef WITH_SMESH_CANCEL_COMPUTE
|
||||||
|
SMESHGUI_ComputeDlg_QThreadQDialog qthreaddialog(desktop(), gen, myMesh, myMainShape);
|
||||||
|
qthreaddialog.exec();
|
||||||
|
res = qthreaddialog.result();
|
||||||
|
#else
|
||||||
|
res = gen->Compute(myMesh, myMainShape);
|
||||||
|
#endif
|
||||||
|
if (res)
|
||||||
computeFailed = false;
|
computeFailed = false;
|
||||||
}
|
}
|
||||||
catch(const SALOME::SALOME_Exception & S_ex){
|
catch(const SALOME::SALOME_Exception & S_ex){
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include <QList>
|
#include <QList>
|
||||||
#include <QPointer>
|
#include <QPointer>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
|
#include <QThread>
|
||||||
|
|
||||||
// IDL includes
|
// IDL includes
|
||||||
#include <SALOMEconfig.h>
|
#include <SALOMEconfig.h>
|
||||||
@ -260,4 +261,57 @@ private:
|
|||||||
QtxComboBox* myPreviewMode;
|
QtxComboBox* myPreviewMode;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Thread to launch computation
|
||||||
|
*/
|
||||||
|
|
||||||
|
class SMESHGUI_EXPORT SMESHGUI_ComputeDlg_QThread : public QThread
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
SMESHGUI_ComputeDlg_QThread(SMESH::SMESH_Gen_var gen,
|
||||||
|
SMESH::SMESH_Mesh_var mesh,
|
||||||
|
GEOM::GEOM_Object_var mainShape);
|
||||||
|
bool result();
|
||||||
|
void cancel();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void run();
|
||||||
|
|
||||||
|
private:
|
||||||
|
SMESH::SMESH_Gen_var myGen;
|
||||||
|
SMESH::SMESH_Mesh_var myMesh;
|
||||||
|
GEOM::GEOM_Object_var myMainShape;
|
||||||
|
bool myResult;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Dialog to display Cancel button
|
||||||
|
*/
|
||||||
|
|
||||||
|
class SMESHGUI_EXPORT SMESHGUI_ComputeDlg_QThreadQDialog : public QDialog
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
SMESHGUI_ComputeDlg_QThreadQDialog(QWidget *parent,
|
||||||
|
SMESH::SMESH_Gen_var gen,
|
||||||
|
SMESH::SMESH_Mesh_var mesh,
|
||||||
|
GEOM::GEOM_Object_var mainShape);
|
||||||
|
bool result();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void timerEvent(QTimerEvent *timer);
|
||||||
|
void closeEvent(QCloseEvent *event);
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void onCancel();
|
||||||
|
|
||||||
|
private:
|
||||||
|
SMESHGUI_ComputeDlg_QThread qthread;
|
||||||
|
QPushButton *cancelButton;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
#endif // SMESHGUI_COMPUTEDLG_H
|
#endif // SMESHGUI_COMPUTEDLG_H
|
||||||
|
Loading…
Reference in New Issue
Block a user