1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
|
/*
LX200 Basic 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 LX200BASIC_H
#define LX200BASIC_H
#include "indidevapi.h"
#include "indicom.h"
class LX200Basic
{
public:
LX200Basic();
~LX200Basic();
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 connection_lost();
void connection_resumed();
private:
enum LX200_STATUS { LX200_SLEW, LX200_TRACK, LX200_SYNC, LX200_PARK };
/* Switches */
ISwitch ConnectS[2];
ISwitch OnCoordSetS[3];
ISwitch AbortSlewS[1];
/* Texts */
IText PortT[1];
IText ObjectT[1];
/* Numbers */
INumber EquatorialCoordsRN[2];
INumber EquatorialCoordsWN[2];
INumber SlewAccuracyN[2];
INumber TrackAccuracyN[2];
/* Switch Vectors */
ISwitchVectorProperty ConnectSP;
ISwitchVectorProperty OnCoordSetSP;
ISwitchVectorProperty AbortSlewSP;
/* Number Vectors */
INumberVectorProperty EquatorialCoordsRNP;
INumberVectorProperty EquatorialCoordsWNP;
INumberVectorProperty SlewAccuracyNP;
INumberVectorProperty TrackAccuracyNP;
/* Text Vectors */
ITextVectorProperty PortTP;
ITextVectorProperty ObjectTP;
/*******************************************************/
/* Connection Routines
********************************************************/
void init_properties();
void get_initial_data();
void connect_telescope();
bool is_connected(void);
/*******************************************************/
/* Misc routines
********************************************************/
bool process_coords();
int get_switch_index(ISwitchVectorProperty *sp);
/*******************************************************/
/* Simulation Routines
********************************************************/
void enable_simulation(bool enable);
/*******************************************************/
/* Error handling routines
********************************************************/
void slew_error(int slewCode);
void reset_all_properties();
void handle_error(INumberVectorProperty *nvp, int err, const char *msg);
void correct_fault();
protected:
double JD; /* Julian Date */
double lastRA;
double lastDEC;
bool simulation;
bool fault;
int fd; /* Telescope tty file descriptor */
int currentSet;
int lastSet;
};
#endif
|