2001-06-26 16:59:19 -04:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/button.h
|
|
|
|
// Purpose: wxButtonBase class
|
|
|
|
// Author: Vadim Zetlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 15.08.00
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) Vadim Zetlin
|
2004-05-23 16:53:33 -04:00
|
|
|
// Licence: wxWindows licence
|
2001-06-26 16:59:19 -04:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
1998-08-14 20:23:28 -04:00
|
|
|
#ifndef _WX_BUTTON_H_BASE_
|
|
|
|
#define _WX_BUTTON_H_BASE_
|
1998-05-20 10:01:55 -04:00
|
|
|
|
2003-07-09 17:48:53 -04:00
|
|
|
#include "wx/defs.h"
|
|
|
|
|
2001-07-10 09:44:04 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
2004-05-30 11:14:41 -04:00
|
|
|
// wxButton flags shared with other classes
|
2001-07-10 09:44:04 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2004-05-30 11:14:41 -04:00
|
|
|
#if wxUSE_TOGGLEBTN || wxUSE_BUTTON
|
2002-09-02 11:18:25 -04:00
|
|
|
|
|
|
|
// These flags affect label alignment
|
2001-07-10 09:44:04 -04:00
|
|
|
#define wxBU_LEFT 0x0040
|
|
|
|
#define wxBU_TOP 0x0080
|
|
|
|
#define wxBU_RIGHT 0x0100
|
|
|
|
#define wxBU_BOTTOM 0x0200
|
2004-11-15 01:23:57 -05:00
|
|
|
#define wxBU_ALIGN_MASK ( wxBU_LEFT | wxBU_TOP | wxBU_RIGHT | wxBU_BOTTOM )
|
2004-05-30 11:14:41 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if wxUSE_BUTTON
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxButton specific flags
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// These two flags are obsolete
|
|
|
|
#define wxBU_NOAUTODRAW 0x0000
|
|
|
|
#define wxBU_AUTODRAW 0x0004
|
|
|
|
|
2001-07-10 09:44:04 -04:00
|
|
|
// by default, the buttons will be created with some (system dependent)
|
|
|
|
// minimal size to make them look nicer, giving this style will make them as
|
|
|
|
// small as possible
|
|
|
|
#define wxBU_EXACTFIT 0x0001
|
|
|
|
|
2009-06-17 18:13:46 -04:00
|
|
|
// this flag can be used to disable using the text label in the button: it is
|
|
|
|
// mostly useful when creating buttons showing bitmap and having stock id as
|
|
|
|
// without it both the standard label corresponding to the stock id and the
|
|
|
|
// bitmap would be shown
|
|
|
|
#define wxBU_NOTEXT 0x0002
|
|
|
|
|
|
|
|
|
2009-06-14 23:36:16 -04:00
|
|
|
#include "wx/bitmap.h"
|
2001-06-26 16:59:19 -04:00
|
|
|
#include "wx/control.h"
|
|
|
|
|
2008-03-26 11:06:00 -04:00
|
|
|
extern WXDLLIMPEXP_DATA_CORE(const char) wxButtonNameStr[];
|
2001-06-26 16:59:19 -04:00
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxButton: a push button
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2008-03-26 11:06:00 -04:00
|
|
|
class WXDLLIMPEXP_CORE wxButtonBase : public wxControl
|
2001-06-26 16:59:19 -04:00
|
|
|
{
|
|
|
|
public:
|
2004-01-15 08:49:22 -05:00
|
|
|
wxButtonBase() { }
|
2003-07-21 20:24:07 -04:00
|
|
|
|
2009-06-14 18:55:24 -04:00
|
|
|
// show the image in the button in addition to the label: this method is
|
|
|
|
// supported on all (major) platforms
|
|
|
|
void SetBitmap(const wxBitmap& bitmap, wxDirection dir = wxLEFT)
|
|
|
|
{
|
|
|
|
SetBitmapLabel(bitmap);
|
|
|
|
SetBitmapPosition(dir);
|
|
|
|
}
|
|
|
|
|
|
|
|
wxBitmap GetBitmap() const { return DoGetBitmap(State_Normal); }
|
|
|
|
|
|
|
|
// Methods for setting individual images for different states: normal,
|
|
|
|
// selected (meaning pushed or pressed), focused (meaning normal state for
|
|
|
|
// a focused button), disabled or hover (a.k.a. hot or current).
|
|
|
|
//
|
|
|
|
// Remember that SetBitmap() itself must be called before any other
|
|
|
|
// SetBitmapXXX() methods (except for SetBitmapLabel() which is a synonym
|
|
|
|
// for it anyhow) and that all bitmaps passed to these functions should be
|
|
|
|
// of the same size.
|
|
|
|
void SetBitmapLabel(const wxBitmap& bitmap)
|
|
|
|
{ DoSetBitmap(bitmap, State_Normal); }
|
|
|
|
void SetBitmapPressed(const wxBitmap& bitmap)
|
|
|
|
{ DoSetBitmap(bitmap, State_Pressed); }
|
|
|
|
void SetBitmapDisabled(const wxBitmap& bitmap)
|
|
|
|
{ DoSetBitmap(bitmap, State_Disabled); }
|
|
|
|
void SetBitmapCurrent(const wxBitmap& bitmap)
|
|
|
|
{ DoSetBitmap(bitmap, State_Current); }
|
|
|
|
void SetBitmapFocus(const wxBitmap& bitmap)
|
|
|
|
{ DoSetBitmap(bitmap, State_Focused); }
|
|
|
|
|
|
|
|
wxBitmap GetBitmapLabel() const { return DoGetBitmap(State_Normal); }
|
|
|
|
wxBitmap GetBitmapPressed() const { return DoGetBitmap(State_Pressed); }
|
|
|
|
wxBitmap GetBitmapDisabled() const { return DoGetBitmap(State_Disabled); }
|
|
|
|
wxBitmap GetBitmapCurrent() const { return DoGetBitmap(State_Current); }
|
|
|
|
wxBitmap GetBitmapFocus() const { return DoGetBitmap(State_Focused); }
|
|
|
|
|
2001-06-26 16:59:19 -04:00
|
|
|
|
|
|
|
// set the margins around the image
|
2009-06-14 18:55:24 -04:00
|
|
|
void SetBitmapMargins(wxCoord x, wxCoord y) { DoSetBitmapMargins(x, y); }
|
|
|
|
void SetBitmapMargins(const wxSize& sz) { DoSetBitmapMargins(sz.x, sz.y); }
|
|
|
|
|
|
|
|
// set the image position relative to the text, i.e. wxLEFT means that the
|
|
|
|
// image is to the left of the text (this is the default)
|
2009-06-15 00:23:54 -04:00
|
|
|
void SetBitmapPosition(wxDirection dir);
|
2009-06-14 18:55:24 -04:00
|
|
|
|
2001-06-26 16:59:19 -04:00
|
|
|
|
2007-04-08 18:18:35 -04:00
|
|
|
// make this button the default button in its top level window
|
|
|
|
//
|
|
|
|
// returns the old default item (possibly NULL)
|
|
|
|
virtual wxWindow *SetDefault();
|
2001-06-26 16:59:19 -04:00
|
|
|
|
2003-12-02 22:24:47 -05:00
|
|
|
// Buttons on MSW can look bad if they are not native colours, because
|
|
|
|
// then they become owner-drawn and not theme-drawn. Disable it here
|
|
|
|
// in wxButtonBase to make it consistent.
|
|
|
|
virtual bool ShouldInheritColours() const { return false; }
|
|
|
|
|
2001-06-26 16:59:19 -04:00
|
|
|
// returns the default button size for this platform
|
|
|
|
static wxSize GetDefaultSize();
|
2003-07-21 20:24:07 -04:00
|
|
|
|
2009-06-14 18:55:24 -04:00
|
|
|
// wxUniv-compatible and deprecated equivalents to SetBitmapXXX()
|
|
|
|
#if WXWIN_COMPATIBILITY_2_8
|
|
|
|
void SetImageLabel(const wxBitmap& bitmap) { SetBitmap(bitmap); }
|
|
|
|
void SetImageMargins(wxCoord x, wxCoord y) { SetBitmapMargins(x, y); }
|
|
|
|
#endif // WXWIN_COMPATIBILITY_2_8
|
|
|
|
|
|
|
|
// backwards compatible names for pressed/current bitmaps: they're not
|
|
|
|
// deprecated as there is nothing really wrong with using them and no real
|
|
|
|
// advantage to using the new names but the new names are still preferred
|
|
|
|
wxBitmap GetBitmapSelected() const { return GetBitmapPressed(); }
|
|
|
|
wxBitmap GetBitmapHover() const { return GetBitmapCurrent(); }
|
|
|
|
|
|
|
|
void SetBitmapSelected(const wxBitmap& bitmap) { SetBitmapPressed(bitmap); }
|
|
|
|
void SetBitmapHover(const wxBitmap& bitmap) { SetBitmapCurrent(bitmap); }
|
|
|
|
|
2007-11-13 07:10:34 -05:00
|
|
|
|
2009-06-15 00:23:54 -04:00
|
|
|
// this enum is not part of wx public API, it is public because it is used
|
|
|
|
// in non wxButton-derived classes internally
|
|
|
|
//
|
|
|
|
// also notice that MSW code relies on the values of the enum elements, do
|
|
|
|
// not change them without revising src/msw/button.cpp
|
2009-06-14 18:55:24 -04:00
|
|
|
enum State
|
|
|
|
{
|
|
|
|
State_Normal,
|
|
|
|
State_Current, // a.k.a. hot or "hovering"
|
2009-06-15 00:23:54 -04:00
|
|
|
State_Pressed, // a.k.a. "selected" in public API for some reason
|
2009-06-14 18:55:24 -04:00
|
|
|
State_Disabled,
|
|
|
|
State_Focused,
|
|
|
|
State_Max
|
|
|
|
};
|
|
|
|
|
2009-06-17 18:13:46 -04:00
|
|
|
// return true if this button shouldn't show the text label, either because
|
|
|
|
// it doesn't have it or because it was explicitly disabled with wxBU_NOTEXT
|
|
|
|
bool DontShowLabel() const
|
|
|
|
{
|
|
|
|
return HasFlag(wxBU_NOTEXT) || GetLabel().empty();
|
|
|
|
}
|
|
|
|
|
|
|
|
// return true if we do show the label
|
|
|
|
bool ShowsLabel() const
|
|
|
|
{
|
|
|
|
return !DontShowLabel();
|
|
|
|
}
|
|
|
|
|
2009-06-15 00:23:54 -04:00
|
|
|
protected:
|
|
|
|
// choose the default border for this window
|
|
|
|
virtual wxBorder GetDefaultBorder() const { return wxBORDER_NONE; }
|
|
|
|
|
2009-06-14 18:55:24 -04:00
|
|
|
virtual wxBitmap DoGetBitmap(State WXUNUSED(which)) const
|
|
|
|
{ return wxBitmap(); }
|
|
|
|
virtual void DoSetBitmap(const wxBitmap& WXUNUSED(bitmap),
|
|
|
|
State WXUNUSED(which))
|
|
|
|
{ }
|
2009-06-15 19:10:16 -04:00
|
|
|
|
|
|
|
virtual wxSize DoGetBitmapMargins() const
|
|
|
|
{ return wxSize(0, 0); }
|
|
|
|
|
2009-06-14 18:55:24 -04:00
|
|
|
virtual void DoSetBitmapMargins(wxCoord WXUNUSED(x), wxCoord WXUNUSED(y))
|
|
|
|
{ }
|
2009-06-15 19:10:16 -04:00
|
|
|
|
2009-06-15 00:23:54 -04:00
|
|
|
virtual void DoSetBitmapPosition(wxDirection WXUNUSED(dir))
|
|
|
|
{ }
|
2009-06-14 18:55:24 -04:00
|
|
|
|
|
|
|
|
2009-02-08 06:45:59 -05:00
|
|
|
wxDECLARE_NO_COPY_CLASS(wxButtonBase);
|
2001-06-26 16:59:19 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
#if defined(__WXUNIVERSAL__)
|
|
|
|
#include "wx/univ/button.h"
|
|
|
|
#elif defined(__WXMSW__)
|
|
|
|
#include "wx/msw/button.h"
|
1998-07-10 10:15:17 -04:00
|
|
|
#elif defined(__WXMOTIF__)
|
2001-06-26 16:59:19 -04:00
|
|
|
#include "wx/motif/button.h"
|
2006-01-22 22:27:34 -05:00
|
|
|
#elif defined(__WXGTK20__)
|
2001-06-26 16:59:19 -04:00
|
|
|
#include "wx/gtk/button.h"
|
2006-01-22 22:27:34 -05:00
|
|
|
#elif defined(__WXGTK__)
|
|
|
|
#include "wx/gtk1/button.h"
|
1998-08-14 20:23:28 -04:00
|
|
|
#elif defined(__WXMAC__)
|
2008-06-11 15:17:41 -04:00
|
|
|
#include "wx/osx/button.h"
|
2003-03-22 01:18:36 -05:00
|
|
|
#elif defined(__WXCOCOA__)
|
|
|
|
#include "wx/cocoa/button.h"
|
1999-07-27 23:38:12 -04:00
|
|
|
#elif defined(__WXPM__)
|
2001-06-26 16:59:19 -04:00
|
|
|
#include "wx/os2/button.h"
|
2005-01-24 02:38:52 -05:00
|
|
|
#elif defined(__WXPALMOS__)
|
|
|
|
#include "wx/palmos/button.h"
|
1998-05-20 10:01:55 -04:00
|
|
|
#endif
|
|
|
|
|
2001-06-26 16:59:19 -04:00
|
|
|
#endif // wxUSE_BUTTON
|
|
|
|
|
1998-05-20 10:01:55 -04:00
|
|
|
#endif
|
1998-08-14 20:23:28 -04:00
|
|
|
// _WX_BUTTON_H_BASE_
|