1 /////////////////////////////////////////////////////////////////////////////
 
   3 // Purpose:     SWIG interface defs for wxButton, wxBitmapButton
 
   7 // Created:     10-June-1998
 
   9 // Copyright:   (c) 2003 by Total Control Software
 
  10 // Licence:     wxWindows license
 
  11 /////////////////////////////////////////////////////////////////////////////
 
  16 //---------------------------------------------------------------------------
 
  19 MAKE_CONST_WXSTRING(ButtonNameStr);
 
  31 //---------------------------------------------------------------------------
 
  34 "A button is a control that contains a text string, and is one of the most
 
  35 common elements of a GUI.  It may be placed on a dialog box or panel, or
 
  36 indeed almost any other window.", "
 
  40     ==============   ==========================================
 
  41     wx.BU_LEFT       Left-justifies the label. WIN32 only.
 
  42     wx.BU_TOP        Aligns the label to the top of the button.
 
  44     wx.BU_RIGHT      Right-justifies the bitmap label. WIN32 only.
 
  45     wx.BU_BOTTOM     Aligns the label to the bottom of the button.
 
  47     wx.BU_EXACTFIT   Creates the button as small as possible
 
  48                      instead of making it of the standard size
 
  49                      (which is the default behaviour.)
 
  50     ==============   ==========================================
 
  54     ============     ==========================================
 
  55     EVT_BUTTON       Sent when the button is clicked.
 
  56     ============     ==========================================
 
  58 :see: `wx.BitmapButton`
 
  61 MustHaveApp(wxButton);
 
  63 class wxButton : public wxControl
 
  66     %pythonAppend wxButton         "self._setOORInfo(self)"
 
  67     %pythonAppend wxButton()       ""
 
  71         wxButton(wxWindow* parent, wxWindowID id=-1,
 
  72                  const wxString& label=wxPyEmptyString,
 
  73                  const wxPoint& pos = wxDefaultPosition,
 
  74                  const wxSize& size = wxDefaultSize,
 
  76                  const wxValidator& validator = wxDefaultValidator,
 
  77                  const wxString& name = wxPyButtonNameStr),
 
  78         "Create and show a button.", "");
 
  82         "Precreate a Button for 2-phase creation.", "",
 
  86         bool , Create(wxWindow* parent, wxWindowID id=-1,
 
  87                       const wxString& label=wxPyEmptyString,
 
  88                       const wxPoint& pos = wxDefaultPosition,
 
  89                       const wxSize& size = wxDefaultSize,
 
  91                       const wxValidator& validator = wxDefaultValidator,
 
  92                       const wxString& name = wxPyButtonNameStr),
 
  93         "Acutally create the GUI Button for 2-phase creation.", "");
 
  99         "This sets the button to be the default item for the panel or dialog box.", "");
 
 103         static wxSize , GetDefaultSize(),
 
 104         "Returns the default button size for this platform.", "");   
 
 106     static wxVisualAttributes
 
 107     GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
 
 112 //---------------------------------------------------------------------------
 
 115 DocStr(wxBitmapButton,
 
 116 "A Button that contains a bitmap.  A bitmap button can be supplied with a
 
 117 single bitmap, and wxWidgets will draw all button states using this bitmap. If
 
 118 the application needs more control, additional bitmaps for the selected state,
 
 119 unpressed focused state, and greyed-out state may be supplied.", "       
 
 123     ==============  =============================================
 
 124     wx.BU_AUTODRAW  If this is specified, the button will be drawn
 
 125                     automatically using the label bitmap only,
 
 126                     providing a 3D-look border. If this style is
 
 127                     not specified, the button will be drawn
 
 128                     without borders and using all provided
 
 130     wx.BU_LEFT      Left-justifies the label. WIN32 only.
 
 131     wx.BU_TOP       Aligns the label to the top of the button. WIN32
 
 133     wx.BU_RIGHT     Right-justifies the bitmap label. WIN32 only.
 
 134     wx.BU_BOTTOM    Aligns the label to the bottom of the
 
 136     wx.BU_EXACTFIT  Creates the button as small as possible
 
 137                     instead of making it of the standard size
 
 138                     (which is the default behaviour.)
 
 139     ==============  =============================================
 
 143      ===========   ==================================
 
 144      EVT_BUTTON    Sent when the button is clicked.
 
 145      ===========   ==================================
 
 147 :see: `wx.Button`, `wx.Bitmap`
 
 150 MustHaveApp(wxBitmapButton);
 
 152 class wxBitmapButton : public wxButton
 
 155     %pythonAppend wxBitmapButton         "self._setOORInfo(self)"
 
 156     %pythonAppend wxBitmapButton()       ""
 
 159         wxBitmapButton(wxWindow* parent, wxWindowID id=-1,
 
 160                        const wxBitmap& bitmap = wxNullBitmap,
 
 161                        const wxPoint& pos = wxDefaultPosition,
 
 162                        const wxSize& size = wxDefaultSize,
 
 163                        long style = wxBU_AUTODRAW,
 
 164                        const wxValidator& validator = wxDefaultValidator,
 
 165                        const wxString& name = wxPyButtonNameStr),
 
 166         "Create and show a button with a bitmap for the label.", "");
 
 170         "Precreate a BitmapButton for 2-phase creation.", "",
 
 174         bool , Create(wxWindow* parent, wxWindowID id=-1,
 
 175                       const wxBitmap& bitmap = wxNullBitmap,
 
 176                       const wxPoint& pos = wxDefaultPosition,
 
 177                       const wxSize& size = wxDefaultSize,
 
 178                       long style = wxBU_AUTODRAW,
 
 179                       const wxValidator& validator = wxDefaultValidator,
 
 180                       const wxString& name = wxPyButtonNameStr),
 
 181         "Acutally create the GUI BitmapButton for 2-phase creation.", "");
 
 185         wxBitmap , GetBitmapLabel(),
 
 186         "Returns the label bitmap (the one passed to the constructor).", "");
 
 189         wxBitmap , GetBitmapDisabled(),
 
 190         "Returns the bitmap for the disabled state.", "");
 
 193         wxBitmap , GetBitmapFocus(),
 
 194         "Returns the bitmap for the focused state.", "");
 
 198         wxBitmap , GetBitmapSelected(),
 
 199         "Returns the bitmap for the selected state.", "");
 
 203         void , SetBitmapDisabled(const wxBitmap& bitmap),
 
 204         "Sets the bitmap for the disabled button appearance.", "");
 
 208         void , SetBitmapFocus(const wxBitmap& bitmap),
 
 209         "Sets the bitmap for the button appearance when it has the keyboard focus.", "");
 
 213         void , SetBitmapSelected(const wxBitmap& bitmap),
 
 214         "Sets the bitmap for the selected (depressed) button appearance.", "");
 
 218         void , SetBitmapLabel(const wxBitmap& bitmap),
 
 219         "Sets the bitmap label for the button.  This is the bitmap used for the
 
 220 unselected state, and for all other states if no other bitmaps are provided.", "");
 
 223     void SetMargins(int x, int y);
 
 224     int GetMarginX() const;
 
 225     int GetMarginY() const;
 
 229 //---------------------------------------------------------------------------