You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdeedu/kstars/kstars/indi/apmount.h

145 lines
3.6 KiB

/*
Astro-Physics driver
Copyright (C) 2005 Jasem Mutlaq (mutlaqja@ikarustech.com)
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef ASTROPHYSICS_H
#define ASTROPHYSICS_H
#include "indidevapi.h"
#include "indicom.h"
#define POLLMS 1000 /* poll period, ms */
#define mydev "Astro-Physics" /* The device name */
/* equatorial position */
// N.B. No Static identifier as it is needed for external linkage
class APMount
{
public:
APMount();
~APMount();
void ISGetProperties (const char *dev);
void ISNewNumber (const char *dev, const char *name, double values[], char *names[], int n);
void ISNewText (const char *dev, const char *name, char *texts[], char *names[], int n);
void ISNewSwitch (const char *dev, const char *name, ISState *states, char *names[], int n);
void ISPoll ();
void connectionLost();
void connectionResumed();
private:
void initProperties();
/* Switches */
ISwitch AlignmentS [2];
ISwitch PowerS[2];
ISwitch OnCoordSetS[3];
ISwitch TrackModeS[4];
ISwitch AbortSlewS[1];
ISwitch ParkS[2];
ISwitch MovementS[4];
ISwitch FocusMotionS[2];
/* Texts */
IText PortT[1];
IText UTCT[1];
IText ObjectT[1];
/* Numbers */
INumber EqN[2];
INumber GeoN[2];
INumber FocusTimerN[1];
INumber SDTimeN[1];
INumber HorN[2];
INumber FocusSpeedN[1];
/* Switch Vectors */
ISwitchVectorProperty PowerSP;
ISwitchVectorProperty AlignmentSP;
ISwitchVectorProperty OnCoordSetSP;
ISwitchVectorProperty AbortSlewSP;
ISwitchVectorProperty ParkSP;
ISwitchVectorProperty TrackModeSP;
ISwitchVectorProperty MovementSP;
ISwitchVectorProperty FocusMotionSP;
/* Number Vectors */
INumberVectorProperty EqNP;
INumberVectorProperty GeoNP;
INumberVectorProperty FocusTimerNP;
INumberVectorProperty SDTimeNP;
INumberVectorProperty HorNP;
INumberVectorProperty FocusSpeedNP;
/* Text Vectors */
ITextVectorProperty PortTP;
ITextVectorProperty TimeTP;
ITextVectorProperty ObjectTP;
void getBasicData();
int checkPower(INumberVectorProperty *np);
int checkPower(ISwitchVectorProperty *sp);
int checkPower(ITextVectorProperty *tp);
void handleError(ISwitchVectorProperty *svp, int err, const char *msg);
void handleError(INumberVectorProperty *nvp, int err, const char *msg);
void handleError(ITextVectorProperty *tvp, int err, const char *msg);
bool isTelescopeOn(void);
void powerTelescope();
void slewError(int slewCode);
void getAlignment();
int handleCoordSet();
int getOnSwitch(ISwitchVectorProperty *sp);
void correctFault();
void enableSimulation(bool enable);
void updateTime();
void updateLocation();
protected:
int timeFormat;
int currentSiteNum;
int trackingMode;
double JD;
double targetRA;
double targetDEC;
double lastRA;
double lastDEC;
double UTCOffset;
bool fault;
bool simulation;
struct tm *localTM;
int currentSet;
int lastSet;
int lastMove[4];
};
#endif