File: wxGuiderFileInterface.cpp

package info (click to toggle)
wxastrocapture 1.8.1%2Bgit20140821.796e1a1%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 42,212 kB
  • sloc: cpp: 43,421; sh: 733; perl: 246; makefile: 14
file content (82 lines) | stat: -rw-r--r-- 1,965 bytes parent folder | download | duplicates (4)
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
#include "wxGuiderFileInterface.h"
#include "wxGuidingConfig.h"

#include <time.h>
#include <math.h>



wxGuiderFileInterface::wxGuiderFileInterface()
: m_xdat(0)
, m_ydat(0)
{
   //ctor
}

wxGuiderFileInterface::~wxGuiderFileInterface()
{
   guideEnd();
}


bool wxGuiderFileInterface::guideStart()
{
   guideEnd();

   wxString path = wxGuidingConfig::getFileInterfacePath();
   wxChar last = path.Last();

   // check the last character
   if((last != '\\') && (last != '/'))path += '/';

   wxString xpath = path + wxT("X.DAT");
   wxString ypath = path + wxT("Y.DAT");
   m_xdat = new ofstream(xpath.char_str());
   m_ydat = new ofstream(ypath.char_str());

   if(m_xdat && m_ydat){
      set_guiding_active(true);
      return true;
   }
   return false;
}

bool wxGuiderFileInterface::guideError(unsigned long timestamp  // (in)  Time stamp   [ms]
                                      ,double ra                // (in)  Error in RA  [arcseconds]
                                      ,double dec               // (in)  Error in DEC [arcseconds]
                                      )
{
   if(m_xdat && m_ydat) {
      //CA:20090412 - reports now ms
      double seconds=(double)timestamp/1000.0;

      wxString xf,yf;
      xf.Printf(wxT(" %8.2f  %8.2f"),seconds, ra);
      yf.Printf(wxT(" %8.2f  %8.2f"),seconds,dec);

      // rewind x.dat and write new line
      m_xdat->seekp (0, ios::beg);
      (*m_xdat) << xf.char_str() << endl;

      // rewind y.dat and write new line
      m_ydat->seekp (0, ios::beg);
      (*m_ydat) << yf.char_str() << endl;

      return true;
   }
   return false;
}

// end a guiding sequence
bool wxGuiderFileInterface::guideEnd()
{
   delete m_xdat; m_xdat = 0;
   delete m_ydat; m_ydat = 0;
   set_guiding_active(false);
   return true;
}

wxGuider::guider_interface wxGuiderFileInterface::interface_type()
{
   return FILE_INTERFACE;
}