blob: e10da74798b2b2e025ef53af4854bc68986519ef (
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
|
/* Starshatter: The Open Source Project
Copyright (c) 2021-2022, Starshatter: The Open Source Project Contributors
Copyright (c) 2011-2012, Starshatter OpenSource Distribution Contributors
Copyright (c) 1997-2006, Destroyer Studios LLC.
AUTHOR: John DiCamillo
OVERVIEW
========
Manages local weather conditions according to the system stardate
*/
#ifndef Weather_h
#define Weather_h
#include "Types.h"
#include "Text.h"
// +--------------------------------------------------------------------+
class Weather
{
public:
Weather();
virtual ~Weather();
enum STATE { CLEAR,
HIGH_CLOUDS,
MODERATE_CLOUDS,
OVERCAST,
FOG,
STORM,
NUM_STATES
};
virtual void Update();
// accessors:
STATE State() const { return state; }
Text Description() const;
double Period() const { return period; }
double Chance(STATE s) const { return chances[(int)s]; }
double Ceiling() const { return ceiling; }
double Visibility() const { return visibility; }
void SetPeriod(double p) { period = p; }
void SetChance(int n, double c);
protected:
void NormalizeChances();
STATE state;
double period;
double chances[NUM_STATES];
double ceiling;
double visibility;
STATE active_states[NUM_STATES];
double thresholds[NUM_STATES];
};
#endif // Weather_h
|