Kstars

sequencejob.h
1/*
2 SPDX-FileCopyrightText: 2012 Jasem Mutlaq <mutlaqja@ikarustech.com>
3
4 SPDX-License-Identifier: GPL-2.0-or-later
5*/
6
7#pragma once
8
9#include "sequencejobstate.h"
10
11#include <QTableWidgetItem>
12
13class SkyPoint;
14
15/**
16 * @class SequenceJob
17 * @short Sequence Job is a container for the details required to capture a series of images.
18 *
19 * @author Jasem Mutlaq
20 * @version 1.0
21 */
22namespace Ekos
23{
24
25class CaptureDeviceAdaptor;
26
27class SequenceJob : public QObject
28{
30
31 public:
32 static QString const &ISOMarker;
33 static const QStringList StatusStrings();
34
35 // Core Properties
36 typedef enum
37 {
38 // Bool
39 SJ_EnforceTemperature,
40 // Bool
41 // SJ_EnforceStartGuiderDrift, // no specific option
42 // Bool
43 SJ_GuiderActive,
44 // Double
45 SJ_Exposure,
46 // QString
47 SJ_Filter,
48 // QString
49 SJ_Format,
50 // QString
51 SJ_Encoding,
52 // QPoint
53 SJ_Binning,
54 // QRect
55 SJ_ROI,
56 // QString
57 SJ_FullPrefix,
58 // Int
59 SJ_Count,
60 // Int
61 SJ_Delay,
62 // QString
63 SJ_ISO,
64 // Int
65 SJ_ISOIndex,
66 // Double
67 SJ_Gain,
68 // Double
69 SJ_Offset,
70 // QString
71 SJ_TargetName,
72 //QString
73 SJ_LocalDirectory,
74 // QString
75 SJ_PlaceholderFormat,
76 // Uint
77 SJ_PlaceholderSuffix,
78 // QString
79 SJ_RemoteDirectory,
80 // QString
81 SJ_RemoteFormatDirectory,
82 // QString
83 SJ_RemoteFormatFilename,
84 // QString
85 SJ_Filename,
86 // Double
87 SJ_TargetADU,
88 // Double
89 SJ_TargetADUTolerance,
90 // QString
91 SJ_Signature,
92 // Int
93 SJ_DitherPerJobFrequency,
94 // Bool
95 SJ_SkyFlat
96 } PropertyID;
97
98 typedef enum
99 {
100 JOBTYPE_BATCH, /* regular batch job */
101 JOBTYPE_PREVIEW, /* previews (single or looping) */
102 JOBTYPE_DARKFLAT /* capturing dark flats */
103 } SequenceJobType;
104
105 ////////////////////////////////////////////////////////////////////////
106 /// Constructors
107 ////////////////////////////////////////////////////////////////////////
109 const QSharedPointer<CameraState> sharedState,
110 SequenceJobType jobType, XMLEle *root = nullptr, QString targetName = "");
111 SequenceJob(XMLEle *root, QString targetName);
112 ~SequenceJob() = default;
113
114 ////////////////////////////////////////////////////////////////////////
115 /// Capture Fuctions
116 ////////////////////////////////////////////////////////////////////////
117 /**
118 * @brief startCapturing Initialize the camera and start capturing
119 *
120 * This step calls {@see SequenceJobState::initCapture()}, which triggers
121 * all actions before the camera may start to capture. If the initialization
122 * is completed, the sequence job state machine sends the signal
123 * {@see SequenceJobState::initCaptureComplete()} which will trigger the
124 * camera device to finally start capturing ({@see capture()}).
125 *
126 * @param autofocusReady was there a successful focus run previously?
127 * @param mode what is the purpose of capturing?
128 */
129 void startCapturing(bool autofocusReady, FITSMode mode);
130 /**
131 * @brief capture As soon as everything is ready for the camera to start
132 * capturing, this method triggers the camera device to start capturing.
133 * @param mode what is the purpose of capturing?
134 */
135 void capture(FITSMode mode);
136 void abort();
137 void done();
138
139 ////////////////////////////////////////////////////////////////////////
140 /// Core Properties
141 ////////////////////////////////////////////////////////////////////////
142 void setCoreProperty(PropertyID id, const QVariant &value);
143 QVariant getCoreProperty(PropertyID id) const;
144
145 ////////////////////////////////////////////////////////////////////////
146 /// Job Status Functions
147 ////////////////////////////////////////////////////////////////////////
148 const QString &getStatusString()
149 {
150 return StatusStrings()[getStatus()];
151 }
152 // Setter: Set how many captures have completed thus far
153 void setCompleted(int value)
154 {
155 m_Completed = value;
156 }
157 // Getter: How many captured have completed thus far.
158 int getCompleted() const
159 {
160 return m_Completed;
161 }
162 // Setter: Set how many more seconds to expose in this job
163 void setExposeLeft(double value);
164 // Getter: Get how many more seconds are left to expose.
165 double getExposeLeft() const;
166 // Reset: Reset the job status
167 void resetStatus(JOBStatus status = JOB_IDLE);
168 // Setter: Set how many times we re-try this job.
169 void setCaptureRetires(int value);
170 // Getter: Get many timed we retried this job already.
171 int getCaptureRetires() const;
172 // Getter: How many more seconds are remaining in this job given the
173 // estimated download time.
174 int getJobRemainingTime(double estimatedDownloadTime);
175
176 ////////////////////////////////////////////////////////////////////////
177 /// State Machine Functions
178 ////////////////////////////////////////////////////////////////////////
179 // Create all event connections between the state machine and the command processor
180 void connectDeviceAdaptor();
181 // Disconnect all event connections between the state machine and the command processor
182 void disconnectDeviceAdaptor();
183 // Setter: Set Target Filter Name
184 void setTargetFilter(int pos, const QString &name);
185 // Getter: Get Current Filter Slot
186 int getCurrentFilter() const;
187 // Retrieve the pier side from the state
188 ISD::Mount::PierSide getPierSide() const;
189
190 ////////////////////////////////////////////////////////////////////////
191 /// Job Attribute Functions
192 ////////////////////////////////////////////////////////////////////////
193 // job type
194 SequenceJobType jobType() const
195 {
196 return m_jobType;
197 }
198 void setJobType(SequenceJobType newJobType)
199 {
200 m_jobType = newJobType;
201 }
202 QString getSignature()
203 {
204 return (getCoreProperty(SJ_Signature).toString()).remove(".fits");
205 }
206 // Scripts
207 const QMap<ScriptTypes, QString> &getScripts() const
208 {
209 return m_Scripts;
210 }
211 void setScripts(const QMap<ScriptTypes, QString> &scripts)
212 {
213 m_Scripts = scripts;
214 }
215 const QString getScript(ScriptTypes type) const
216 {
217 return m_Scripts[type];
218 }
219 void setScript(ScriptTypes type, const QString &value)
220 {
221 m_Scripts[type] = value;
222 }
223
224 // helper function setting both ISO index and ISO value
225 void setISO(int index);
226
227 // Custom Properties
228 const QMap<QString, QMap<QString, QVariant> > getCustomProperties() const
229 {
230 return m_CustomProperties;
231 }
232 void setCustomProperties(const QMap<QString, QMap<QString, QVariant> > &value)
233 {
234 m_CustomProperties = value;
235 }
236
237 // Core Properties
238 const QMap<PropertyID, QVariant> &getCoreProperties() const
239 {
240 return m_CoreProperties;
241 }
242
243 /**
244 * @brief Retrieve remote directory or, if empty, use the local directory value
245 */
246 const QVariant getRemoteDirectory() const;
247
248 // Setter: Set upload mode
249 void setUploadMode(ISD::Camera::UploadMode value);
250 // Getter: get upload mode
251 ISD::Camera::UploadMode getUploadMode() const;
252
253 // Setter: Set flat field source
254 void setCalibrationPreAction(uint32_t value);
255 // Getter: Get flat field source
256 uint32_t getCalibrationPreAction() const;
257
258 // Setter: Set Wall SkyPoint Azimuth coords
259 void setWallCoord(const SkyPoint &value);
260 // Getter: Get Flat field source wall coords
261 const SkyPoint &getWallCoord() const;
262
263 // Setter: Set flat field duration
264 void setFlatFieldDuration(FlatFieldDuration value);
265 // Getter: Get flat field duration
266 FlatFieldDuration getFlatFieldDuration() const;
267
268 // Setter: Set job progress ignored flag
269 void setJobProgressIgnored(bool value);
270 bool getJobProgressIgnored() const;
271
272 /**
273 * @brief updateDeviceStates Update for all used device types whether there
274 * is one connected.
275 */
276 void updateDeviceStates();
277 /**
278 * @brief Set the light box device
279 */
280 void setLightBox(ISD::LightBox *lightBox);
281
282 /**
283 * @brief Set the dust cap device
284 */
285 void setDustCap(ISD::DustCap *dustCap);
286
287 /**
288 * @brief Set the telescope device
289 */
290 void addMount(ISD::Mount *scope);
291
292 /**
293 * @brief Set the dome device
294 */
295 void setDome(ISD::Dome *dome);
296
297
298 // ////////////////////////////////////////////////////////////////////////////
299 // Facade to state machine
300 // ////////////////////////////////////////////////////////////////////////////
301 /**
302 * @brief Retrieve the current status of the capture sequence job from the state machine
303 */
304 JOBStatus getStatus()
305 {
306 return state->getStatus();
307 }
308
309 void setFrameType(CCDFrameType value)
310 {
311 state->setFrameType(value);
312 }
313 CCDFrameType getFrameType() const
314 {
315 return state->getFrameType();
316 }
317
318 bool isVideo() const
319 {
320 return state->getFrameType() == FRAME_VIDEO;
321 }
322
323 int getTargetFilter() const
324 {
325 return state->targetFilterID;
326 }
327
328 double getTargetTemperature() const
329 {
330 return state->targetTemperature;
331 }
332 void setTargetTemperature(double value)
333 {
334 state->targetTemperature = value;
335 }
336
337 void setFocusStatus(FocusState value)
338 {
339 state->setFocusStatus(value);
340 }
341
342 double getTargetRotation() const
343 {
344 return state->targetPositionAngle;
345 }
346 void setTargetRotation(double value)
347 {
348 state->targetPositionAngle = value;
349 }
350
351 SequenceJobState::CalibrationStage getCalibrationStage() const
352 {
353 return state->calibrationStage;
354 }
355 void setCalibrationStage(SequenceJobState::CalibrationStage value)
356 {
357 state->calibrationStage = value;
358 }
359
360 SequenceJobState::PreparationState getPreparationState() const
361 {
362 return state->m_PreparationState;
363 }
364 void setPreparationState(SequenceJobState::PreparationState value)
365 {
366 state->m_PreparationState = value;
367 }
368
369 bool getAutoFocusReady() const
370 {
371 return state->autoFocusReady;
372 }
373 void setAutoFocusReady(bool value)
374 {
375 state->autoFocusReady = value;
376 }
377
378 /**
379 * @brief Central entry point to start all activities that are necessary
380 * before capturing may start. Signals {@see prepareComplete()} as soon as
381 * everything is ready.
382 */
383 void prepareCapture();
384 /**
385 * @brief processPrepareComplete All preparations necessary for capturing are completed
386 * @param success true iff preparation succeeded
387 */
388 void processPrepareComplete(bool success = true);
389 /**
390 * @brief Abort capturing
391 */
392 void processAbortCapture();
393
394 /**
395 * @brief Check if all initial tasks are completed so that capturing
396 * of flats may start.
397 * @return IPS_OK if cap is closed, IPS_BUSY if not and IPS_ALERT if the
398 * process should be aborted.
399 */
400 IPState checkFlatFramePendingTasksCompleted();
401
402 // current values
403 double currentTemperature() const;
404 double currentGain() const;
405 double currentOffset() const;
406
407 void saveTo(QTextStream &outstream, const QLocale &cLocale) const;
408 void loadFrom(XMLEle *root, const QString &targetName, SequenceJobType jobType);
409
410 signals:
411 // All preparations necessary for capturing are completed
412 void prepareComplete(bool success = true);
413 // Manage the result when capturing has been started
414 void captureStarted(CaptureResult rc);
415 // Abort capturing
416 void abortCapture();
417 // log entry
418 void newLog(QString);
419
420 void prepareState(CaptureState state);
421 // signals to be forwarded to the state machine
422 void prepareCapture(CCDFrameType frameType, bool enforceCCDTemp, bool enforceStartGuiderDrift, bool isPreview);
423 // update the current guiding deviation
424 void updateGuiderDrift(double deviation_rms);
425
426private:
427 /**
428 * @brief init Initialize the sequence job from its XML representation
429 */
430 void init(SequenceJobType jobType, XMLEle *root, QSharedPointer<CameraState> sharedState, const QString &targetName);
431
432 // job type (batch, preview, ...)
433 SequenceJobType m_jobType;
434
435 void setStatus(JOBStatus const);
436
437 //////////////////////////////////////////////////////////////
438 /// Custom Types
439 /// We save all core sequence properties in QVariant map
440 //////////////////////////////////////////////////////////////
441 QMap<PropertyID, QVariant> m_CoreProperties;
442
443 //////////////////////////////////////////////////////////////
444 /// Custom Types
445 /// We don't use Q_PROPERTY for these to simplify use
446 //////////////////////////////////////////////////////////////
447 QMap<QString, QMap<QString, QVariant>> m_CustomProperties;
448 FlatFieldDuration m_FlatFieldDuration { DURATION_MANUAL };
449 // Capture Scripts
451 // Upload Mode
452 ISD::Camera::UploadMode m_UploadMode { ISD::Camera::UPLOAD_CLIENT };
453 // Transfer Format
454 QString m_TransferFormat { "FITS" };
455
456 //////////////////////////////////////////////////////////////
457 /// Status Variables
458 //////////////////////////////////////////////////////////////
459 int m_CaptureRetires { 0 };
460 uint32_t m_Completed { 0 };
461 double m_ExposeLeft { 0 };
462 bool m_JobProgressIgnored {false};
463
464 //////////////////////////////////////////////////////////////
465 /// Device access
466 //////////////////////////////////////////////////////////////
467
468 /**
469 * @brief frameTypes Retrieve the frame types from the active camera's primary chip.
470 */
471 QStringList frameTypes() const;
472 /**
473 * @brief filterLabels list of currently available filter labels
474 */
475 QStringList filterLabels() const;
476 /**
477 * @brief setCameraProperties Set all camera device properties required for capturing
478 */
479 QString setCameraDeviceProperties();
480
481 //////////////////////////////////////////////////////////////
482 /// State machines encapsulating the state of this capture sequence job
483 //////////////////////////////////////////////////////////////
486};
487
488}
Class handles control of INDI dome devices.
Definition indidome.h:25
Handles operation of a remotely controlled dust cover cap.
Definition indidustcap.h:25
Handles operation of a remotely controlled light box.
device handle controlling Mounts.
Definition indimount.h:29
Sequence Job is a container for the details required to capture a series of images.
The sky coordinates of a point in the sky.
Definition skypoint.h:45
Ekos is an advanced Astrophotography tool for Linux.
Definition align.cpp:83
Q_OBJECTQ_OBJECT
QString & remove(QChar ch, Qt::CaseSensitivity cs)
This file is part of the KDE documentation.
Documentation copyright © 1996-2025 The KDE developers.
Generated on Fri Jan 3 2025 11:47:14 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.