X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/853dcc57c6e5ba58e9e546c65ca4965256f3ac21..b7e5ba8f2d676583c790c59388eba8bfa9bd33c2:/include/wx/radiobox.h diff --git a/include/wx/radiobox.h b/include/wx/radiobox.h index 646d796457..0cbb947156 100644 --- a/include/wx/radiobox.h +++ b/include/wx/radiobox.h @@ -16,7 +16,7 @@ #include "wx/ctrlsub.h" -extern WXDLLEXPORT_DATA(const wxChar*) wxRadioBoxNameStr; +extern WXDLLEXPORT_DATA(const wxChar) wxRadioBoxNameStr[]; // ---------------------------------------------------------------------------- // wxRadioBoxBase is not a normal base class, but rather a mix-in because the @@ -27,17 +27,23 @@ extern WXDLLEXPORT_DATA(const wxChar*) wxRadioBoxNameStr; class WXDLLEXPORT wxRadioBoxBase : public wxItemContainerImmutable { public: - // change the individual radio button state + // change/query the individual radio button state virtual bool Enable(int n, bool enable = true) = 0; virtual bool Show(int n, bool show = true) = 0; - // layout parameters - virtual int GetColumnCount() const = 0; - virtual int GetRowCount() const = 0; + // NB: these functions are stubbed here for now but should become pure + // virtual once all ports implement them + virtual bool IsItemEnabled(int WXUNUSED(n)) const { return true; } + virtual bool IsItemShown(int WXUNUSED(n)) const { return true; } + + // return number of columns/rows in this radiobox + int GetColumnCount() const { return m_numCols; } + int GetRowCount() const { return m_numRows; } // return the item above/below/to the left/right of the given one int GetNextItem(int item, wxDirection dir, long style) const; + // deprecated functions // -------------------- @@ -46,12 +52,29 @@ public: wxDEPRECATED( void SetNumberOfRowsOrCols(int n) ); #endif // WXWIN_COMPATIBILITY_2_4 - // for compatibility only, don't use these methods in new code! -#if WXWIN_COMPATIBILITY_2_2 - wxDEPRECATED( int Number() const ); - wxDEPRECATED( wxString GetLabel(int n) const ); - wxDEPRECATED( void SetLabel(int n, const wxString& label) ); -#endif // WXWIN_COMPATIBILITY_2_2 +protected: + wxRadioBoxBase() + { + m_majorDim = 0; + } + + // return the number of items in major direction (which depends on whether + // we have wxRA_SPECIFY_COLS or wxRA_SPECIFY_ROWS style) + int GetMajorDim() const { return m_majorDim; } + + // sets m_majorDim and also updates m_numCols/Rows + // + // the style parameter should be the style of the radiobox itself + void SetMajorDim(int majorDim, long style); + + +private: + // the number of elements in major dimension (i.e. number of columns if + // wxRA_SPECIFY_COLS or the number of rows if wxRA_SPECIFY_ROWS) and also + // the number of rows/columns calculated from it + int m_majorDim, + m_numCols, + m_numRows; }; #if defined(__WXUNIVERSAL__) @@ -60,8 +83,10 @@ public: #include "wx/msw/radiobox.h" #elif defined(__WXMOTIF__) #include "wx/motif/radiobox.h" -#elif defined(__WXGTK__) +#elif defined(__WXGTK20__) #include "wx/gtk/radiobox.h" +#elif defined(__WXGTK__) + #include "wx/gtk1/radiobox.h" #elif defined(__WXMAC__) #include "wx/mac/radiobox.h" #elif defined(__WXCOCOA__)