Ekos::CameraProcess
#include <cameraprocess.h>
Public Types | |
enum | ADUAlgorithm { ADU_LEAST_SQUARES , ADU_POLYNOMIAL } |
typedef struct Ekos::CameraProcess::FitsvViewerTabIDs | FitsvViewerTabIDs |
Public Types inherited from QObject | |
typedef | QObjectList |
Signals | |
void | abortFocus () |
void | addJob (SequenceJob *job) |
void | cameraReady () |
void | captureAborted (double exposureSeconds) |
void | captureComplete (const QVariantMap &metadata) |
void | captureImageStarted () |
void | captureRunning () |
void | captureStopped () |
void | captureTarget (QString targetName) |
void | createJob (SequenceJob::SequenceJobType jobtype=SequenceJob::JOBTYPE_BATCH) |
void | darkFrameCompleted () |
void | downloadingFrame () |
void | driverTimedout (const QString &deviceName) |
void | jobExecutionPreparationStarted () |
void | jobPrepared (SequenceJob *job) |
void | jobStarting () |
void | newDownloadProgress (double downloadTimeLeft) |
void | newExposureProgress (SequenceJob *job) |
void | newImage (SequenceJob *job, const QSharedPointer< FITSData > &data) |
void | newLog (const QString &text) |
void | newView (const QSharedPointer< FITSView > &view) |
void | processingFITSfinished (bool success) |
void | refreshCamera (bool isValid) |
void | refreshCameraSettings () |
void | refreshFilterSettings () |
void | requestAction (CaptureWorkflowActionType action) |
void | resumeGuiding () |
void | rotatorReverseToggled (bool enabled) |
void | sequenceChanged (const QJsonArray &sequence) |
void | stopCapture (CaptureState targetState=CAPTURE_IDLE) |
void | suspendGuiding () |
void | syncGUIToJob (SequenceJob *job) |
void | updateCaptureCountDown (int deltaMS) |
void | updateFrameProperties (int reset) |
void | updateJobTable (SequenceJob *job, bool full=false) |
void | updateMeridianFlipStage (MeridianFlipState::MFStage stage) |
Public Member Functions | |
CameraProcess (QSharedPointer< CameraState > newModuleState, QSharedPointer< CaptureDeviceAdaptor > newDeviceAdaptor) | |
double | calculateFlatExpTime (double currentADU) |
void | captureImage () |
void | capturePreview (bool loop=false) |
QProcess & | captureScript () |
void | captureStarted (CaptureResult rc) |
void | checkCamera () |
bool | checkFlatCalibration (QSharedPointer< FITSData > imageData, double exp_min, double exp_max) |
IPState | checkLightFramePendingTasks () |
void | checkNextExposure () |
bool | checkPausing (CaptureContinueAction continueAction) |
void | clearFlatCache () |
void | closeVideoWindow () |
IPState | continueFramingAction (const QSharedPointer< FITSData > &imageData) |
Q_SCRIPTABLE void | executeJob () |
QStringList | filterLabels () |
SequenceJob * | findNextPendingJob () |
QStringList | frameTypes () |
QStringList | generateScriptArguments () const |
QSharedPointer< StreamWG > | getVideoWindow () |
bool | hasCoolerControl () |
void | jobCreated (SequenceJob *newJob) |
void | llsq (QVector< double > x, QVector< double > y, double &a, double &b) |
bool | loadSequenceQueue (const QString &fileURL, const QString &targetName="", bool setOptions=true) |
Q_SCRIPTABLE void | pauseCapturing () |
void | prepareActiveJobStage1 () |
void | prepareActiveJobStage2 () |
void | prepareJob (SequenceJob *job) |
void | prepareJobExecution () |
IPState | previewImageCompletedAction () |
void | processCaptureError (ISD::Camera::ErrorType type) |
void | processCaptureTimeout () |
void | processFITSData (const QSharedPointer< FITSData > &data, const QString &extension) |
void | processJobCompletion1 () |
void | processJobCompletion2 () |
void | processNewRemoteFile (QString file) |
IPState | processPreCaptureCalibrationStage () |
void | reconnectCameraDriver (const QString &camera, const QString &filterWheel) |
void | refreshOpticalTrain (QString name) |
void | removeDevice (const QSharedPointer< ISD::GenericDevice > &device) |
Q_SCRIPTABLE void | resetFrame () |
void | restartCamera (const QString &name) |
IPState | resumeSequence () |
IPState | runCaptureScript (ScriptTypes scriptType, bool precond=true) |
bool | saveSequenceQueue (const QString &path, bool loadOptions=true) |
void | scriptFinished (int exitCode, QProcess::ExitStatus status) |
void | selectCamera (QString name) |
void | setCamera (bool connection) |
bool | setCamera (ISD::Camera *device) |
bool | setCoolerControl (bool enable) |
bool | setDome (ISD::Dome *device) |
void | setDownloadProgress () |
bool | setDustCap (ISD::DustCap *device) |
void | setExposureProgress (ISD::CameraChip *tChip, double value, IPState state) |
bool | setFilterWheel (ISD::FilterWheel *device) |
bool | setLightBox (ISD::LightBox *device) |
bool | setMount (ISD::Mount *device) |
bool | setRotator (ISD::Rotator *device) |
void | setScope (const QString &name) |
void | showFITSPreview (const QSharedPointer< FITSData > &data) |
void | showVideoFrame (INDI::Property prop, int width, int height) |
void | startJob (SequenceJob *job) |
IPState | startNextExposure () |
IPState | startNextJob () |
void | startNextPendingJob () |
void | stopCapturing (CaptureState targetState) |
void | syncDSLRToTargetChip (const QString &model) |
Q_SCRIPTABLE void | toggleSequence () |
void | toggleVideo (bool enabled) |
void | updateCompletedCaptureCountersAction () |
IPState | updateDownloadTimesAction () |
void | updateFilterInfo () |
void | updateFITSViewer (const QSharedPointer< FITSData > data, const FITSMode &captureMode, const FITSScale &captureFilter, const QString &filename, const QString &deviceName) |
void | updateFITSViewer (const QSharedPointer< FITSData > data, ISD::CameraChip *tChip, const QString &filename) |
void | updateGain (double value, QMap< QString, QMap< QString, QVariant > > &propertyMap) |
IPState | updateImageMetadataAction (QSharedPointer< FITSData > imageData) |
void | updateOffset (double value, QMap< QString, QMap< QString, QVariant > > &propertyMap) |
void | updatePreCaptureCalibrationStatus () |
void | updateTelescopeInfo () |
void | updateVideoWindow (int width, int height, bool streamEnabled) |
Public Member Functions inherited from QObject | |
QObject (QObject *parent) | |
QBindable< QString > | bindableObjectName () |
bool | blockSignals (bool block) |
const QObjectList & | children () const const |
QMetaObject::Connection | connect (const QObject *sender, const char *signal, const char *method, Qt::ConnectionType type) const const |
void | deleteLater () |
void | destroyed (QObject *obj) |
bool | disconnect (const char *signal, const QObject *receiver, const char *method) const const |
bool | disconnect (const QObject *receiver, const char *method) const const |
void | dumpObjectInfo () const const |
void | dumpObjectTree () const const |
QList< QByteArray > | dynamicPropertyNames () const const |
virtual bool | event (QEvent *e) |
virtual bool | eventFilter (QObject *watched, QEvent *event) |
T | findChild (const QString &name, Qt::FindChildOptions options) const const |
QList< T > | findChildren (const QRegularExpression &re, Qt::FindChildOptions options) const const |
QList< T > | findChildren (const QString &name, Qt::FindChildOptions options) const const |
QList< T > | findChildren (Qt::FindChildOptions options) const const |
bool | inherits (const char *className) const const |
void | installEventFilter (QObject *filterObj) |
bool | isQuickItemType () const const |
bool | isWidgetType () const const |
bool | isWindowType () const const |
void | killTimer (int id) |
virtual const QMetaObject * | metaObject () const const |
void | moveToThread (QThread *targetThread) |
QString | objectName () const const |
void | objectNameChanged (const QString &objectName) |
QObject * | parent () const const |
QVariant | property (const char *name) const const |
Q_CLASSINFO (Name, Value) | |
Q_EMIT Q_EMIT | |
Q_ENUM (...) | |
Q_ENUM_NS (...) | |
Q_ENUMS (...) | |
Q_FLAG (...) | |
Q_FLAG_NS (...) | |
Q_FLAGS (...) | |
Q_GADGET Q_GADGET | |
Q_GADGET_EXPORT (EXPORT_MACRO) | |
Q_INTERFACES (...) | |
Q_INVOKABLE Q_INVOKABLE | |
Q_MOC_INCLUDE Q_MOC_INCLUDE | |
Q_NAMESPACE Q_NAMESPACE | |
Q_NAMESPACE_EXPORT (EXPORT_MACRO) | |
Q_OBJECT Q_OBJECT | |
Q_PROPERTY (...) | |
Q_REVISION Q_REVISION | |
Q_SET_OBJECT_NAME (Object) | |
Q_SIGNAL Q_SIGNAL | |
Q_SIGNALS Q_SIGNALS | |
Q_SLOT Q_SLOT | |
Q_SLOTS Q_SLOTS | |
T | qobject_cast (const QObject *object) |
T | qobject_cast (QObject *object) |
QT_NO_NARROWING_CONVERSIONS_IN_CONNECT QT_NO_NARROWING_CONVERSIONS_IN_CONNECT | |
void | removeEventFilter (QObject *obj) |
void | setObjectName (const QString &name) |
void | setObjectName (QAnyStringView name) |
void | setParent (QObject *parent) |
bool | setProperty (const char *name, const QVariant &value) |
bool | setProperty (const char *name, QVariant &&value) |
bool | signalsBlocked () const const |
int | startTimer (int interval, Qt::TimerType timerType) |
int | startTimer (std::chrono::milliseconds interval, Qt::TimerType timerType) |
QThread * | thread () const const |
Additional Inherited Members | |
Properties inherited from QObject | |
objectName | |
Static Public Member Functions inherited from QObject | |
QMetaObject::Connection | connect (const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type) |
QMetaObject::Connection | connect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method, Qt::ConnectionType type) |
QMetaObject::Connection | connect (const QObject *sender, PointerToMemberFunction signal, const QObject *context, Functor functor, Qt::ConnectionType type) |
QMetaObject::Connection | connect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method, Qt::ConnectionType type) |
QMetaObject::Connection | connect (const QObject *sender, PointerToMemberFunction signal, Functor functor) |
bool | disconnect (const QMetaObject::Connection &connection) |
bool | disconnect (const QObject *sender, const char *signal, const QObject *receiver, const char *method) |
bool | disconnect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method) |
bool | disconnect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method) |
QString | tr (const char *sourceText, const char *disambiguation, int n) |
Protected Member Functions inherited from QObject | |
virtual void | childEvent (QChildEvent *event) |
virtual void | connectNotify (const QMetaMethod &signal) |
virtual void | customEvent (QEvent *event) |
virtual void | disconnectNotify (const QMetaMethod &signal) |
bool | isSignalConnected (const QMetaMethod &signal) const const |
int | receivers (const char *signal) const const |
QObject * | sender () const const |
int | senderSignalIndex () const const |
virtual void | timerEvent (QTimerEvent *event) |
Detailed Description
The CameraProcess class holds the entire business logic to control capturing execution.
Capture Execution
Executing the sequence jobs is a complex process (explained here for light frames) and works roughly as follows and starts by calling {
- See also
- Capture::start()} either from the scheduler, by DBUS or by pressing the start button:
- Select the next sequence job to be executed ({
- startNextPendingJob()}. If the list of jobs is empty, an {
- addJob()} event is sent. The corresponding callback function {
-
#jobAdded(SequenceJob*)} is triggered. Now we know that at least one sequence job is to be executed.
- Prepare the selected job
- update the counters of captured frames ({
- Prepare the selected job
-
prepareJob(SequenceJob *)})
- execute the pre job script, if existing ({
-
prepareActiveJobStage1()})
- set temperature, rotator angle and wait (if required) for the initial guiding deviation being below the configured threshold ({
-
prepareJobExecution()}) and wait until these parameters are OK.
- Prepare capturing a single frame We still need to do some preparation steps before capturing starts.
- {
- Prepare capturing a single frame We still need to do some preparation steps before capturing starts.
-
executeJob()} is the starting point, which simply sets the capture state to "busy" and sets the FITS attributes to the camera
- Check all tasks that need to be completed before capturing may start (post meridian flip actions, guiding deviation, dithering, re-focusing, ..., see {
-
checkLightFramePendingTasks()}
- Capture a single frame
- Initiate capturing (set diverse settings of {
- Capture a single frame
- activeCamera()} (see {
-
captureImage})
- hand over the control of capturing to the sequence job ({
-
SequenceJob::startCapturing()})
- Select the correct filter (
-
SequenceJobState::prepareTargetFilter()}
- As soon as the correct filter is set, the sequence job state will send the event {
- SequenceJobState::initCaptureComplete()}, which will finally call trigger {
-
SequenceJob::capture()}
- Listen upon capturing progress
- listen to the event {
- Listen upon capturing progress
-
ISD::Camera::newExposureValue}, update the remaining time and wait until the INDI state changes from busy to OK
- start the download timer to measure download times
- listen to the event {
-
ISD::Camera::newImage} and start processing the FITS image as soon as it has been recieved
- Process received image
- update the FITS image meta data {
- Process received image
-
updateImageMetadataAction()}
- update time calculation and counters and execute post capture script ({
-
imageCapturingCompleted()})
- Check how to continue the sequence execution ({
-
resumeSequence()})
- if the current sequence job isn't completed,
- execute the post capture script
- start next exposure (similar to 3.) ({
- if the current sequence job isn't completed,
- startNextExposure()}) TODO: check why we need this separate method and cannot use {
-
updatePreCaptureCalibrationStatus()}
- if the current sequence is complete,
- execute the post sequence script ({
- if the current sequence is complete,
-
processJobCompletion1()})
- stop the current sequence job ({
-
processJobCompletion2()})
- recall {
- resumeSequence()}, which calls {
- startNextJob()}
ADU based flats calibration
Capturing ADU based flats begins like capturing other frame types. The difference begins as soon as an image has been received (step 6 above) in {
- See also
- imageCapturingCompleted()}. Here {
- checkFlatCalibration()} is called to check the frame's ADU. If the ADU isn't in the expected range, a new frame is captured with modified exposure time ({
- startNextExposure()}.
Autofocus
Capture has three ways that trigger autofocus during a capturing sequence: HFR based, temperature drift based, timer based and post meridian flip based. Each time the capture execution reaches the preparation of caturing a single frame (3. above) (see {
- See also
- CameraState::startFocusIfRequired()} and {
- RefocusState::checkFocusRequired()}).
Meridian Flip
The meridian flip itself is executed by the Mount module and is controlled by (see {
- See also
- MeridianFlipState}). Nevertheless, the Capture module plays an important rule in the meridian flip:
- Accept a flip to be executed As soon as a meridian flip has been planned (informed through {
-
#updateMFMountState(MeridianFlipState::MeridianFlipMountState)}, the meridian flip state is set to MF_REQUESTED.
- If capturing is running the state remains in this state until the frame has been captured. As soon as the capturing state changes to id, suspended or aborted (see {
- CameraState::setCaptureState(CaptureState)}), the meridian flip state is set to MF_ACCEPTED (see {
- MeridianFlipState::updateMeridianFlipStage(const MFStage)}). This is triggered from {
-
checkLightFramePendingTasks()}, i.e. this function is looping once per second until the meridian flip has been completed.
- If capturing is not running, the latter happens immediately. Now the meridian flip is started.
- Post MF actions As soon as the meridian flip has been completed (and the Capture module is waiting for it), the Capture module takes over the control and executes all necessary tasks: aligning, re-focusing, guiding, etc. This happens all through {
- See also
- checkLightFramePendingTasks()}. As soon as all has recovered, capturing continues.
Definition at line 112 of file cameraprocess.h.
Member Enumeration Documentation
◆ ADUAlgorithm
enum Ekos::CameraProcess::ADUAlgorithm |
Definition at line 117 of file cameraprocess.h.
Constructor & Destructor Documentation
◆ CameraProcess()
Ekos::CameraProcess::CameraProcess | ( | QSharedPointer< CameraState > | newModuleState, |
QSharedPointer< CaptureDeviceAdaptor > | newDeviceAdaptor ) |
Definition at line 41 of file cameraprocess.cpp.
Member Function Documentation
◆ calculateFlatExpTime()
double Ekos::CameraProcess::calculateFlatExpTime | ( | double | currentADU | ) |
calculateFlatExpTime calculate the next flat exposure time from the measured ADU value
- Parameters
-
currentADU ADU of the last captured frame
- Returns
- next exposure time to be tried for the flat capturing
Definition at line 2313 of file cameraprocess.cpp.
◆ captureImage()
void Ekos::CameraProcess::captureImage | ( | ) |
captureImage Initiates image capture in the active job.
Definition at line 1448 of file cameraprocess.cpp.
◆ capturePreview()
void Ekos::CameraProcess::capturePreview | ( | bool | loop = false | ) |
capturePreview Capture a preview (single or looping ones)
Definition at line 311 of file cameraprocess.cpp.
◆ captureScript()
|
inline |
Definition at line 704 of file cameraprocess.h.
◆ captureStarted()
void Ekos::CameraProcess::captureStarted | ( | CaptureResult | rc | ) |
captureStarted Manage the result when capturing has been started
Definition at line 846 of file cameraprocess.cpp.
◆ checkCamera()
void Ekos::CameraProcess::checkCamera | ( | ) |
configureCamera Refreshes the CCD information in the capture module.
Definition at line 1936 of file cameraprocess.cpp.
◆ checkFlatCalibration()
bool Ekos::CameraProcess::checkFlatCalibration | ( | QSharedPointer< FITSData > | imageData, |
double | exp_min, | ||
double | exp_max ) |
checkFlatCalibration check the flat calibration
- Parameters
-
imageData current image data to be analysed exp_min minimal possible exposure time exp_max maximal possible exposure time
- Returns
- false iff calibration has not been reached yet
Definition at line 2189 of file cameraprocess.cpp.
◆ checkLightFramePendingTasks()
IPState Ekos::CameraProcess::checkLightFramePendingTasks | ( | ) |
Check all tasks that might be pending before capturing may start.
The following checks are executed:
- Are there any pending jobs that failed? If yes, return with IPS_ALERT.
- Has pausing been initiated (
- See also
- checkPausing()).
- Is a meridian flip already running (
- See also
- m_MeridianFlipState->checkMeridianFlipRunning()) or ready for execution (
- CameraState::checkMeridianFlipReady()).
- check guide deviation for non meridian flip stages if the initial guide limit is set. Wait until the guide deviation is reported to be below the limit (
- Check if dithering is required or running.
- Check if re-focusing is required Needs to be checked after dithering checks to avoid dithering in parallel to focusing, since @startFocusIfRequired() might change its value over time
- Resume guiding if it was suspended (
- See also
- Capture::resumeGuiding())
- Returns
- IPS_OK iff no task is pending, IPS_BUSY otherwise (or IPS_ALERT if a problem occured)
Definition at line 796 of file cameraprocess.cpp.
◆ checkNextExposure()
void Ekos::CameraProcess::checkNextExposure | ( | ) |
checkNextExposure Try to start capturing the next exposure (
- See also
- startNextExposure()). If startNextExposure() returns, that there are still some jobs pending, we wait for 1 second and retry to start it again. If one of the pending preparation jobs has problems, the looping stops.
Definition at line 894 of file cameraprocess.cpp.
◆ checkPausing()
bool Ekos::CameraProcess::checkPausing | ( | CaptureContinueAction | continueAction | ) |
checkPausing check if a pause has been planned and pause subsequently
- Parameters
-
continueAction action to be executed when resume after pausing
- Returns
- true iff capturing has been paused
Definition at line 2708 of file cameraprocess.cpp.
◆ clearFlatCache()
void Ekos::CameraProcess::clearFlatCache | ( | ) |
clearFlatCache Clear the measured values for flat calibrations
Definition at line 2424 of file cameraprocess.cpp.
◆ closeVideoWindow()
void Ekos::CameraProcess::closeVideoWindow | ( | ) |
Definition at line 2617 of file cameraprocess.cpp.
◆ continueFramingAction()
IPState Ekos::CameraProcess::continueFramingAction | ( | const QSharedPointer< FITSData > & | imageData | ) |
continueFramingAction If framing is running, start the next capture sequence
- Returns
- IPS_OK in all cases
Definition at line 1671 of file cameraprocess.cpp.
◆ executeJob()
void Ekos::CameraProcess::executeJob | ( | ) |
executeJob Start the execution of activeJob by initiating updatePreCaptureCalibrationStatus().
Definition at line 694 of file cameraprocess.cpp.
◆ filterLabels()
QStringList Ekos::CameraProcess::filterLabels | ( | ) |
filterLabels list of currently available filter labels
Definition at line 2924 of file cameraprocess.cpp.
◆ findNextPendingJob()
SequenceJob * Ekos::CameraProcess::findNextPendingJob | ( | ) |
findExecutableJob find next job to be executed
Definition at line 2725 of file cameraprocess.cpp.
◆ frameTypes()
QStringList Ekos::CameraProcess::frameTypes | ( | ) |
frameTypes Retrieve the frame types from the active camera's primary chip.
Definition at line 2910 of file cameraprocess.cpp.
◆ generateScriptArguments()
QStringList Ekos::CameraProcess::generateScriptArguments | ( | ) | const |
generateScriptArguments Generate argument list to pass to capture script
- Returns
- generates argument list consisting of one argument -metadata followed by JSON-formatted key:value pair: -ts UNIX timestamp -image full path to captured image (if any) -size size of file in bytes (if any) -job {name, index} -capture {name, index} -filter TODO depending on user feedback.
Definition at line 2871 of file cameraprocess.cpp.
◆ getVideoWindow()
QSharedPointer< StreamWG > Ekos::CameraProcess::getVideoWindow | ( | ) |
getVideoWindow Return the current video window and initialize it if required.
Definition at line 2589 of file cameraprocess.cpp.
◆ hasCoolerControl()
bool Ekos::CameraProcess::hasCoolerControl | ( | ) |
Does the CCD has a cooler control (On/Off) ?
Definition at line 2877 of file cameraprocess.cpp.
◆ jobCreated()
void Ekos::CameraProcess::jobCreated | ( | SequenceJob * | newJob | ) |
Counterpart to the event {.
- See also
- createJob(SequenceJob::SequenceJobType)} where the event receiver reports whether one has been added successfully and of which type it was.
Definition at line 288 of file cameraprocess.cpp.
◆ llsq()
Definition at line 2825 of file cameraprocess.cpp.
◆ loadSequenceQueue()
bool Ekos::CameraProcess::loadSequenceQueue | ( | const QString & | fileURL, |
const QString & | targetName = "", | ||
bool | setOptions = true ) |
Loads the Ekos Sequence Queue file in the Sequence Queue.
Jobs are appended to existing jobs.
- Parameters
-
fileURL full URL of the filename targetName override the target defined in the sequence queue file (necessary for using the target of the scheduler)
Definition at line 2635 of file cameraprocess.cpp.
◆ pauseCapturing()
void Ekos::CameraProcess::pauseCapturing | ( | ) |
pauseCapturing Pauses capturing as soon as the current capture is complete.
Definition at line 440 of file cameraprocess.cpp.
◆ prepareActiveJobStage1()
void Ekos::CameraProcess::prepareActiveJobStage1 | ( | ) |
prepareActiveJobStage1 Check for pre job script to execute.
If none, move to stage 2
Definition at line 651 of file cameraprocess.cpp.
◆ prepareActiveJobStage2()
void Ekos::CameraProcess::prepareActiveJobStage2 | ( | ) |
prepareActiveJobStage2 Reset #calibrationStage and continue with preparePreCaptureActions().
Definition at line 667 of file cameraprocess.cpp.
◆ prepareJob()
void Ekos::CameraProcess::prepareJob | ( | SequenceJob * | job | ) |
prepareJob Update the counters of existing frames and continue with prepareActiveJob(), if there exist less images than targeted.
If enough images exist, continue with processJobCompletion().
Definition at line 463 of file cameraprocess.cpp.
◆ prepareJobExecution()
void Ekos::CameraProcess::prepareJobExecution | ( | ) |
preparePreCaptureActions Trigger setting the filter, temperature, (if existing) the rotator angle and let the activeJob execute the preparation actions before a capture may take place (
- See also
- SequenceJob::prepareCapture()).
After triggering the settings, this method returns. This mechanism is slightly tricky, since it asynchronous and event based and works as collaboration between Capture and SequenceJob. Capture has the connection to devices and SequenceJob knows the target values.
Each time Capture receives an updated value - e.g. the current CCD temperature (
- See also
- updateCCDTemperature()) - it informs the activeJob about the current CCD temperature. SequenceJob checks, if it has reached the target value and if yes, sets this action as as completed.
As soon as all actions are completed, SequenceJob emits a prepareComplete() event, which triggers executeJob() from the CameraProcess.
Definition at line 748 of file cameraprocess.cpp.
◆ previewImageCompletedAction()
IPState Ekos::CameraProcess::previewImageCompletedAction | ( | ) |
previewImageCompletedAction Activities required when a preview image has been captured.
- Returns
- IPS_OK if a preview has been completed, IPS_IDLE otherwise
Definition at line 1714 of file cameraprocess.cpp.
◆ processCaptureError()
void Ekos::CameraProcess::processCaptureError | ( | ISD::Camera::ErrorType | type | ) |
processCaptureError Handle when image capture fails
- Parameters
-
type error type
Definition at line 2157 of file cameraprocess.cpp.
◆ processCaptureTimeout()
void Ekos::CameraProcess::processCaptureTimeout | ( | ) |
processCaptureTimeout If exposure timed out, let's handle it.
Definition at line 2090 of file cameraprocess.cpp.
◆ processFITSData()
void Ekos::CameraProcess::processFITSData | ( | const QSharedPointer< FITSData > & | data, |
const QString & | extension ) |
newFITS process new FITS data received from camera.
Update status of active job and overall sequence.
Manage the capture process after a captured image has been successfully downloaded from the camera:
- stop timers for timeout and download progress
- update the download time calculation
- update captured frames counters ({
- See also
- updateCompletedCaptureCountersAction()})
- check flat calibration (for flats only)
- execute the post capture script (if existing)
- resume the sequence ({
- See also
- resumeSequence()})
- Parameters
-
data pointer to blob containing FITS data extension defining the file type
Definition at line 1060 of file cameraprocess.cpp.
◆ processJobCompletion1()
void Ekos::CameraProcess::processJobCompletion1 | ( | ) |
processJobCompletionStage1 Process job completion.
In stage 1 when simply check if the is a post-job script to be running if yes, we run it and wait until it is done before we move to stage2
Definition at line 1350 of file cameraprocess.cpp.
◆ processJobCompletion2()
void Ekos::CameraProcess::processJobCompletion2 | ( | ) |
processJobCompletionStage2 Stop execution of the current sequence and check whether there exists a next sequence and start it, if there is a next one to be started (
- See also
- resumeSequence()).
Definition at line 1366 of file cameraprocess.cpp.
◆ processNewRemoteFile()
void Ekos::CameraProcess::processNewRemoteFile | ( | QString | file | ) |
setNewRemoteFile A new image has been stored as remote file
- Parameters
-
file local file path
Definition at line 1275 of file cameraprocess.cpp.
◆ processPreCaptureCalibrationStage()
IPState Ekos::CameraProcess::processPreCaptureCalibrationStage | ( | ) |
processPreCaptureCalibrationStage Execute the tasks that need to be completed before capturing may start.
For light frames, checkLightFramePendingTasks() is called.
- Returns
- IPS_OK if all necessary tasks have been completed
Definition at line 1287 of file cameraprocess.cpp.
◆ reconnectCameraDriver()
void Ekos::CameraProcess::reconnectCameraDriver | ( | const QString & | camera, |
const QString & | filterWheel ) |
reconnectDriver Reconnect the camera driver
Definition at line 1987 of file cameraprocess.cpp.
◆ refreshOpticalTrain()
void Ekos::CameraProcess::refreshOpticalTrain | ( | QString | name | ) |
refreshOpticalTrain Refresh the devices from the optical train configuration
- Parameters
-
name name of the optical train configuration
Definition at line 770 of file cameraprocess.cpp.
◆ removeDevice()
void Ekos::CameraProcess::removeDevice | ( | const QSharedPointer< ISD::GenericDevice > & | device | ) |
Generic method for removing any connected device.
Definition at line 2014 of file cameraprocess.cpp.
◆ resetFrame()
void Ekos::CameraProcess::resetFrame | ( | ) |
resetFrame Reset frame settings of the camera
Definition at line 1571 of file cameraprocess.cpp.
◆ restartCamera()
void Ekos::CameraProcess::restartCamera | ( | const QString & | name | ) |
restartCamera Restarts the INDI driver associated with a camera.
Remote and Local drivers are supported.
- Parameters
-
name Name of camera to restart. If a driver defined multiple cameras, they would be removed and added again after driver restart.
- Note
- Restarting camera should only be used as a last resort when it comes completely unresponsive. Due the complex nature of driver interactions with Ekos, restarting cameras can lead to unexpected behavior.
Definition at line 2893 of file cameraprocess.cpp.
◆ resumeSequence()
IPState Ekos::CameraProcess::resumeSequence | ( | ) |
resumeSequence Try to continue capturing.
Take the active job, if there is one, or search for the next one that is either idle or aborted. If a new job is selected, call startNextJob() to prepare it. If the current job is still active, initiate checkNextExposure().
- Returns
- IPS_OK if there is a job that may be continued, IPS_BUSY otherwise.
Definition at line 944 of file cameraprocess.cpp.
◆ runCaptureScript()
IPState Ekos::CameraProcess::runCaptureScript | ( | ScriptTypes | scriptType, |
bool | precond = true ) |
runCaptureScript Run the pre-/post capture/job script
- Parameters
-
scriptType script type (pre-/post capture/job) precond additional pre condition for starting the script
- Returns
- IPS_BUSY, of script exists, IPS_OK otherwise
Definition at line 1846 of file cameraprocess.cpp.
◆ saveSequenceQueue()
bool Ekos::CameraProcess::saveSequenceQueue | ( | const QString & | path, |
bool | loadOptions = true ) |
Saves the Sequence Queue to the Ekos Sequence Queue file.
- Parameters
-
fileURL full URL of the filename
Definition at line 2660 of file cameraprocess.cpp.
◆ scriptFinished()
void Ekos::CameraProcess::scriptFinished | ( | int | exitCode, |
QProcess::ExitStatus | status ) |
scriptFinished Slot managing the return status of pre/post capture/job scripts
Definition at line 1864 of file cameraprocess.cpp.
◆ selectCamera()
void Ekos::CameraProcess::selectCamera | ( | QString | name | ) |
setCamera select camera device
- Parameters
-
name Name of the camera device
Definition at line 1917 of file cameraprocess.cpp.
◆ setCamera() [1/2]
void Ekos::CameraProcess::setCamera | ( | bool | connection | ) |
Connect or disconnect the camera device.
- Parameters
-
connection flag if connect (=true) or disconnect (=false)
Definition at line 2667 of file cameraprocess.cpp.
◆ setCamera() [2/2]
bool Ekos::CameraProcess::setCamera | ( | ISD::Camera * | device | ) |
setCamera Connect to the given camera device (and deconnect the old one if existing)
- Parameters
-
device pointer to camera INDI device.
- Returns
- True if added successfully, false if duplicate or failed to add.
Definition at line 168 of file cameraprocess.cpp.
◆ setCoolerControl()
bool Ekos::CameraProcess::setCoolerControl | ( | bool | enable | ) |
Set the CCD cooler ON/OFF.
Definition at line 2885 of file cameraprocess.cpp.
◆ setDome()
bool Ekos::CameraProcess::setDome | ( | ISD::Dome * | device | ) |
setDome Connect to the given dome device
- Parameters
-
device point to dome INDI device
- Returns
- True if added successfully, false if duplicate or failed to add.
Definition at line 158 of file cameraprocess.cpp.
◆ setDownloadProgress()
void Ekos::CameraProcess::setDownloadProgress | ( | ) |
setDownloadProgress update the Capture Module and Summary Screen's estimate of how much time is left in the download
Definition at line 1655 of file cameraprocess.cpp.
◆ setDustCap()
bool Ekos::CameraProcess::setDustCap | ( | ISD::DustCap * | device | ) |
setDustCap Connect to the given dust cap device (and deconnect the old one if existing)
- Parameters
-
device pointer to dust cap INDI device
- Returns
- True if added successfully, false if duplicate or failed to add.
Definition at line 134 of file cameraprocess.cpp.
◆ setExposureProgress()
void Ekos::CameraProcess::setExposureProgress | ( | ISD::CameraChip * | tChip, |
double | value, | ||
IPState | state ) |
setExposureProgress Manage exposure progress reported by the camera device.
Definition at line 1581 of file cameraprocess.cpp.
◆ setFilterWheel()
bool Ekos::CameraProcess::setFilterWheel | ( | ISD::FilterWheel * | device | ) |
setFilterWheel Connect to the given filter wheel device (and deconnect the old one if existing)
- Parameters
-
device pointer to filter wheel INDI device.
- Returns
- True if added successfully, false if duplicate or failed to add.
Definition at line 2695 of file cameraprocess.cpp.
◆ setLightBox()
bool Ekos::CameraProcess::setLightBox | ( | ISD::LightBox * | device | ) |
setLightBox Connect to the given dust cap device (and deconnect the old one if existing)
- Parameters
-
device pointer to light box INDI device.
- Returns
- True if added successfully, false if duplicate or failed to add.
Definition at line 147 of file cameraprocess.cpp.
◆ setMount()
bool Ekos::CameraProcess::setMount | ( | ISD::Mount * | device | ) |
setMount Connect to the given mount device (and deconnect the old one if existing)
- Parameters
-
device pointer to Mount device.
- Returns
- True if added successfully, false if duplicate or failed to add.
Definition at line 84 of file cameraprocess.cpp.
◆ setRotator()
bool Ekos::CameraProcess::setRotator | ( | ISD::Rotator * | device | ) |
setRotator Connect to the given rotator device (and deconnect the old one if existing)
- Parameters
-
device pointer to rotator INDI device
- Returns
- True if added successfully, false if duplicate or failed to add.
Definition at line 107 of file cameraprocess.cpp.
◆ setScope()
|
inline |
setScope Set active train telescope name
- Parameters
-
name Name of scope
Definition at line 190 of file cameraprocess.h.
◆ showFITSPreview()
void Ekos::CameraProcess::showFITSPreview | ( | const QSharedPointer< FITSData > & | data | ) |
showFITSPreview Directly show the FITS data as preview
- Parameters
-
data pointer to blob containing FITS data
Definition at line 1268 of file cameraprocess.cpp.
◆ showVideoFrame()
void Ekos::CameraProcess::showVideoFrame | ( | INDI::Property | prop, |
int | width, | ||
int | height ) |
Definition at line 2625 of file cameraprocess.cpp.
◆ startJob()
void Ekos::CameraProcess::startJob | ( | SequenceJob * | job | ) |
startJob Start the execution of a selected sequence job:
- Initialize the state for capture preparation ({
- See also
- CameraState::initCapturePreparation()}
- Prepare the selected job ({
- See also
- prepareJob(SequenceJob *)})
- Parameters
-
job selected sequence job
Definition at line 457 of file cameraprocess.cpp.
◆ startNextExposure()
IPState Ekos::CameraProcess::startNextExposure | ( | ) |
startNextExposure Ensure that all pending preparation tasks are be completed (focusing, dithering, etc.) and start the next exposure.
Checks of pending preparations depends upon the frame type:
- For light frames, pending preparations like focusing, dithering etc. needs to be checked before each single frame capture. efore starting to capture the next light frame, checkLightFramePendingTasks() is called to check if all pending preparation tasks have been completed successfully. As soon as this is the case, the sequence timer #seqTimer is started to wait the configured delay and starts capturing the next image.
- For bias, dark and flat frames, preparation jobs are only executed when starting a sequence. Hence, for these frames we directly start the sequence timer #seqTimer.
- Returns
- IPS_OK, iff all pending preparation jobs are completed (
- See also
- checkLightFramePendingTasks()). In that case, the #seqTimer is started to wait for the configured settling delay and then capture the next image (
- Capture::captureImage). In case that a pending task aborted, IPS_IDLE is returned.
Definition at line 920 of file cameraprocess.cpp.
◆ startNextJob()
IPState Ekos::CameraProcess::startNextJob | ( | ) |
startNextJob Select the next job that is either idle or aborted and call prepareJob(*SequenceJob) to prepare its execution and resume guiding if it was suspended (and no meridian flip is running).
- Returns
- IPS_OK if a job to be executed exists, IPS_IDLE otherwise.
Definition at line 1412 of file cameraprocess.cpp.
◆ startNextPendingJob()
void Ekos::CameraProcess::startNextPendingJob | ( | ) |
startNextPendingJob Start the next pending job.
Find the next job to be executed:
- If there are already some jobs defined, {
- See also
- findNextPendingJob()} is used to find the next job to be executed.
- If the list is empty, the current settings are used to create a job instantly, which subsequently will be executed.
Definition at line 267 of file cameraprocess.cpp.
◆ stopCapturing()
void Ekos::CameraProcess::stopCapturing | ( | CaptureState | targetState | ) |
stopCapturing Stopping the entire capturing state (envelope for aborting, suspending, pausing, ...)
- Parameters
-
targetState state capturing should be having afterwards
Definition at line 334 of file cameraprocess.cpp.
◆ syncDSLRToTargetChip()
void Ekos::CameraProcess::syncDSLRToTargetChip | ( | const QString & | model | ) |
syncDSLRToTargetChip Syncs INDI driver CCD_INFO property to the DSLR values.
This include Max width, height, and pixel sizes.
- Parameters
-
model Name of camera driver in the DSLR database.
Definition at line 1967 of file cameraprocess.cpp.
◆ toggleSequence()
void Ekos::CameraProcess::toggleSequence | ( | ) |
toggleSequence Toggle sequence state depending on its current state.
- If paused, then resume sequence.
- If idle or completed, then start sequence.
- Otherwise, abort current sequence.
Definition at line 233 of file cameraprocess.cpp.
◆ toggleVideo()
void Ekos::CameraProcess::toggleVideo | ( | bool | enabled | ) |
Toggle video streaming if supported by the device.
- Parameters
-
enabled Set to true to start video streaming, false to stop it if active.
Definition at line 195 of file cameraprocess.cpp.
◆ updateCompletedCaptureCountersAction()
void Ekos::CameraProcess::updateCompletedCaptureCountersAction | ( | ) |
updateCompletedCaptureCounters Update counters if an image has been captured
Definition at line 1732 of file cameraprocess.cpp.
◆ updateDownloadTimesAction()
IPState Ekos::CameraProcess::updateDownloadTimesAction | ( | ) |
updateDownloadTimesAction Add the current download time to the list of already measured ones
Definition at line 1694 of file cameraprocess.cpp.
◆ updateFilterInfo()
void Ekos::CameraProcess::updateFilterInfo | ( | ) |
updateFilterInfo Update the filter information in the INDI drivers of the current camera and dust cap
Definition at line 2449 of file cameraprocess.cpp.
◆ updateFITSViewer() [1/2]
void Ekos::CameraProcess::updateFITSViewer | ( | const QSharedPointer< FITSData > | data, |
const FITSMode & | captureMode, | ||
const FITSScale & | captureFilter, | ||
const QString & | filename, | ||
const QString & | deviceName ) |
updateFITSViewer display new image in the configured FITSViewer tab.
Definition at line 2516 of file cameraprocess.cpp.
◆ updateFITSViewer() [2/2]
void Ekos::CameraProcess::updateFITSViewer | ( | const QSharedPointer< FITSData > | data, |
ISD::CameraChip * | tChip, | ||
const QString & | filename ) |
Definition at line 2582 of file cameraprocess.cpp.
◆ updateGain()
void Ekos::CameraProcess::updateGain | ( | double | value, |
QMap< QString, QMap< QString, QVariant > > & | propertyMap ) |
getGain Update the gain value from the custom property value.
Depending on the camera, it is either stored as GAIN property value of CCD_GAIN or as Gain property value from CCD_CONTROLS.
Definition at line 2932 of file cameraprocess.cpp.
◆ updateImageMetadataAction()
IPState Ekos::CameraProcess::updateImageMetadataAction | ( | QSharedPointer< FITSData > | imageData | ) |
updateImageMetadataAction Update meta data of a captured image
Definition at line 1779 of file cameraprocess.cpp.
◆ updateOffset()
void Ekos::CameraProcess::updateOffset | ( | double | value, |
QMap< QString, QMap< QString, QVariant > > & | propertyMap ) |
getOffset Update the offset value from the custom property value.
Depending on the camera, it is either stored as OFFSET property value of CCD_OFFSET or as Offset property value from CCD_CONTROLS.
Definition at line 2966 of file cameraprocess.cpp.
◆ updatePreCaptureCalibrationStatus()
void Ekos::CameraProcess::updatePreCaptureCalibrationStatus | ( | ) |
updatePreCaptureCalibrationStatus This is a wrapping loop for processPreCaptureCalibrationStage(), which contains all checks before captureImage() may be called.
If processPreCaptureCalibrationStage() returns IPS_OK (i.e. everything is ready so that capturing may be started), captureImage() is called. Otherwise, it waits for a second and calls itself again.
Definition at line 1328 of file cameraprocess.cpp.
◆ updateTelescopeInfo()
void Ekos::CameraProcess::updateTelescopeInfo | ( | ) |
updateTelescopeInfo Update the scope information in the camera's INDI driver.
Definition at line 2430 of file cameraprocess.cpp.
◆ updateVideoWindow()
void Ekos::CameraProcess::updateVideoWindow | ( | int | width, |
int | height, | ||
bool | streamEnabled ) |
Definition at line 2608 of file cameraprocess.cpp.
The documentation for this class was generated from the following files:
Documentation copyright © 1996-2025 The KDE developers.
Generated on Fri Jan 3 2025 11:47:17 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006
KDE's Doxygen guidelines are available online.