]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/os2/radiobox.h
Fix for wxTextCtrl::GetSelection for singel line controls in GTK2 mode
[wxWidgets.git] / include / wx / os2 / radiobox.h
index ec2ac64f86244f8543d1197099dede317f735258..d6eb7cc229744727917f08e81bdc4f9b6b8e9ba0 100644 (file)
 #ifndef _WX_RADIOBOX_H_
 #define _WX_RADIOBOX_H_
 
-#include "wx/control.h"
-
-WXDLLEXPORT_DATA(extern const char*) wxRadioBoxNameStr;
-
 // List box item
 class WXDLLEXPORT wxBitmap ;
 
-class WXDLLEXPORT wxRadioBox: public wxControl
+class WXDLLEXPORT wxRadioBox: public wxControl, public wxRadioBoxBase
 {
-  DECLARE_DYNAMIC_CLASS(wxRadioBox)
 public:
-  wxRadioBox();
-
-  inline wxRadioBox(wxWindow *parent, wxWindowID id, const wxString& title,
-             const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
-             int n = 0, const wxString choices[] = NULL,
-             int majorDim = 0, long style = wxRA_HORIZONTAL,
-#if wxUSE_VALIDATORS
-#  if defined(__VISAGECPP__)
-             const wxValidator* val = wxDefaultValidator, const wxString& name = wxRadioBoxNameStr)
-#  else
-             const wxValidator& val = wxDefaultValidator, const wxString& name = wxRadioBoxNameStr)
-#  endif
-#endif
-  {
-    Create(parent, id, title, pos, size, n, choices, majorDim, style, val, name);
-  }
-
-  ~wxRadioBox();
-
-  bool Create(wxWindow *parent, wxWindowID id, const wxString& title,
-             const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
-             int n = 0, const wxString choices[] = NULL,
-             int majorDim = 0, long style = wxRA_HORIZONTAL,
-#if wxUSE_VALIDATORS
-#  if defined(__VISAGECPP__)
-             const wxValidator* val = wxDefaultValidator, const wxString& name = wxRadioBoxNameStr);
-#  else
-             const wxValidator& val = wxDefaultValidator, const wxString& name = wxRadioBoxNameStr);
-#  endif
-#endif
+    wxRadioBox();
+
+    inline wxRadioBox( wxWindow*          pParent
+                      ,wxWindowID         vId
+                      ,const wxString&    rsTitle
+                      ,const wxPoint&     rPos = wxDefaultPosition
+                      ,const wxSize&      rSize = wxDefaultSize
+                      ,int                nNum = 0
+                      ,const wxString     asChoices[] = NULL
+                      ,int                nMajorDim = 0
+                      ,long               lStyle = wxRA_HORIZONTAL
+                      ,const wxValidator& rVal = wxDefaultValidator
+                      ,const wxString&    rsName = wxRadioBoxNameStr
+                     )
+    {
+        Create( pParent
+               ,vId
+               ,rsTitle
+               ,rPos
+               ,rSize
+               ,nNum
+               ,asChoices
+               ,nMajorDim
+               ,lStyle
+               ,rVal
+               ,rsName
+              );
+    }
+
+    ~wxRadioBox();
+
+    bool Create( wxWindow*          pParent
+                ,wxWindowID         vId
+                ,const wxString&    rsTitle
+                ,const wxPoint&     rPos = wxDefaultPosition
+                ,const wxSize&      rSize = wxDefaultSize
+                ,int                nNum = 0
+                ,const wxString     asChoices[] = NULL
+                ,int                nMajorDim = 0
+                ,long               lStyle = wxRA_HORIZONTAL
+                ,const wxValidator& rVal = wxDefaultValidator
+                ,const wxString&    rsName = wxRadioBoxNameStr
+               );
+
+    void             Command(wxCommandEvent& rEvent);
+    bool             ContainsHWND(WXHWND hWnd) const;
+    virtual bool     Enable(bool bEnable = TRUE);
+    void             Enable( int  nItem
+                            ,bool bEnable
+                           );
+    int              FindString(const wxString& sStr) const;
+
+    virtual WXHBRUSH OnCtlColor( WXHDC    hDC
+                                ,WXHWND   hWnd
+                                ,WXUINT   uCtlColor
+                                ,WXUINT   uMessage
+                                ,WXWPARAM wParam
+                                ,WXLPARAM lParam
+                               );
+    virtual bool     OS2Command( WXUINT uParam
+                                ,WXWORD wId
+                               );
+    void             SendNotificationEvent(void);
+    virtual void     Show( int  nItem
+                          ,bool bShow =  TRUE
+                         ) ;
+    bool             Show(bool bShow);
+    MRESULT          WindowProc( WXUINT   uMsg
+                                ,WXWPARAM wParam
+                                ,WXLPARAM lParam
+                               );
+
+
+
+
+           virtual int      GetColumnCount(void) const;
+           virtual int      GetCount(void) const;
+    inline         int      GetNumberOfRowsOrCols(void) const { return m_nNoRowsOrCols; }
+                   int      GetNumHor(void) const;
+                   int      GetNumVer(void) const;
+                   void     GetPosition( int* pnX
+                                        ,int* pnY
+                                       ) const;
+    inline         WXHWND*  GetRadioButtons(void) const { return m_ahRadioButtons; }
+           virtual int      GetRowCount(void) const;
+                   int      GetSelection(void) const;
+                   void     GetSize( int* pnX
+                                    ,int* pnY
+                                   ) const;
+    inline         int      GetSizeFlags(void) const { return m_nSizeFlags; }
+                   void     AdjustButtons( int nX
+                                          ,int nY
+                                          ,int nWidth
+                                          ,int nHeight
+                                          ,int nSizeFlags
+                                         );
+                   wxString GetString(int nIndex) const;
+           virtual wxString GetStringSelection(void) const;
+
+    inline         void     SetButtonFont(const wxFont& rFont) { SetFont(rFont); }
+                   void     SetFocus(void);
+           virtual bool     SetFont(const wxFont& rFont);
+    inline         void     SetLabelFont(const wxFont& WXUNUSED(font)) {};
+    inline         void     SetNumberOfRowsOrCols(int nNum) { m_nNoRowsOrCols = nNum; }
+                   void     SetSelection(int nIndex);
+           virtual void     SetString( int             nNum
+                                      ,const wxString& rsLabel
+                                     );
+           virtual bool     SetStringSelection(const wxString& rsStr);
+
+                   void     SetLabel( int             nItem
+                                     ,const wxString& rsLabel
+                                    );
+                   void     SetLabel( int       item
+                                     ,wxBitmap* pBitmap
+                                    );
+                   wxString GetLabel(int nItem) const;
 
-  virtual bool OS2Command(WXUINT param, WXWORD id);
-  virtual WXHBRUSH OnCtlColor(WXHDC pDC, WXHWND pWnd, WXUINT nCtlColor,
-                              WXUINT message, WXWPARAM wParam, WXLPARAM lParam);
-
-  int FindString(const wxString& s) const;
-  void SetSelection(int N);
-  int GetSelection() const;
-  wxString GetString(int N) const;
-
-  void GetSize(int *x, int *y) const;
-  void GetPosition(int *x, int *y) const;
-
-  void SetLabel(int item, const wxString& label);
-  void SetLabel(int item, wxBitmap *bitmap);
-  wxString GetLabel(int item) const;
-  bool Show(bool show);
-  void SetFocus();
-  bool Enable(bool enable);
-  void Enable(int item, bool enable);
-  void Show(int item, bool show) ;
-  inline void SetLabelFont(const wxFont& WXUNUSED(font)) {};
-  inline void SetButtonFont(const wxFont& font) { SetFont(font); }
-
-  virtual wxString GetStringSelection() const;
-  virtual bool SetStringSelection(const wxString& s);
-  inline virtual int Number() const { return m_noItems; } ;
-  void Command(wxCommandEvent& event);
-
-  inline int GetNumberOfRowsOrCols() const { return m_noRowsOrCols; }
-  inline void SetNumberOfRowsOrCols(int n) { m_noRowsOrCols = n; }
-
-  // implementation only from now on
-  // -------------------------------
-
-  WXHWND *GetRadioButtons() const { return m_radioButtons; }
-  bool ContainsHWND(WXHWND hWnd) const;
-  void SendNotificationEvent();
-
-  // get the number of buttons per column/row
-  int GetNumVer() const;
-  int GetNumHor() const;
-
-#if WXWIN_COMPATIBILITY
-  wxRadioBox(wxWindow *parent, wxFunction func, const char *title,
-             int x = -1, int y = -1, int width = -1, int height = -1,
-             int n = 0, char **choices = NULL,
-             int majorDim = 0, long style = wxRA_HORIZONTAL, const char *name = wxRadioBoxNameStr);
-#endif // WXWIN_COMPATIBILITY
 
 protected:
-  void SubclassRadioButton(WXHWND hWndBtn);
+    virtual wxSize DoGetBestSize(void) const;
+    virtual void   DoSetSize( int nX
+                             ,int nY
+                             ,int nWidth
+                             ,int nHeight
+                             ,int nSizeFlags = wxSIZE_AUTO
+                            );
+    wxSize         GetMaxButtonSize(void) const;
+    wxSize         GetTotalButtonSize(const wxSize& rSizeBtn) const;
+    void           SubclassRadioButton(WXHWND hWndBtn);
+
+
+    WXHWND*                         m_ahRadioButtons;
+    int                             m_nMajorDim ;
+    int*                            m_pnRadioWidth;  // for bitmaps
+    int*                            m_pnRadioHeight;
+    int                             m_nNoItems;
+    int                             m_nNoRowsOrCols;
+    int                             m_nSelectedButton;
+    int                             m_nSizeFlags;
 
-  WXHWND *          m_radioButtons;
-  int               m_majorDim ;
-  int *             m_radioWidth;  // for bitmaps
-  int *             m_radioHeight;
-
-  int               m_noItems;
-  int               m_noRowsOrCols;
-  int               m_selectedButton;
-
-  virtual void DoSetSize(int x, int y,
-                         int width, int height,
-                         int sizeFlags = wxSIZE_AUTO);
 private:
-  virtual void SetLabel(const wxString& label)
-  { wxWindowBase::SetLabel(label); }
-  wxString GetLabel() const
-  { return(wxWindowBase::GetLabel()); }
-};
+    inline wxString GetLabel() const
+    { return wxWindowBase::GetLabel(); }
+    inline void     SetLabel(const wxString& rsLabel)
+    { wxWindowBase::SetLabel(rsLabel); }
+
+    DECLARE_DYNAMIC_CLASS(wxRadioBox)
+}; // end of wxRadioBox
 
 #endif
     // _WX_RADIOBOX_H_