9#include "sequencejobstate.h"
11#include <QTableWidgetItem>
25class CaptureDeviceAdaptor;
32 static QString const &ISOMarker;
39 SJ_EnforceTemperature,
81 SJ_RemoteFormatDirectory,
83 SJ_RemoteFormatFilename,
89 SJ_TargetADUTolerance,
93 SJ_DitherPerJobFrequency,
110 SequenceJobType jobType, XMLEle *root =
nullptr,
QString targetName =
"");
129 void startCapturing(
bool autofocusReady, FITSMode mode);
135 void capture(FITSMode mode);
142 void setCoreProperty(PropertyID
id,
const QVariant &value);
143 QVariant getCoreProperty(PropertyID
id)
const;
148 const QString &getStatusString()
150 return StatusStrings()[getStatus()];
153 void setCompleted(
int value)
158 int getCompleted()
const
163 void setExposeLeft(
double value);
165 double getExposeLeft()
const;
167 void resetStatus(JOBStatus status = JOB_IDLE);
169 void setCaptureRetires(
int value);
171 int getCaptureRetires()
const;
174 int getJobRemainingTime(
double estimatedDownloadTime);
180 void connectDeviceAdaptor();
182 void disconnectDeviceAdaptor();
184 void setTargetFilter(
int pos,
const QString &name);
186 int getCurrentFilter()
const;
188 ISD::Mount::PierSide getPierSide()
const;
194 SequenceJobType jobType()
const
198 void setJobType(SequenceJobType newJobType)
200 m_jobType = newJobType;
204 return (getCoreProperty(SJ_Signature).toString()).
remove(
".fits");
215 const QString getScript(ScriptTypes type)
const
217 return m_Scripts[type];
219 void setScript(ScriptTypes type,
const QString &value)
221 m_Scripts[type] = value;
225 void setISO(
int index);
230 return m_CustomProperties;
234 m_CustomProperties = value;
240 return m_CoreProperties;
246 const QVariant getRemoteDirectory()
const;
249 void setUploadMode(ISD::Camera::UploadMode value);
251 ISD::Camera::UploadMode getUploadMode()
const;
254 void setCalibrationPreAction(uint32_t value);
256 uint32_t getCalibrationPreAction()
const;
259 void setWallCoord(
const SkyPoint &value);
261 const SkyPoint &getWallCoord()
const;
264 void setFlatFieldDuration(FlatFieldDuration value);
266 FlatFieldDuration getFlatFieldDuration()
const;
269 void setJobProgressIgnored(
bool value);
270 bool getJobProgressIgnored()
const;
276 void updateDeviceStates();
304 JOBStatus getStatus()
306 return state->getStatus();
309 void setFrameType(CCDFrameType value)
311 state->setFrameType(value);
313 CCDFrameType getFrameType()
const
315 return state->getFrameType();
320 return state->getFrameType() == FRAME_VIDEO;
323 int getTargetFilter()
const
325 return state->targetFilterID;
328 double getTargetTemperature()
const
330 return state->targetTemperature;
332 void setTargetTemperature(
double value)
334 state->targetTemperature = value;
337 void setFocusStatus(FocusState value)
339 state->setFocusStatus(value);
342 double getTargetRotation()
const
344 return state->targetPositionAngle;
346 void setTargetRotation(
double value)
348 state->targetPositionAngle = value;
351 SequenceJobState::CalibrationStage getCalibrationStage()
const
353 return state->calibrationStage;
355 void setCalibrationStage(SequenceJobState::CalibrationStage value)
357 state->calibrationStage = value;
360 SequenceJobState::PreparationState getPreparationState()
const
362 return state->m_PreparationState;
364 void setPreparationState(SequenceJobState::PreparationState value)
366 state->m_PreparationState = value;
369 bool getAutoFocusReady()
const
371 return state->autoFocusReady;
373 void setAutoFocusReady(
bool value)
375 state->autoFocusReady = value;
383 void prepareCapture();
388 void processPrepareComplete(
bool success =
true);
392 void processAbortCapture();
400 IPState checkFlatFramePendingTasksCompleted();
403 double currentTemperature()
const;
404 double currentGain()
const;
405 double currentOffset()
const;
408 void loadFrom(XMLEle *root,
const QString &targetName, SequenceJobType jobType);
412 void prepareComplete(
bool success =
true);
414 void captureStarted(CaptureResult rc);
420 void prepareState(CaptureState state);
422 void prepareCapture(CCDFrameType frameType,
bool enforceCCDTemp,
bool enforceStartGuiderDrift,
bool isPreview);
424 void updateGuiderDrift(
double deviation_rms);
433 SequenceJobType m_jobType;
435 void setStatus(JOBStatus
const);
448 FlatFieldDuration m_FlatFieldDuration { DURATION_MANUAL };
452 ISD::Camera::UploadMode m_UploadMode { ISD::Camera::UPLOAD_CLIENT };
454 QString m_TransferFormat {
"FITS" };
459 int m_CaptureRetires { 0 };
460 uint32_t m_Completed { 0 };
461 double m_ExposeLeft { 0 };
462 bool m_JobProgressIgnored {
false};
479 QString setCameraDeviceProperties();
Class handles control of INDI dome devices.
Handles operation of a remotely controlled dust cover cap.
Handles operation of a remotely controlled light box.
device handle controlling Mounts.
Sequence Job is a container for the details required to capture a series of images.
The sky coordinates of a point in the sky.
Ekos is an advanced Astrophotography tool for Linux.
QString & remove(QChar ch, Qt::CaseSensitivity cs)