[libcamera-devel] [PATCH 3/4] qcam: CameraSelectDialog: Display Location and Model propety of camera
Umang Jain
umang.jain at ideasonboard.com
Thu Aug 4 14:06:09 CEST 2022
Hi Utkarsh,
Thank you for the patch.
On 8/3/22 23:25, Utkarsh Tiwari via libcamera-devel wrote:
> The camera selection dialog currently only displays the camera Id.
> Display the camera location and camera model if available.
>
> Signed-off-by: Utkarsh Tiwari <utkarsh02t at gmail.com>
> ---
> src/qcam/main_window.cpp | 69 ++++++++++++++++++++++++++++++++++++++++
> src/qcam/main_window.h | 7 ++++
> 2 files changed, 76 insertions(+)
>
> diff --git a/src/qcam/main_window.cpp b/src/qcam/main_window.cpp
> index 80a73b68..81fa3e60 100644
> --- a/src/qcam/main_window.cpp
> +++ b/src/qcam/main_window.cpp
> @@ -12,6 +12,7 @@
> #include <string>
>
> #include <libcamera/camera_manager.h>
> +#include <libcamera/property_ids.h>
> #include <libcamera/version.h>
>
> #include <QComboBox>
> @@ -23,6 +24,7 @@
> #include <QImage>
> #include <QImageWriter>
> #include <QInputDialog>
> +#include <QLabel>
> #include <QMutexLocker>
> #include <QStandardPaths>
> #include <QStringList>
> @@ -291,6 +293,47 @@ void MainWindow::switchCamera(int index)
> startStopAction_->setChecked(true);
> }
>
> +QString MainWindow::getCameraLocation(const std::shared_ptr<Camera> &camera)
> +{
> + if (camera == nullptr)
> + return QString();
> +
> + const ControlList &cameraProperties = camera->properties();
> + const auto &location = cameraProperties.get(properties::Location);
> +
> + if (location) {
> + switch (*location) {
> + case properties::CameraLocationFront:
> + return "Internal front camera ";
> + case properties::CameraLocationBack:
> + return "Internal back camera ";
> + case properties::CameraLocationExternal:
> + return "External camera ";
> + }
> + }
> + return QString();
> +}
> +
> +QString MainWindow::getCameraModel(const std::shared_ptr<Camera> &camera)
> +{
> + if (camera == nullptr)
> + return QString();
> +
> + const ControlList &cameraProperties = camera->properties();
> + const auto &model = cameraProperties.get(properties::Model);
> +
> + if (model)
> + return QString::fromStdString(*model);
> +
> + return QString();
> +}
> +
> +void MainWindow::updateCameraInfo(const std::shared_ptr<libcamera::Camera> &camera)
> +{
> + cameraLocation_->setText(getCameraLocation(camera));
> + cameraModel_->setText(getCameraModel(camera));
The getCameramodel() and getCameraLocation are concise helpers which can
be subsumed under updateCameraInfo() itself.
> +}
> +
> std::string MainWindow::chooseCamera()
> {
> std::string result;
> @@ -303,6 +346,29 @@ std::string MainWindow::chooseCamera()
> for (const std::shared_ptr<Camera> &cam : cm_->cameras())
> cameraIdComboBox_->addItem(QString::fromStdString(cam->id()));
>
> + /* Display Camera Informtion in the Selection Dialog. */
/* Display camera information in the selection dialog. */
> + cameraLocation_ = new QLabel;
> + cameraModel_ = new QLabel;
> +
> + std::shared_ptr<Camera> currentCamera;
> +
> + /*
> + * When the Qdialog starts, the QComboBox would have the first
s/Qdialog/QDialog/
s/would/should/
> + * camera's Id as its currentText.
> + */
> + if (cm_->cameras().size())
> + currentCamera = cm_->cameras()[0];
> + else
> + currentCamera = nullptr;
currentCamera is a shared_ptr above which doesn't yet manage an object
which means it's nullptr unless it's assigned. Hence, you can drop the
else block here.
Rest looks good to me!
> +
> + if (currentCamera)
> + updateCameraInfo(currentCamera);
> +
> + connect(cameraIdComboBox_, &QComboBox::currentTextChanged,
> + this, [&]() {
> + updateCameraInfo(cm_->get(cameraIdComboBox_->currentText().toStdString()));
> + });
> +
> /* Setup QDialogButtonBox. */
> QDialogButtonBox *dialogButtonBox = new QDialogButtonBox;
> dialogButtonBox->addButton(QDialogButtonBox::Cancel);
> @@ -323,6 +389,9 @@ std::string MainWindow::chooseCamera()
> /* Setup the layout for the dialog. */
> QFormLayout *cameraSelectLayout = new QFormLayout(cameraSelectDialog);
> cameraSelectLayout->addRow("Camera: ", cameraIdComboBox_);
> + cameraSelectLayout->addRow("Location: ", cameraLocation_);
> + cameraSelectLayout->addRow("Model: ", cameraModel_);
> +
> cameraSelectLayout->addWidget(dialogButtonBox);
>
> cameraSelectDialog->exec();
> diff --git a/src/qcam/main_window.h b/src/qcam/main_window.h
> index b8122eb9..3a1c6156 100644
> --- a/src/qcam/main_window.h
> +++ b/src/qcam/main_window.h
> @@ -20,6 +20,7 @@
>
> #include <QElapsedTimer>
> #include <QIcon>
> +#include <QLabel>
> #include <QMainWindow>
> #include <QMutex>
> #include <QObject>
> @@ -88,6 +89,10 @@ private:
> void processHotplug(HotplugEvent *e);
> void processViewfinder(libcamera::FrameBuffer *buffer);
>
> + QString getCameraLocation(const std::shared_ptr<libcamera::Camera> &camera);
> + QString getCameraModel(const std::shared_ptr<libcamera::Camera> &camera);
> + void updateCameraInfo(const std::shared_ptr<libcamera::Camera> &camera);
> +
> /* UI elements */
> QToolBar *toolbar_;
> QAction *startStopAction_;
> @@ -102,6 +107,8 @@ private:
> QTimer titleTimer_;
>
> QPointer<QComboBox> cameraIdComboBox_;
> + QLabel *cameraLocation_;
> + QLabel *cameraModel_;
>
> /* Options */
> const OptionsParser::Options &options_;
More information about the libcamera-devel
mailing list