File: navimain.h

package info (click to toggle)
rtklib 2.4.3%2Bdfsg1-2.1
  • links: PTS
  • area: main
  • in suites: bullseye
  • size: 41,796 kB
  • sloc: cpp: 51,592; ansic: 50,584; fortran: 987; makefile: 861; sh: 45
file content (247 lines) | stat: -rw-r--r-- 7,681 bytes parent folder | download | duplicates (2)
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
//---------------------------------------------------------------------------
#ifndef navimainH
#define navimainH
//---------------------------------------------------------------------------
#include <Classes.hpp>
#include <Controls.hpp>
#include <StdCtrls.hpp>
#include <Forms.hpp>
#include <ExtCtrls.hpp>
#include <Buttons.hpp>
#include <Graphics.hpp>
#include <ComCtrls.hpp>
#include <Dialogs.hpp>
#include <ImgList.hpp>
#include <Menus.hpp>

#include "rtklib.h"

#define MAXSCALE	18
#define MAXMAPPNT	10

//---------------------------------------------------------------------------
class TMainForm : public TForm
{
__published:
	TPanel *Panel1;
	TPanel *Panel2;
	TPanel *Panel3;
	TPanel *Panel11;
	
	TLabel *LabelTime;
	TLabel *Message;
	
	TPopupMenu *PopupMenu;
	TMenuItem *MenuMonitor;
	TMenuItem *MenuExpand;
	TMenuItem *N1;
	TMenuItem *MenuStart;
	TMenuItem *MenuPlot;
	TMenuItem *N2;
	TMenuItem *MenuExit;
	TMenuItem *MenuStop;
	
	TSpeedButton *BtnTimeSys;
	
	TTrayIcon *TrayIcon;
	
	TSaveDialog *SaveDialog;
	
	TImageList *ImageList;
	
	TTimer *Timer;
	TPanel *Panel4;
	TButton *BtnExit;
	TButton *BtnOpt;
	TButton *BtnPlot;
	TButton *BtnStart;
	TButton *BtnStop;
	TPanel *Panel33;
	TSpeedButton *BtnTaskTray;
	TSpeedButton *BtnAbout;
	TPanel *Panel31;
	TSpeedButton *BtnMonitor;
	TPanel *Panel32;
	TPanel *Panel12;
	TImage *Image1;
	TImage *Image2;
	TPanel *Str1;
	TPanel *Str2;
	TPanel *Str3;
	TPanel *Str4;
	TPanel *Str5;
	TPanel *Str6;
	TPanel *Str7;
	TPanel *Str8;
	TPanel *Svr;
	TPanel *Panel13;
	TPanel *Panel131;
	TSpeedButton *BtnOutputStr;
	TPanel *Panel132;
	TSpeedButton *BtnLogStr;
	TPanel *Panel121;
	TSpeedButton *BtnInputStr;
	TPanel *Panel21;
	TPanel *Panel211;
	TLabel *LabelNSat;
	TLabel *LabelStd;
	TLabel *Plabel1;
	TLabel *Plabel2;
	TLabel *Plabel3;
	TLabel *PlabelA;
	TLabel *Pos1;
	TLabel *Pos2;
	TLabel *Pos3;
	TLabel *Solution;
	TPanel *IndSol;
	TPanel *Panel213;
	TScrollBar *ScbSol;
	TButton *BtnSave;
	TPanel *Panel212;
	TLabel *Plabel0;
	TSplitter *Splitter1;
	TPanel *Panel221;
	TImage *Plot1;
	TSpeedButton *BtnFreqType1;
	TSplitter *Splitter2;
	TPanel *Panel222;
	TImage *Disp2;
	TImage *Plot2;
	TSpeedButton *BtnFreqType2;
	TImage *Disp1;
	TSpeedButton *BtnSolType;
	TSpeedButton *BtnPlotType1;
	TSpeedButton *BtnPlotType2;
	TSpeedButton *BtnPanel;
	TPanel *Pane6;
	TPanel *Panel22;
	TPanel *Panel5;
	TPanel *IndQ;
	TLabel *SolS;
	TLabel *SolQ;
	TSpeedButton *BtnSolType2;
	
	void __fastcall FormCreate        (TObject *Sender);
	void __fastcall FormShow          (TObject *Sender);
	void __fastcall FormClose         (TObject *Sender, TCloseAction &Action);
	
	void __fastcall TimerTimer        (TObject *Sender);
	
	void __fastcall BtnStartClick     (TObject *Sender);
	void __fastcall BtnStopClick      (TObject *Sender);
	void __fastcall BtnPlotClick      (TObject *Sender);
	void __fastcall BtnOptClick       (TObject *Sender);
	void __fastcall BtnExitClick      (TObject *Sender);
	
	void __fastcall BtnTimeSysClick   (TObject *Sender);
	void __fastcall BtnInputStrClick  (TObject *Sender);
	void __fastcall BtnOutputStrClick (TObject *Sender);
	void __fastcall BtnLogStrClick    (TObject *Sender);
	void __fastcall BtnSolTypeClick   (TObject *Sender);
	void __fastcall BtnPlotType1Click  (TObject *Sender);
	
	void __fastcall BtnMonitorClick   (TObject *Sender);
	void __fastcall BtnSaveClick      (TObject *Sender);
	void __fastcall BtnAboutClick     (TObject *Sender);
	void __fastcall BtnTaskTrayClick  (TObject *Sender);
	
	void __fastcall MenuExpandClick   (TObject *Sender);
	void __fastcall MenuStartClick    (TObject *Sender);
	void __fastcall MenuStopClick     (TObject *Sender);
	void __fastcall MenuPlotClick     (TObject *Sender);
	void __fastcall MenuMonitorClick  (TObject *Sender);
	void __fastcall MenuExitClick     (TObject *Sender);
	
	void __fastcall ScbSolChange      (TObject *Sender);
	
	void __fastcall TrayIconDblClick  (TObject *Sender);
	void __fastcall BtnFreqType1Click(TObject *Sender);
	void __fastcall Panel221Resize(TObject *Sender);
	void __fastcall Panel4Resize(TObject *Sender);
	void __fastcall Panel21Resize(TObject *Sender);
	void __fastcall Panel222Resize(TObject *Sender);
	void __fastcall BtnPanelClick(TObject *Sender);
	void __fastcall BtnPlotType2Click(TObject *Sender);
	void __fastcall BtnFreqType2Click(TObject *Sender);
	void __fastcall Panel211Resize(TObject *Sender);
	void __fastcall Panel5Resize(TObject *Sender);
private:
	tle_t TLEData;

	void __fastcall UpdateLog    (int stat, gtime_t time, double *rr, float *qr,
								  double *rb, int ns, double age, double ratio);
	void __fastcall SvrStart     (void);
	void __fastcall SvrStop      (void);
	void __fastcall UpdatePanel  (void);
	void __fastcall UpdateTimeSys(void);
	void __fastcall UpdateSolType(void);
	void __fastcall UpdateFont   (void);
	void __fastcall UpdateTime   (void);
	void __fastcall UpdatePos    (void);
	void __fastcall UpdateStr    (void);
	void __fastcall DrawPlot     (TImage *plot, int type, int freq);
	void __fastcall UpdatePlot   (void);
	void __fastcall ChangePlot   (void);
	int  __fastcall ConfOverwrite(const char *path);
	
	void __fastcall DrawSnr      (TCanvas *c, int w, int h, int top, int index, int freq);
	void __fastcall DrawSat      (TCanvas *c, int w, int h, int x0, int y0, int index, int freq);
	void __fastcall DrawBL       (TCanvas *c, int w, int h);
	void __fastcall DrawSky      (TCanvas *c, int w, int h, int x0, int y0);
	void __fastcall DrawText     (TCanvas *c, int x, int y, UnicodeString s,
								  TColor color, int align);
	void __fastcall DrawArrow    (TCanvas *c, int x, int y, int siz,
								  int ang, TColor color);
	void __fastcall OpenMoniPort (int port);
	void __fastcall InitSolBuff  (void);
	void __fastcall SaveLog      (void);
	void __fastcall LoadNav      (nav_t *nav);
	void __fastcall SaveNav      (nav_t *nav);
	void __fastcall LoadOpt      (void);
	void __fastcall SaveOpt      (void);
	void __fastcall SetTrayIcon  (int index);
	int  __fastcall ExecCmd      (AnsiString cmd, int show);
	TColor __fastcall SnrColor   (int snr);
public:
	AnsiString IniFile;
	
	int PanelStack,PanelMode;
	int SvrCycle,SvrBuffSize,Scale,SolBuffSize,NavSelect,SavedSol;
	int NmeaReq,NmeaCycle,InTimeTag,OutTimeTag,OutAppend,LogTimeTag,LogAppend;
	int TimeoutTime,ReconTime,SbasCorr,DgpsCorr,TideCorr,FileSwapMargin;
	int Stream[MAXSTRRTK],StreamC[MAXSTRRTK],Format[MAXSTRRTK];
	int CmdEna[3][2],CmdEnaTcp[3][2];
	int TimeSys,SolType,PlotType1,FreqType1,PlotType2,FreqType2;
	int MoniPort,OpenPort;
	
	int PSol,PSolS,PSolE,Nsat[2],SolCurrentStat;
	int Sat[2][MAXSAT],Snr[2][MAXSAT][NFREQ],Vsat[2][MAXSAT];
	double Az[2][MAXSAT],El[2][MAXSAT];
	gtime_t *Time;
	int *SolStat,*Nvsat;
	double *SolRov,*SolRef,*Qr,*VelRov,*Age,*Ratio;
	AnsiString Paths[MAXSTRRTK][4],Cmds[3][2],CmdsTcp[3][2];
	AnsiString InTimeStart,InTimeSpeed,ExSats;
	AnsiString RcvOpt[3],ProxyAddr;
	AnsiString OutSwapInterval,LogSwapInterval;
	prcopt_t PrcOpt;
	solopt_t SolOpt;
	TFont *PosFont;
	int DebugTraceF,DebugStatusF,OutputGeoidF,BaselineC;
	int RovPosTypeF,RefPosTypeF,RovAntPcvF,RefAntPcvF;
	AnsiString RovAntF,RefAntF,SatPcvFileF,AntPcvFileF;
	double RovAntDel[3],RefAntDel[3],RovPos[3],RefPos[3],NmeaPos[2];
	double Baseline[2];
	AnsiString History[10],MntpHist[10];
	
	AnsiString GeoidDataFileF,StaPosFileF,DCBFileF,EOPFileF,TLEFileF;
	AnsiString TLESatFileF,LocalDirectory,PntName[MAXMAPPNT];
	double PntPos[MAXMAPPNT][3];
	int NMapPnt;
	
	__fastcall TMainForm(TComponent* Owner);
};
//---------------------------------------------------------------------------
extern PACKAGE TMainForm *MainForm;
//---------------------------------------------------------------------------
#endif