summaryrefslogtreecommitdiff
path: root/src/qcam/main_window.cpp
diff options
context:
ption>space:mode:
Diffstat (limited to 'src/qcam/main_window.cpp')
-rw-r--r--src/qcam/main_window.cpp40
1 files changed, 25 insertions, 15 deletions
diff --git a/src/qcam/main_window.cpp b/src/qcam/main_window.cpp
index ef4ad4a2..3d563092 100644
--- a/src/qcam/main_window.cpp
+++ b/src/qcam/main_window.cpp
@@ -66,27 +66,37 @@ void MainWindow::updateTitle()
setWindowTitle(title_ + " : " + QString::number(fps, 'f', 2) + " fps");
}
-int MainWindow::openCamera(CameraManager *cm)
+std::string MainWindow::chooseCamera(CameraManager *cm)
{
- std::string cameraName;
+ QStringList cameras;
+ bool result;
+
+ if (cm->cameras().size() == 1)
+ return cm->cameras()[0]->name();
- if (!options_.isSet(OptCamera)) {
- QStringList cameras;
- bool result;
+ for (const std::shared_ptr<Camera> &cam : cm->cameras())
+ cameras.append(QString::fromStdString(cam->name()));
- for (const std::shared_ptr<Camera> &cam : cm->cameras())
- cameras.append(QString::fromStdString(cam->name()));
+ QString name = QInputDialog::getItem(this, "Select Camera",
+ "Camera:", cameras, 0,
+ false, &result);
+ if (!result)
+ return std::string();
- QString name = QInputDialog::getItem(this, "Select Camera",
- "Camera:", cameras, 0,
- false, &result);
- if (!result)
- return -EINVAL;
+ return name.toStdString();
+}
- cameraName = name.toStdString();
- } else {
+int MainWindow::openCamera(CameraManager *cm)
+{
+ std::string cameraName;
+
+ if (options_.isSet(OptCamera))
cameraName = static_cast<std::string>(options_[OptCamera]);
- }
+ else
+ cameraName = chooseCamera(cm);
+
+ if (cameraName == "")
+ return -EINVAL;
camera_ = cm->get(cameraName);
if (!camera_) {