diff options
-rw-r--r-- | facetracknoir/ui.cpp | 105 |
1 files changed, 39 insertions, 66 deletions
diff --git a/facetracknoir/ui.cpp b/facetracknoir/ui.cpp index 10445182..416a619c 100644 --- a/facetracknoir/ui.cpp +++ b/facetracknoir/ui.cpp @@ -340,100 +340,73 @@ void MainWindow::showHeadPose() } template<typename t> -mem<t> mk_dialog(mem<dylib> lib) +bool mk_dialog(mem<dylib> lib, mem<t>* orig) { + if (*orig && (*orig)->isVisible()) + { + (*orig)->show(); + (*orig)->raise(); + return false; + } + if (lib && lib->Dialog) { auto dialog = mem<t>(reinterpret_cast<t*>(lib->Dialog())); dialog->setWindowFlags(Qt::Dialog); dialog->setFixedSize(dialog->size()); - return dialog; + + *orig = dialog; + dialog->show(); + dialog->raise(); + + return true; } - return nullptr; + return false; } void MainWindow::showTrackerSettings() { - if (pTrackerDialog && pTrackerDialog->isVisible()) - { - pTrackerDialog->show(); - pTrackerDialog->raise(); - } - else - { - auto dialog = mk_dialog<ITrackerDialog>(current_tracker()); - if (!dialog) return; - pTrackerDialog = dialog; - if (libs.pTracker != nullptr) - dialog->register_tracker(libs.pTracker.get()); - dialog->show(); - dialog->raise(); - } + if (mk_dialog(current_tracker(), &pTrackerDialog) && libs.pTracker) + pTrackerDialog->register_tracker(libs.pTracker.get()); } void MainWindow::showProtocolSettings() { - if (pProtocolDialog && pProtocolDialog->isVisible()) - { - pProtocolDialog->show(); - pProtocolDialog->raise(); - } else - { - auto dialog = mk_dialog<IProtocolDialog>(current_protocol()); - if (!dialog) return; - pProtocolDialog = dialog; - if (libs.pProtocol != nullptr) - dialog->register_protocol(libs.pProtocol.get()); - dialog->show(); - dialog->raise(); - } + if (mk_dialog(current_tracker(), &pProtocolDialog) && libs.pProtocol) + pProtocolDialog->register_protocol(libs.pProtocol.get()); } void MainWindow::showFilterSettings() { - if (pFilterDialog && pFilterDialog->isVisible()) - { - pFilterDialog->show(); - pFilterDialog->raise(); - } else - { - auto dialog = mk_dialog<IFilterDialog>(current_filter()); - if (!dialog) return; - pFilterDialog = dialog; - if (libs.pFilter != nullptr) - dialog->register_filter(libs.pFilter.get()); - dialog->show(); - dialog->raise(); - } + if (mk_dialog(current_tracker(), &pFilterDialog) && libs.pFilter) + pFilterDialog->register_filter(libs.pFilter.get()); } -void MainWindow::showKeyboardShortcuts() { - if (shortcuts_widget && shortcuts_widget->isVisible()) +template<typename t, typename... Args> +bool mk_window(mem<t>* place, Args... params) +{ + if (*place && (*place)->isVisible()) { - shortcuts_widget->show(); - shortcuts_widget->raise(); + (*place)->show(); + (*place)->raise(); + return false; } else { - shortcuts_widget = std::make_shared<OptionsDialog>(); - shortcuts_widget->setWindowFlags(Qt::Dialog); - connect(shortcuts_widget.get(), SIGNAL(reload()), this, SLOT(bindKeyboardShortcuts())); - shortcuts_widget->show(); - shortcuts_widget->raise(); + *place = std::make_shared<t>(params...); + (*place)->setWindowFlags(Qt::Dialog); + (*place)->show(); + (*place)->raise(); + return true; } } +void MainWindow::showKeyboardShortcuts() { + if (mk_window(&shortcuts_widget)) + connect(shortcuts_widget.get(), SIGNAL(reload()), this, SLOT(bindKeyboardShortcuts())); +} + void MainWindow::showCurveConfiguration() { - if (mapping_widget && mapping_widget->isVisible()) - { - mapping_widget->show(); - mapping_widget->raise(); - } - else - { - mapping_widget = std::make_shared<MapWidget>(pose, s); - mapping_widget->setWindowFlags(Qt::Dialog); - mapping_widget->show(); - } + mk_window<MapWidget, Mappings&, main_settings&>(&mapping_widget, pose, s); } void MainWindow::exit() { |