[libcamera-devel] [PATCH] qcam: Centralize toggling of Capture Script Action

Utkarsh Tiwari utkarsh02t at gmail.com
Mon Jul 11 18:53:27 CEST 2022


Centralize the use of scriptExecAction_ in a single
function toggleScriptAction().

Call toggleScriptAction() with a true value to
reset script_ and set the icon to show availability
to load script to the user.
Call with a false value to set the icon to show
the stopping icon.

Signed-off-by: Utkarsh Tiwari <utkarsh02t at gmail.com>
---
This patch applies on top of series
https://lists.libcamera.org/pipermail/libcamera-devel/2022-June/031151.html

 src/qcam/main_window.cpp | 26 ++++++++++++++++++--------
 src/qcam/main_window.h   |  2 ++
 2 files changed, 20 insertions(+), 8 deletions(-)

diff --git a/src/qcam/main_window.cpp b/src/qcam/main_window.cpp
index a13a8b34..d4b3d629 100644
--- a/src/qcam/main_window.cpp
+++ b/src/qcam/main_window.cpp
@@ -161,8 +161,7 @@ MainWindow::MainWindow(CameraManager *cm, const OptionsParser::Options &options)
 		}
 
 		/* Show stopping availability. */
-		scriptExecAction_->setIcon(QIcon(":x-square.svg"));
-		scriptExecAction_->setText("Stop Script execution");
+		toggleScriptAction(false);
 	}
 
 	startStopAction_->setChecked(true);
@@ -252,6 +251,8 @@ int MainWindow::createToolbars()
 						      QIcon(":file.svg")),
 				     "Open Capture Script");
 	connect(action, &QAction::triggered, this, &MainWindow::chooseScript);
+
+	/* Do not operate directly call toggleScriptAction */
 	scriptExecAction_ = action;
 
 	return 0;
@@ -289,10 +290,7 @@ void MainWindow::chooseScript()
 		 * This is the second valid press of load script button,
 		 * It indicates stopping, Stop and set button for new script.
 		 */
-		script_.reset();
-		scriptExecAction_->setIcon(QIcon::fromTheme("document-open",
-							    QIcon(":file.svg")));
-		scriptExecAction_->setText("Open Capture Script");
+		toggleScriptAction(true);
 		return;
 	}
 
@@ -323,14 +321,26 @@ void MainWindow::chooseScript()
 	 * Valid script verified
 	 * Set the button to indicate stopping availibility.
 	 */
-	scriptExecAction_->setIcon(QIcon(":x-square.svg"));
-	scriptExecAction_->setText("Stop Script execution");
+	toggleScriptAction(false);
 
 	/* Start capture again if we were capturing before. */
 	if (wasCapturing)
 		toggleCapture(true);
 }
 
+void MainWindow::toggleScriptAction(bool showAvailable)
+{
+	if (showAvailable) {
+		script_.reset();
+		scriptExecAction_->setIcon(QIcon::fromTheme("document-open",
+							    QIcon(":file.svg")));
+		scriptExecAction_->setText("Open Capture Script");
+	} else {
+		scriptExecAction_->setIcon(QIcon(":x-square.svg"));
+		scriptExecAction_->setText("Stop Script execution");
+	}
+}
+
 /* -----------------------------------------------------------------------------
  * Camera Selection
  */
diff --git a/src/qcam/main_window.h b/src/qcam/main_window.h
index 4d19ab64..6f131b17 100644
--- a/src/qcam/main_window.h
+++ b/src/qcam/main_window.h
@@ -90,6 +90,8 @@ private:
 
 	void chooseScript();
 
+	void toggleScriptAction(bool showAvailable);
+
 	/* UI elements */
 	QToolBar *toolbar_;
 	QAction *startStopAction_;
-- 
2.25.1



More information about the libcamera-devel mailing list