better handling of multiple sensors in the GUI
parent
527951b7bd
commit
bb7e922511
|
@ -934,7 +934,7 @@ void MainWindow::on_tabBar_currentChanged(int index) {
|
||||||
m_statusMessage = "";
|
m_statusMessage = "";
|
||||||
updateStatus();
|
updateStatus();
|
||||||
updateUI();
|
updateUI();
|
||||||
ui->menuCamera->clear();
|
updateCameraMenu();
|
||||||
|
|
||||||
if (index != -1) {
|
if (index != -1) {
|
||||||
SceneContext *context = m_context[index];
|
SceneContext *context = m_context[index];
|
||||||
|
@ -958,28 +958,41 @@ void MainWindow::on_tabBar_currentChanged(int index) {
|
||||||
|
|
||||||
m_lastTab = context;
|
m_lastTab = context;
|
||||||
|
|
||||||
const Scene *scene = context->scene;
|
|
||||||
if (scene) {
|
|
||||||
const ref_vector<Sensor> &sensors = scene->getSensors();
|
|
||||||
for (size_t i = 0; i < sensors.size(); ++i) {
|
|
||||||
const Sensor *sensor = sensors[i].get();
|
|
||||||
const Properties &props = sensor->getProperties();
|
|
||||||
QAction *act = new QAction(ui->menuCamera);
|
|
||||||
act->setText(formatString("\"%s\" (%s)",
|
|
||||||
props.getID().c_str(), props.getPluginName().c_str()).c_str());
|
|
||||||
act->setData(qVariantFromValue((void *) sensor));
|
|
||||||
ui->menuCamera->addAction(act);
|
|
||||||
connect(act, SIGNAL(triggered()), this, SLOT(onActivateCamera()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
adjustSize();
|
adjustSize();
|
||||||
m_lastTab = NULL;
|
m_lastTab = NULL;
|
||||||
ui->menuCamera->clear();
|
|
||||||
}
|
}
|
||||||
ui->glView->setFocus();
|
ui->glView->setFocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::updateCameraMenu() {
|
||||||
|
ui->menuCamera->clear();
|
||||||
|
int currentIndex = ui->tabBar->currentIndex();
|
||||||
|
if (currentIndex < 0)
|
||||||
|
return;
|
||||||
|
SceneContext *context = m_context[currentIndex];
|
||||||
|
const Scene *scene = context->scene;
|
||||||
|
if (!scene)
|
||||||
|
return;
|
||||||
|
|
||||||
|
bool isRendering = context->renderJob != NULL;
|
||||||
|
|
||||||
|
const ref_vector<Sensor> &sensors = scene->getSensors();
|
||||||
|
for (size_t i = 0; i < sensors.size(); ++i) {
|
||||||
|
const Sensor *sensor = sensors[i].get();
|
||||||
|
const Properties &props = sensor->getProperties();
|
||||||
|
QAction *act = new QAction(ui->menuCamera);
|
||||||
|
act->setCheckable(true);
|
||||||
|
act->setChecked(sensor == scene->getSensor());
|
||||||
|
act->setEnabled(!isRendering);
|
||||||
|
act->setText(formatString("\"%s\" (%s)",
|
||||||
|
props.getID().c_str(), props.getPluginName().c_str()).c_str());
|
||||||
|
act->setData(qVariantFromValue((void *) sensor));
|
||||||
|
ui->menuCamera->addAction(act);
|
||||||
|
connect(act, SIGNAL(triggered()), this, SLOT(onActivateCamera()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MainWindow::on_actionClose_triggered() {
|
void MainWindow::on_actionClose_triggered() {
|
||||||
int index = ui->tabBar->currentIndex();
|
int index = ui->tabBar->currentIndex();
|
||||||
if (m_contextIndex != -1)
|
if (m_contextIndex != -1)
|
||||||
|
@ -1451,6 +1464,7 @@ void MainWindow::on_actionRender_triggered() {
|
||||||
context->mode = ERender;
|
context->mode = ERender;
|
||||||
m_statusMessage = "";
|
m_statusMessage = "";
|
||||||
updateUI();
|
updateUI();
|
||||||
|
updateCameraMenu();
|
||||||
context->sizeIncrease = QSize(0, m_progressWidget->sizeHint().height());
|
context->sizeIncrease = QSize(0, m_progressWidget->sizeHint().height());
|
||||||
|
|
||||||
#if defined(__LINUX__)
|
#if defined(__LINUX__)
|
||||||
|
@ -1732,6 +1746,7 @@ void MainWindow::onJobFinished(const RenderJob *job, bool cancelled) {
|
||||||
refresh(job);
|
refresh(job);
|
||||||
context->renderJob = NULL;
|
context->renderJob = NULL;
|
||||||
updateUI();
|
updateUI();
|
||||||
|
updateCameraMenu();
|
||||||
if (ui->tabBar->currentIndex() != -1 &&
|
if (ui->tabBar->currentIndex() != -1 &&
|
||||||
m_context[ui->tabBar->currentIndex()] == context)
|
m_context[ui->tabBar->currentIndex()] == context)
|
||||||
resize(size() - context->sizeIncrease);
|
resize(size() - context->sizeIncrease);
|
||||||
|
@ -1929,7 +1944,8 @@ void MainWindow::refresh(const RenderJob *job) {
|
||||||
|
|
||||||
void MainWindow::onActivateCamera() {
|
void MainWindow::onActivateCamera() {
|
||||||
int index = ui->tabBar->currentIndex();
|
int index = ui->tabBar->currentIndex();
|
||||||
if (index == -1 || m_context[index]->scene == NULL)
|
if (index == -1 || m_context[index]->scene == NULL ||
|
||||||
|
m_context[index]->renderJob != NULL)
|
||||||
return;
|
return;
|
||||||
QAction *action = qobject_cast<QAction *>(sender());
|
QAction *action = qobject_cast<QAction *>(sender());
|
||||||
Sensor *sensor = static_cast<Sensor *>(action->data().value<void *>());
|
Sensor *sensor = static_cast<Sensor *>(action->data().value<void *>());
|
||||||
|
@ -1956,6 +1972,7 @@ void MainWindow::onActivateCamera() {
|
||||||
on_tabBar_currentChanged(index);
|
on_tabBar_currentChanged(index);
|
||||||
updateUI();
|
updateUI();
|
||||||
adjustSize();
|
adjustSize();
|
||||||
|
updateCameraMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_glView_loadFileRequest(const QString &string) {
|
void MainWindow::on_glView_loadFileRequest(const QString &string) {
|
||||||
|
|
|
@ -136,6 +136,7 @@ protected:
|
||||||
void checkForUpdates(bool notifyIfNone = false);
|
void checkForUpdates(bool notifyIfNone = false);
|
||||||
void saveAs(SceneContext *ctx, const QString &targetFile);
|
void saveAs(SceneContext *ctx, const QString &targetFile);
|
||||||
void refresh(const RenderJob *job);
|
void refresh(const RenderJob *job);
|
||||||
|
void updateCameraMenu();
|
||||||
QSize sizeHint() const;
|
QSize sizeHint() const;
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
|
|
Loading…
Reference in New Issue