X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FGUI%2Fdialog.hxx;h=63aef704b1d2ec3354c7b4261749a2054db43515;hb=5cad5aa7da2476ca8323a61f81dea59676dca085;hp=f30f3cf22da7d627ee1666bedb8767a1783d27ff;hpb=5a38a9d071f3d58b14225cbdcfdaf4abe1f0e2dc;p=flightgear.git diff --git a/src/GUI/dialog.hxx b/src/GUI/dialog.hxx index f30f3cf22..63aef704b 100644 --- a/src/GUI/dialog.hxx +++ b/src/GUI/dialog.hxx @@ -8,20 +8,25 @@ #endif #include -#include #include // for SG_USING_STD #include #include - -#undef PUCLASS_LIST -#include "puList.hxx" +#include #include -SG_USING_STD(vector); +using std::vector; + + +// ugly temporary workaround for plib's lack of user defined class ids FIXME +#define FGCLASS_LIST 0x00000001 +#define FGCLASS_AIRPORTLIST 0x00000002 +#define FGCLASS_PROPERTYLIST 0x00000004 +class GUI_ID { public: GUI_ID(int id) : id(id) {} virtual ~GUI_ID() {} int id; }; + + class FGDialog; -class FGBinding; class NewGUI; class FGColor; @@ -87,6 +92,15 @@ public: */ virtual void update (); + /** + * Recompute the dialog's layout + */ + void relayout(); + + + void setNeedsLayout() { + _needsRelayout = true; + } private: enum { @@ -123,6 +137,11 @@ private: // return key code number for keystring int getKeyCode(const char *keystring); + /** + * Apply layout sizes to a tree of puObjects + */ + void applySize(puObject *object); + // The top-level PUI object. puObject * _object; @@ -137,6 +156,8 @@ private: // last position. SGPropertyNode_ptr _props; + bool _needsRelayout; + // Nasal module. string _module; SGPropertyNode_ptr _nasal_close; @@ -156,6 +177,24 @@ private: }; vector _propertyObjects; vector _liveObjects; + + class ConditionalObject : public SGConditional + { + public: + ConditionalObject(const std::string& aName, puObject* aPu) : + _name(aName), + _pu(aPu) + { ; } + + void update(FGDialog* aDlg); + + private: + const std::string _name; + puObject* _pu; + }; + + typedef SGSharedPtr ConditionalObjectRef; + vector _conditionalObjects; }; // @@ -170,16 +209,25 @@ private: // class fgPopup : public puPopup { public: - fgPopup(int x, int y, bool d = true) : puPopup(x, y) { _dragging = false; _draggable = d;} + fgPopup(int x, int y, bool r = true, bool d = true) : + puPopup(x, y), _draggable(d), _resizable(r), _dragging(false) + {} int checkHit(int b, int up, int x, int y); int checkKey(int key, int updown); int getHitObjects(puObject *, int x, int y); puObject *getKeyObject(puObject *, int key); puObject *getActiveInputField(puObject *); + void applySize(puObject *); private: + enum { LEFT = 1, RIGHT = 2, TOP = 4, BOTTOM = 8 }; bool _draggable; + bool _resizable; bool _dragging; - int _dX, _dY; + int _resizing; + int _start_cursor; + int _cursor; + int _dlgX, _dlgY, _dlgW, _dlgH; + int _startX, _startY; }; @@ -199,17 +247,19 @@ private: }; -class fgList : public fgValueList, public puList { +class fgList : public fgValueList, public puaList, public GUI_ID { public: fgList(int x1, int y1, int x2, int y2, SGPropertyNode *p, int sw) : - fgValueList(p), puList(x1, y1, x2, y2, _list, sw) {} - virtual void update(); + fgValueList(p), puaList(x1, y1, x2, y2, _list, sw), GUI_ID(FGCLASS_LIST) {} + void update(); }; class fgComboBox : public fgValueList, public puaComboBox { public: fgComboBox(int x1, int y1, int x2, int y2, SGPropertyNode *p, bool editable) : fgValueList(p), puaComboBox(x1, y1, x2, y2, _list, editable) {} + + void update(); }; class fgSelectBox : public fgValueList, public puaSelectBox {