1 /////////////////////////////////////////////////////////////////////////////// 
   2 // Name:        ribbon/buttonbar.h 
   3 // Purpose:     interface of wxRibbonButtonBar 
   4 // Author:      Peter Cawley 
   6 // Licence:     wxWindows licence 
   7 /////////////////////////////////////////////////////////////////////////////// 
  10     Flags for button bar button size and state. 
  12     Buttons on a ribbon button bar can each come in three sizes: small, medium, 
  13     and large. In some places this is called the size class, and the term size 
  14     used for the pixel width and height associated with a particular size 
  17     A button can also be in zero or more hovered or active states, or in the 
  20 enum wxRibbonButtonBarButtonState
 
  23         Button is small (the interpretation of small is dependant upon the art 
  24         provider, but it will be smaller than medium). 
  26     wxRIBBON_BUTTONBAR_BUTTON_SMALL     
= 0 << 0, 
  29         Button is medium sized (the interpretation of medium is dependant upon 
  30         the art provider, but it will be between small and large). 
  32     wxRIBBON_BUTTONBAR_BUTTON_MEDIUM    
= 1 << 0, 
  35         Button is large (the interpretation of large is dependant upon the art 
  36         provider, but it will be larger than medium). 
  38     wxRIBBON_BUTTONBAR_BUTTON_LARGE     
= 2 << 0, 
  41         A mask to extract button size from a combination of flags. 
  43     wxRIBBON_BUTTONBAR_BUTTON_SIZE_MASK 
= 3 << 0, 
  46         The normal (non-dropdown) region of the button is being hovered over by 
  47         the mouse cursor. Only applicable to normal and hybrid buttons. 
  49     wxRIBBON_BUTTONBAR_BUTTON_NORMAL_HOVERED    
= 1 << 3, 
  52         The dropdown region of the button is being hovered over by the mouse 
  53         cursor. Only applicable to dropdown and hybrid buttons. 
  55     wxRIBBON_BUTTONBAR_BUTTON_DROPDOWN_HOVERED  
= 1 << 4, 
  58         A mask to extract button hover state from a combination of flags. 
  60     wxRIBBON_BUTTONBAR_BUTTON_HOVER_MASK        
= wxRIBBON_BUTTONBAR_BUTTON_NORMAL_HOVERED 
| wxRIBBON_BUTTONBAR_BUTTON_DROPDOWN_HOVERED
, 
  63         The normal (non-dropdown) region of the button is being pressed. 
  64         Only applicable to normal and hybrid buttons. 
  66     wxRIBBON_BUTTONBAR_BUTTON_NORMAL_ACTIVE     
= 1 << 5, 
  69         The dropdown region of the button is being pressed. 
  70         Only applicable to dropdown and hybrid buttons. 
  72     wxRIBBON_BUTTONBAR_BUTTON_DROPDOWN_ACTIVE   
= 1 << 6, 
  75         The button is disabled. Hover flags may still be set when a button 
  76         is disabled, but should be ignored during drawing if the button is 
  79     wxRIBBON_BUTTONBAR_BUTTON_DISABLED          
= 1 << 7, 
  82         A mask to extract button state from a combination of flags. 
  84     wxRIBBON_BUTTONBAR_BUTTON_STATE_MASK        
= 0xF8, 
  88     @class wxRibbonButtonBar 
  90     A ribbon button bar is similar to a traditional toolbar. It contains one or 
  91     more buttons (button bar buttons, not wxButtons), each of which has a label 
  92     and an icon. It differs from a wxRibbonToolBar in several ways: 
  93       @li Individual buttons can grow and contract. 
  94       @li Buttons have labels as well as bitmaps. 
  95       @li Bitmaps are typically larger (at least 32x32 pixels) on a button bar 
  96         compared to a tool bar (which typically has 16x15). 
  97       @li There is no grouping of buttons on a button bar 
  98       @li A button bar typically has a border around each individual button, 
  99         whereas a tool bar typically has a border around each group of buttons. 
 101     @beginEventEmissionTable{wxRibbonButtonBarEvent} 
 102     @event{EVT_RIBBONBUTTONBAR_CLICKED(id, func)} 
 103         Triggered when the normal (non-dropdown) region of a button on the 
 104         button bar is clicked. 
 105     @event{EVT_RIBBONBUTTONBAR_DROPDOWN_CLICKED(id, func)} 
 106         Triggered when the dropdown region of a button on the button bar is 
 107         clicked. wxRibbonButtonBarEvent::PopupMenu() should be called by the 
 108         event handler if it wants to display a popup menu (which is what most 
 109         dropdown buttons should be doing). 
 115 class wxRibbonButtonBar 
: public wxRibbonControl
 
 120         With this constructor, Create() should be called in order to create 
 126         Construct a ribbon button bar with the given parameters. 
 128             Parent window for the button bar (typically a wxRibbonPanel). 
 130             Initial position of the button bar. 
 132             Initial size of the button bar. 
 134             Button bar style, currently unused. 
 136     wxRibbonButtonBar(wxWindow
* parent
, 
 137                   wxWindowID id 
= wxID_ANY
, 
 138                   const wxPoint
& pos 
= wxDefaultPosition
, 
 139                   const wxSize
& size 
= wxDefaultSize
, 
 145     virtual ~wxRibbonButtonBar(); 
 148         Create a button bar in two-step button bar construction. 
 149         Should only be called when the default constructor is used, and 
 150         arguments have the same meaning as in the full constructor. 
 152     bool Create(wxWindow
* parent
, 
 153                 wxWindowID id 
= wxID_ANY
, 
 154                 const wxPoint
& pos 
= wxDefaultPosition
, 
 155                 const wxSize
& size 
= wxDefaultSize
, 
 159         Add a button to the button bar (simple version). 
 161     virtual wxRibbonButtonBarButtonBase
* AddButton( 
 163                 const wxString
& label
, 
 164                 const wxBitmap
& bitmap
, 
 165                 const wxString
& help_string
, 
 166                 wxRibbonButtonBarButtonKind kind 
= wxRIBBON_BUTTONBAR_BUTTON_NORMAL
); 
 169         Add a dropdown button to the button bar (simple version). 
 173     virtual wxRibbonButtonBarButtonBase
* AddDropdownButton( 
 175                 const wxString
& label
, 
 176                 const wxBitmap
& bitmap
, 
 177                 const wxString
& help_string 
= wxEmptyString
); 
 180         Add a hybrid button to the button bar (simple version). 
 184     virtual wxRibbonButtonBarButtonBase
* AddHybridButton( 
 186                 const wxString
& label
, 
 187                 const wxBitmap
& bitmap
, 
 188                 const wxString
& help_string 
= wxEmptyString
); 
 191         Add a button to the button bar. 
 194             ID of the new button (used for event callbacks). 
 196             Label of the new button. 
 198             Large bitmap of the new button. Must be the same size as all other 
 199             large bitmaps used on the button bar. 
 201             Small bitmap of the new button. If left as null, then a small 
 202             bitmap will be automatically generated. Must be the same size as 
 203             all other small bitmaps used on the button bar. 
 204         @param bitmap_disabled 
 205             Large bitmap of the new button when it is disabled. If left as 
 206             null, then a bitmap will be automatically generated from @a bitmap. 
 207         @param bitmap_small_disabled 
 208             Small bitmap of the new button when it is disabled. If left as 
 209             null, then a bitmap will be automatically generated from @a 
 212             The kind of button to add. 
 214             The UI help string to associate with the new button. 
 216             Client data to associate with the new button. 
 218         @return An opaque pointer which can be used only with other button bar 
 221         @see AddDropdownButton() 
 222         @see AddHybridButton() 
 224     virtual wxRibbonButtonBarButtonBase
* AddButton( 
 226                 const wxString
& label
, 
 227                 const wxBitmap
& bitmap
, 
 228                 const wxBitmap
& bitmap_small 
= wxNullBitmap
, 
 229                 const wxBitmap
& bitmap_disabled 
= wxNullBitmap
, 
 230                 const wxBitmap
& bitmap_small_disabled 
= wxNullBitmap
, 
 231                 wxRibbonButtonBarButtonKind kind 
= wxRIBBON_BUTTONBAR_BUTTON_NORMAL
, 
 232                 const wxString
& help_string 
= wxEmptyString
, 
 233                 wxObject
* client_data 
= NULL
); 
 236         Calculate button layouts and positions. 
 238         Must be called after buttons are added to the button bar, as otherwise 
 239         the newly added buttons will not be displayed. In normal situations, it 
 240         will be called automatically when wxRibbonBar::Realize() is called. 
 242     virtual bool Realize(); 
 245         Delete all buttons from the button bar. 
 249     virtual void ClearButtons(); 
 252         Delete a single button from the button bar. 
 256     virtual bool DeleteButton(int button_id
); 
 259         Enable or disable a single button on the bar. 
 262             ID of the button to enable or disable. 
 264             @true to enable the button, @false to disable it. 
 266     virtual void EnableButton(int button_id
, bool enable 
= true); 
 270     @class wxRibbonButtonBarEvent 
 272     Event used to indicate various actions relating to a button on a 
 275     See wxRibbonButtonBar for available event types. 
 278     @category{events,ribbon} 
 282 class wxRibbonButtonBarEvent 
: public wxCommandEvent
 
 288     wxRibbonButtonBarEvent(wxEventType command_type 
= wxEVT_NULL
, 
 290                        wxRibbonButtonBar
* bar 
= NULL
); 
 293         Returns the bar which contains the button which the event relates to. 
 295     wxRibbonButtonBar
* GetBar(); 
 298         Sets the button bar relating to this event. 
 300     void SetBar(wxRibbonButtonBar
* bar
); 
 303         Display a popup menu as a result of this (dropdown clicked) event. 
 305     bool PopupMenu(wxMenu
* menu
);