1 #ifndef GUI_MAPWIDGET_HXX
2 #define GUI_MAPWIDGET_HXX
5 #include <simgear/compiler.h>
6 #include <simgear/math/SGMath.hxx>
7 #include <simgear/props/props.hxx>
11 #include "dialog.hxx" // for GUI_ID
23 class MapWidget : public puObject
26 MapWidget(int x, int y, int width, int height);
29 virtual void setSize(int width, int height);
30 virtual void doHit( int button, int updown, int x, int y ) ;
31 virtual void draw( int dx, int dy ) ;
32 virtual int checkKey(int key, int updown);
34 void setProperty(SGPropertyNode_ptr prop);
38 void handlePan(int x, int y);
40 void pan(const SGVec2d& delta);
44 void paintAircraftLocation(const SGGeod& aircraftPos);
47 void drawFlightHistory();
50 void drawNavRadio(SGPropertyNode_ptr radio);
51 void drawTunedLocalizer(SGPropertyNode_ptr radio);
53 void drawLatLonGrid();
54 SGVec2d gridPoint(int ix, int iy);
55 bool drawLineClipped(const SGVec2d& a, const SGVec2d& b);
58 void drawAirport(FGAirport* apt);
59 int scoreAirportRunways(FGAirport* apt);
60 void drawRunwayPre(FGRunway* rwy);
61 void drawRunway(FGRunway* rwy);
62 void drawHelipad(FGHelipad* hp);
63 void drawILS(bool tuned, FGRunway* rwy);
66 void drawNDB(bool tuned, FGNavRecord* nav);
67 void drawVOR(bool tuned, FGNavRecord* nav);
68 void drawFix(FGFix* fix);
71 void drawAIAircraft(const SGPropertyNode* model, const SGGeod& pos, double hdg);
72 void drawAIShip(const SGPropertyNode* model, const SGGeod& pos, double hdg);
75 bool validDataForKey(void* key);
76 MapData* getOrCreateDataForKey(void* key);
77 MapData* createDataForKey(void* key);
78 void setAnchorForKey(void* key, const SGVec2d& anchor);
81 SGVec2d project(const SGGeod& geod) const;
82 SGGeod unproject(const SGVec2d& p) const;
83 double currentScale() const;
85 int displayHeading(double trueHeading) const;
87 void circleAt(const SGVec2d& center, int nSides, double r);
88 void circleAtAlt(const SGVec2d& center, int nSides, double r, double r2);
89 void drawLine(const SGVec2d& p1, const SGVec2d& p2);
90 void drawLegendBox(const SGVec2d& pos, const std::string& t);
95 double _upHeading; // true heading corresponding to +ve y-axis
96 bool _magneticHeadings;
99 SGGeod _projectionCenter;
100 bool _orthoAzimuthProject;
103 SGVec2d _hitLocation;
105 SGPropertyNode_ptr _root;
106 SGPropertyNode_ptr _gps;
108 typedef std::map<void*, MapData*> KeyDataMap;
110 std::vector<MapData*> _dataQueue;
114 typedef std::map<int, SGVec2d> GridPointCache;
115 GridPointCache _gridCache;
120 #endif // of GUI_MAPWIDGET_HXX