##// END OF EJS Templates
Fix the cosinus bug....
Fix the cosinus bug. The provider now works on the variable controller thread instead of the main thread. That means the visu is still usable during zoom operation

File last commit:

r174:992eeb099247
r298:3a08c66e4df2
Show More
VisualizationController.cpp
48 lines | 1.4 KiB | text/x-c | CppLexer
/ core / src / Visualization / VisualizationController.cpp
Add the visualization controller
r53 #include <Visualization/VisualizationController.h>
Alexandre Leroux
Makes the connection between Variable controller and Visualization controller...
r170 #include <Variable/Variable.h>
Add the visualization controller
r53 #include <QMutex>
#include <QThread>
#include <QDir>
#include <QStandardPaths>
Q_LOGGING_CATEGORY(LOG_VisualizationController, "VisualizationController")
class VisualizationController::VisualizationControllerPrivate {
public:
QMutex m_WorkingMutex;
};
VisualizationController::VisualizationController(QObject *parent)
: impl{spimpl::make_unique_impl<VisualizationControllerPrivate>()}
{
Remove coverage from windows build...
r76 qCDebug(LOG_VisualizationController()) << tr("VisualizationController construction")
<< QThread::currentThread();
Add the visualization controller
r53 }
VisualizationController::~VisualizationController()
{
Remove coverage from windows build...
r76 qCDebug(LOG_VisualizationController()) << tr("VisualizationController destruction")
<< QThread::currentThread();
Add the visualization controller
r53 this->waitForFinish();
}
void VisualizationController::initialize()
{
Remove coverage from windows build...
r76 qCDebug(LOG_VisualizationController()) << tr("VisualizationController init")
<< QThread::currentThread();
Add the visualization controller
r53 impl->m_WorkingMutex.lock();
qCDebug(LOG_VisualizationController()) << tr("VisualizationController init END");
}
void VisualizationController::finalize()
{
impl->m_WorkingMutex.unlock();
}
void VisualizationController::waitForFinish()
{
QMutexLocker locker{&impl->m_WorkingMutex};
}