blob: 8b87b998dce9dd5e88f373fe7e56ebfb6c023ca3 (
plain)
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
|
/***************************************************************************
modcalcjd.cpp - description
-------------------
begin : Tue Jan 15 2002
copyright : (C) 2002 by Pablo de Vicente
email : vicente@oan.es
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#include "modcalcjd.h"
#include "modcalcjd.moc"
#include "kstars.h"
#include "kstarsdata.h"
#include "geolocation.h"
#include "libtdeedu/extdate/extdatetimeedit.h"
#include <tqdatetimeedit.h> //need for TQTimeEdit
#include <tqradiobutton.h>
#include <klineedit.h>
#include <klocale.h>
#include <kglobal.h>
#include "kstarsdatetime.h"
#define MJD0 2400000.5
modCalcJD::modCalcJD(TQWidget *parentSplit, const char *name) : modCalcJdDlg(parentSplit,name) {
showCurrentTime();
show();
}
modCalcJD::~modCalcJD(void)
{
}
void modCalcJD::slotComputeTime (void)
{
if(DateRadio->isChecked()) {
computeFromCalendar();
} else if (JdRadio->isChecked()) {
JdName->setFocus();
computeFromJd();
} else if (MjdRadio->isChecked()) {
MjdName->setFocus();
computeFromMjd();
}
}
void modCalcJD::computeFromCalendar (void)
{
long double julianDay, modjulianDay;
julianDay = getDateTime().djd();
showJd( julianDay );
modjulianDay = julianDay - MJD0;
showMjd(modjulianDay);
}
void modCalcJD::computeFromMjd (void)
{
long double julianDay, modjulianDay;
modjulianDay = KGlobal::locale()->readNumber( MjdName->text() );
julianDay = MJD0 + modjulianDay;
showJd( julianDay );
computeFromJd();
}
void modCalcJD::computeFromJd (void)
{
long double julianDay, modjulianDay;
julianDay = KGlobal::locale()->readNumber( JdName->text() );
KStarsDateTime dt( julianDay );
datBox->setDate( dt.date() );
timBox->setTime( dt.time() );
modjulianDay = julianDay - MJD0;
showMjd( modjulianDay );
}
void modCalcJD::slotClearTime (void)
{
JdName->setText ("");
MjdName->setText ("");
datBox->setDate( ExtDate::currentDate() );
timBox->setTime(TQTime(0,0,0));
}
void modCalcJD::showCurrentTime (void)
{
KStars *ks = (KStars*) parent()->parent()->parent();
KStarsDateTime dt = ks->data()->geo()->LTtoUT( KStarsDateTime::currentDateTime() );
datBox->setDate( dt.date() );
timBox->setTime( dt.time() );
computeFromCalendar();
}
KStarsDateTime modCalcJD::getDateTime (void)
{
return KStarsDateTime( datBox->date() , timBox->time() );
}
void modCalcJD::showJd(long double julianDay)
{
JdName->setText(KGlobal::locale()->formatNumber( (double)julianDay, 5 ) );
}
void modCalcJD::showMjd(long double modjulianDay)
{
MjdName->setText(KGlobal::locale()->formatNumber( (double)modjulianDay, 5 ) );
}
|