cam: Move printing of camera information to CameraSession class

The three CamApp functions listControls(), listProperties() and
infoConfiguration() operate on a camera. They would thus be better
placed in the CameraSession class. Move them there. As they now have no
error to return anymore, make them void functions.

Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
This commit is contained in:
Laurent Pinchart 2021-07-07 02:12:07 +03:00
parent 3d50939113
commit 66c955648f
3 changed files with 70 additions and 80 deletions

View file

@ -11,6 +11,7 @@
#include <sstream>
#include <libcamera/control_ids.h>
#include <libcamera/property_ids.h>
#include "camera_session.h"
#include "event_loop.h"
@ -89,6 +90,50 @@ CameraSession::~CameraSession()
camera_->release();
}
void CameraSession::listControls() const
{
for (const auto &ctrl : camera_->controls()) {
const ControlId *id = ctrl.first;
const ControlInfo &info = ctrl.second;
std::cout << "Control: " << id->name() << ": "
<< info.toString() << std::endl;
}
}
void CameraSession::listProperties() const
{
for (const auto &prop : camera_->properties()) {
const ControlId *id = properties::properties.at(prop.first);
const ControlValue &value = prop.second;
std::cout << "Property: " << id->name() << " = "
<< value.toString() << std::endl;
}
}
void CameraSession::infoConfiguration() const
{
unsigned int index = 0;
for (const StreamConfiguration &cfg : *config_) {
std::cout << index << ": " << cfg.toString() << std::endl;
const StreamFormats &formats = cfg.formats();
for (PixelFormat pixelformat : formats.pixelformats()) {
std::cout << " * Pixelformat: "
<< pixelformat.toString() << " "
<< formats.range(pixelformat).toString()
<< std::endl;
for (const Size &size : formats.sizes(pixelformat))
std::cout << " - " << size.toString()
<< std::endl;
}
index++;
}
}
int CameraSession::start(const OptionsParser::Options &options)
{
int ret;

View file

@ -35,6 +35,10 @@ public:
libcamera::Camera *camera() { return camera_.get(); }
libcamera::CameraConfiguration *config() { return config_.get(); }
void listControls() const;
void listProperties() const;
void infoConfiguration() const;
int start(const OptionsParser::Options &options);
void stop();

View file

@ -39,9 +39,6 @@ private:
void cameraRemoved(std::shared_ptr<Camera> cam);
void captureDone();
int parseOptions(int argc, char *argv[]);
int listControls();
int listProperties();
int infoConfiguration();
int run();
static std::string cameraName(const Camera *camera);
@ -158,74 +155,6 @@ int CamApp::parseOptions(int argc, char *argv[])
return 0;
}
int CamApp::listControls()
{
if (!session_) {
std::cout << "Cannot list controls without a camera"
<< std::endl;
return -EINVAL;
}
for (const auto &ctrl : session_->camera()->controls()) {
const ControlId *id = ctrl.first;
const ControlInfo &info = ctrl.second;
std::cout << "Control: " << id->name() << ": "
<< info.toString() << std::endl;
}
return 0;
}
int CamApp::listProperties()
{
if (!session_) {
std::cout << "Cannot list properties without a camera"
<< std::endl;
return -EINVAL;
}
for (const auto &prop : session_->camera()->properties()) {
const ControlId *id = properties::properties.at(prop.first);
const ControlValue &value = prop.second;
std::cout << "Property: " << id->name() << " = "
<< value.toString() << std::endl;
}
return 0;
}
int CamApp::infoConfiguration()
{
if (!session_) {
std::cout << "Cannot print stream information without a camera"
<< std::endl;
return -EINVAL;
}
unsigned int index = 0;
for (const StreamConfiguration &cfg : *session_->config()) {
std::cout << index << ": " << cfg.toString() << std::endl;
const StreamFormats &formats = cfg.formats();
for (PixelFormat pixelformat : formats.pixelformats()) {
std::cout << " * Pixelformat: "
<< pixelformat.toString() << " "
<< formats.range(pixelformat).toString()
<< std::endl;
for (const Size &size : formats.sizes(pixelformat))
std::cout << " - " << size.toString()
<< std::endl;
}
index++;
}
return 0;
}
void CamApp::cameraAdded(std::shared_ptr<Camera> cam)
{
std::cout << "Camera Added: " << cam->id() << std::endl;
@ -269,21 +198,33 @@ int CamApp::run()
}
if (options_.isSet(OptListControls)) {
ret = listControls();
if (ret)
return ret;
if (!session_) {
std::cout << "Cannot list controls without a camera"
<< std::endl;
return -EINVAL;
}
session_->listControls();
}
if (options_.isSet(OptListProperties)) {
ret = listProperties();
if (ret)
return ret;
if (!session_) {
std::cout << "Cannot list properties without a camera"
<< std::endl;
return -EINVAL;
}
session_->listProperties();
}
if (options_.isSet(OptInfo)) {
ret = infoConfiguration();
if (ret)
return ret;
if (!session_) {
std::cout << "Cannot print stream information without a camera"
<< std::endl;
return -EINVAL;
}
session_->infoConfiguration();
}
if (options_.isSet(OptCapture)) {