default implementation of Get(Class)DefaultAttributes()
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@26523 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
1b69c81574
commit
34040e3126
@ -22,7 +22,8 @@
|
|||||||
class WXDLLEXPORT wxControl : public wxControlBase
|
class WXDLLEXPORT wxControl : public wxControlBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
wxControl();
|
wxControl() { }
|
||||||
|
|
||||||
wxControl(wxWindow *parent, wxWindowID id,
|
wxControl(wxWindow *parent, wxWindowID id,
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxSize& size = wxDefaultSize, long style = 0,
|
const wxSize& size = wxDefaultSize, long style = 0,
|
||||||
@ -43,9 +44,18 @@ public:
|
|||||||
// Simulates an event
|
// Simulates an event
|
||||||
virtual void Command(wxCommandEvent& event) { ProcessCommand(event); }
|
virtual void Command(wxCommandEvent& event) { ProcessCommand(event); }
|
||||||
|
|
||||||
|
|
||||||
// implementation from now on
|
// implementation from now on
|
||||||
// --------------------------
|
// --------------------------
|
||||||
|
|
||||||
|
virtual wxVisualAttributes GetDefaultAttributes() const
|
||||||
|
{
|
||||||
|
return GetClassDefaultAttributes(GetWindowVariant());
|
||||||
|
}
|
||||||
|
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
// Calls the callback and appropriate event handlers
|
// Calls the callback and appropriate event handlers
|
||||||
bool ProcessCommand(wxCommandEvent& event);
|
bool ProcessCommand(wxCommandEvent& event);
|
||||||
|
|
||||||
@ -105,6 +115,14 @@ protected:
|
|||||||
// default style for the control include WS_TABSTOP if it AcceptsFocus()
|
// default style for the control include WS_TABSTOP if it AcceptsFocus()
|
||||||
virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
|
virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
|
||||||
|
|
||||||
|
// this is a helper for the derived class GetClassDefaultAttributes()
|
||||||
|
// implementation: it returns the right colours for the classes which
|
||||||
|
// contain something else (e.g. wxListBox, wxTextCtrl, ...) instead of
|
||||||
|
// being simple controls (such as wxButton, wxCheckBox, ...)
|
||||||
|
static wxVisualAttributes
|
||||||
|
GetCompositeControlsDefaultAttributes(wxWindowVariant variant);
|
||||||
|
|
||||||
|
|
||||||
// for controls like radiobuttons which are really composite this array
|
// for controls like radiobuttons which are really composite this array
|
||||||
// holds the ids (not HWNDs!) of the sub controls
|
// holds the ids (not HWNDs!) of the sub controls
|
||||||
wxArrayLong m_subControls;
|
wxArrayLong m_subControls;
|
||||||
|
@ -9,6 +9,14 @@
|
|||||||
// Licence: wxWindows licence
|
// Licence: wxWindows licence
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// declarations
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// headers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
||||||
#pragma implementation "control.h"
|
#pragma implementation "control.h"
|
||||||
#endif
|
#endif
|
||||||
@ -27,6 +35,7 @@
|
|||||||
#include "wx/app.h"
|
#include "wx/app.h"
|
||||||
#include "wx/dcclient.h"
|
#include "wx/dcclient.h"
|
||||||
#include "wx/log.h"
|
#include "wx/log.h"
|
||||||
|
#include "wx/settings.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/control.h"
|
#include "wx/control.h"
|
||||||
@ -37,22 +46,32 @@
|
|||||||
#include <commctrl.h>
|
#include <commctrl.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxWin macros
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
IMPLEMENT_ABSTRACT_CLASS(wxControl, wxWindow)
|
IMPLEMENT_ABSTRACT_CLASS(wxControl, wxWindow)
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(wxControl, wxWindow)
|
BEGIN_EVENT_TABLE(wxControl, wxWindow)
|
||||||
EVT_ERASE_BACKGROUND(wxControl::OnEraseBackground)
|
EVT_ERASE_BACKGROUND(wxControl::OnEraseBackground)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
// Item members
|
// ============================================================================
|
||||||
wxControl::wxControl()
|
// wxControl implementation
|
||||||
{
|
// ============================================================================
|
||||||
}
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxControl ctor/dtor
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
wxControl::~wxControl()
|
wxControl::~wxControl()
|
||||||
{
|
{
|
||||||
m_isBeingDeleted = TRUE;
|
m_isBeingDeleted = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// control window creation
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
bool wxControl::Create(wxWindow *parent,
|
bool wxControl::Create(wxWindow *parent,
|
||||||
wxWindowID id,
|
wxWindowID id,
|
||||||
@ -147,8 +166,9 @@ bool wxControl::MSWCreateControl(const wxChar *classname,
|
|||||||
// install wxWindows window proc for this window
|
// install wxWindows window proc for this window
|
||||||
SubclassWin(m_hWnd);
|
SubclassWin(m_hWnd);
|
||||||
|
|
||||||
// controls use the same font and colours as their parent dialog by default
|
// set up fonts and colours
|
||||||
InheritAttributes();
|
InheritAttributes();
|
||||||
|
SetFont(GetDefaultAttributes().font);
|
||||||
|
|
||||||
// set the size now if no initial size specified
|
// set the size now if no initial size specified
|
||||||
if ( w <= 0 || h <= 0 )
|
if ( w <= 0 || h <= 0 )
|
||||||
@ -159,6 +179,10 @@ bool wxControl::MSWCreateControl(const wxChar *classname,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// various accessors
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
wxBorder wxControl::GetDefaultBorder() const
|
wxBorder wxControl::GetDefaultBorder() const
|
||||||
{
|
{
|
||||||
// we want to automatically give controls a sunken style (confusingly,
|
// we want to automatically give controls a sunken style (confusingly,
|
||||||
@ -167,11 +191,57 @@ wxBorder wxControl::GetDefaultBorder() const
|
|||||||
return wxBORDER_SUNKEN;
|
return wxBORDER_SUNKEN;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WXDWORD wxControl::MSWGetStyle(long style, WXDWORD *exstyle) const
|
||||||
|
{
|
||||||
|
long msStyle = wxWindow::MSWGetStyle(style, exstyle);
|
||||||
|
|
||||||
|
if ( AcceptsFocus() )
|
||||||
|
{
|
||||||
|
msStyle |= WS_TABSTOP;
|
||||||
|
}
|
||||||
|
|
||||||
|
return msStyle;
|
||||||
|
}
|
||||||
|
|
||||||
wxSize wxControl::DoGetBestSize() const
|
wxSize wxControl::DoGetBestSize() const
|
||||||
{
|
{
|
||||||
return wxSize(DEFAULT_ITEM_WIDTH, DEFAULT_ITEM_HEIGHT);
|
return wxSize(DEFAULT_ITEM_WIDTH, DEFAULT_ITEM_HEIGHT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* static */ wxVisualAttributes
|
||||||
|
wxControl::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
|
||||||
|
{
|
||||||
|
wxVisualAttributes attrs;
|
||||||
|
|
||||||
|
// old school (i.e. not "common") controls use the standard dialog font
|
||||||
|
// by default
|
||||||
|
attrs.font = wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT);
|
||||||
|
|
||||||
|
// most, or at least many, of the controls use the same colours as the
|
||||||
|
// buttons -- others will have to override this (and possibly simply call
|
||||||
|
// GetCompositeControlsDefaultAttributes() from their versions)
|
||||||
|
attrs.colFg = wxSystemSettings::GetColour(wxSYS_COLOUR_BTNTEXT);
|
||||||
|
attrs.colBg = wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE);
|
||||||
|
|
||||||
|
return attrs;
|
||||||
|
}
|
||||||
|
|
||||||
|
// another version for the "composite", i.e. non simple controls
|
||||||
|
/* static */ wxVisualAttributes
|
||||||
|
wxControl::GetCompositeControlsDefaultAttributes(wxWindowVariant variant)
|
||||||
|
{
|
||||||
|
wxVisualAttributes attrs;
|
||||||
|
attrs.font = wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT);
|
||||||
|
attrs.colFg = wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOWTEXT);
|
||||||
|
attrs.colBg = wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW);
|
||||||
|
|
||||||
|
return attrs;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// message handling
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
bool wxControl::ProcessCommand(wxCommandEvent& event)
|
bool wxControl::ProcessCommand(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
return GetEventHandler()->ProcessEvent(event);
|
return GetEventHandler()->ProcessEvent(event);
|
||||||
@ -283,22 +353,13 @@ WXHBRUSH wxControl::OnCtlColor(WXHDC pDC, WXHWND WXUNUSED(pWnd), WXUINT WXUNUSED
|
|||||||
return (WXHBRUSH)brush->GetResourceHandle();
|
return (WXHBRUSH)brush->GetResourceHandle();
|
||||||
}
|
}
|
||||||
|
|
||||||
WXDWORD wxControl::MSWGetStyle(long style, WXDWORD *exstyle) const
|
|
||||||
{
|
|
||||||
long msStyle = wxWindow::MSWGetStyle(style, exstyle);
|
|
||||||
|
|
||||||
if ( AcceptsFocus() )
|
|
||||||
{
|
|
||||||
msStyle |= WS_TABSTOP;
|
|
||||||
}
|
|
||||||
|
|
||||||
return msStyle;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
// global functions
|
// global functions
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// this is used in radiobox.cpp and slider95.cpp and should be removed as soon
|
||||||
|
// as it is not needed there any more!
|
||||||
|
//
|
||||||
// Call this repeatedly for several wnds to find the overall size
|
// Call this repeatedly for several wnds to find the overall size
|
||||||
// of the widget.
|
// of the widget.
|
||||||
// Call it initially with -1 for all values in rect.
|
// Call it initially with -1 for all values in rect.
|
||||||
|
@ -3137,8 +3137,6 @@ bool wxWindowMSW::MSWCreate(const wxChar *wclass,
|
|||||||
|
|
||||||
SubclassWin(m_hWnd);
|
SubclassWin(m_hWnd);
|
||||||
|
|
||||||
SetFont(wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT));
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user