1999-10-22 18:00:39 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/ctrlsub.h (read: "wxConTRoL with SUBitems")
|
|
|
|
// Purpose: wxControlWithItems interface
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 22.10.99
|
|
|
|
// RCS-ID: $Id$
|
2004-05-23 14:56:36 +00:00
|
|
|
// Copyright: (c) wxWidgets team
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
1999-10-22 18:00:39 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_CTRLSUB_H_BASE_
|
|
|
|
#define _WX_CTRLSUB_H_BASE_
|
|
|
|
|
2005-03-16 16:18:31 +00:00
|
|
|
#include "wx/defs.h"
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
#if wxUSE_CONTROLS
|
|
|
|
|
1999-10-22 18:00:39 +00:00
|
|
|
#include "wx/control.h" // base class
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2001-06-26 20:59:19 +00:00
|
|
|
// wxItemContainer defines an interface which is implemented by all controls
|
1999-10-22 18:00:39 +00:00
|
|
|
// which have string subitems each of which may be selected.
|
|
|
|
//
|
2005-02-13 19:01:17 +00:00
|
|
|
// It is decomposed in wxItemContainerImmutable which omits all methods
|
|
|
|
// adding/removing items and is used by wxRadioBox and wxItemContainer itself.
|
|
|
|
//
|
2001-06-26 20:59:19 +00:00
|
|
|
// Examples: wxListBox, wxCheckListBox, wxChoice and wxComboBox (which
|
|
|
|
// implements an extended interface deriving from this one)
|
1999-10-22 18:00:39 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2005-02-13 19:01:17 +00:00
|
|
|
class WXDLLEXPORT wxItemContainerImmutable
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxItemContainerImmutable() { }
|
|
|
|
virtual ~wxItemContainerImmutable();
|
|
|
|
|
|
|
|
// accessing strings
|
|
|
|
// -----------------
|
|
|
|
|
2006-03-23 22:05:23 +00:00
|
|
|
virtual unsigned int GetCount() const = 0;
|
2005-02-13 19:01:17 +00:00
|
|
|
bool IsEmpty() const { return GetCount() == 0; }
|
|
|
|
|
2006-03-23 22:05:23 +00:00
|
|
|
virtual wxString GetString(unsigned int n) const = 0;
|
2005-02-13 19:01:17 +00:00
|
|
|
wxArrayString GetStrings() const;
|
2006-03-23 22:05:23 +00:00
|
|
|
virtual void SetString(unsigned int n, const wxString& s) = 0;
|
2005-09-27 16:54:43 +00:00
|
|
|
|
|
|
|
// finding string natively is either case sensitive or insensitive
|
|
|
|
// but never both so fall back to this base version for not
|
|
|
|
// supported search type
|
|
|
|
virtual int FindString(const wxString& s, bool bCase = false) const
|
|
|
|
{
|
2006-03-23 22:05:23 +00:00
|
|
|
unsigned int count = GetCount();
|
2005-09-27 16:54:43 +00:00
|
|
|
|
2006-03-23 22:05:23 +00:00
|
|
|
for ( unsigned int i = 0; i < count ; ++i )
|
2005-09-27 16:54:43 +00:00
|
|
|
{
|
|
|
|
if (GetString(i).IsSameAs( s , bCase ))
|
2006-03-23 22:05:23 +00:00
|
|
|
return (int)i;
|
2005-09-27 16:54:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return wxNOT_FOUND;
|
|
|
|
}
|
2005-02-13 19:01:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
// selection
|
|
|
|
// ---------
|
|
|
|
|
|
|
|
virtual void SetSelection(int n) = 0;
|
|
|
|
virtual int GetSelection() const = 0;
|
|
|
|
|
|
|
|
// set selection to the specified string, return false if not found
|
|
|
|
bool SetStringSelection(const wxString& s);
|
|
|
|
|
|
|
|
// return the selected string or empty string if none
|
|
|
|
wxString GetStringSelection() const;
|
|
|
|
|
|
|
|
// this is the same as SetSelection( for single-selection controls but
|
|
|
|
// reads better for multi-selection ones
|
|
|
|
void Select(int n) { SetSelection(n); }
|
|
|
|
|
2005-02-23 16:39:25 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
// check that the index is valid
|
2006-03-23 22:05:23 +00:00
|
|
|
inline bool IsValid(unsigned int n) const { return n < GetCount(); }
|
|
|
|
inline bool IsValidInsert(unsigned int n) const { return n <= GetCount(); }
|
2005-02-13 19:01:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxItemContainer : public wxItemContainerImmutable
|
1999-10-22 18:00:39 +00:00
|
|
|
{
|
|
|
|
public:
|
2004-01-15 13:49:22 +00:00
|
|
|
wxItemContainer() { m_clientDataItemsType = wxClientData_None; }
|
2002-01-07 21:52:28 +00:00
|
|
|
virtual ~wxItemContainer();
|
1999-10-22 18:00:39 +00:00
|
|
|
|
|
|
|
// adding items
|
|
|
|
// ------------
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
int Append(const wxString& item)
|
|
|
|
{ return DoAppend(item); }
|
|
|
|
int Append(const wxString& item, void *clientData)
|
|
|
|
{ int n = DoAppend(item); SetClientData(n, clientData); return n; }
|
|
|
|
int Append(const wxString& item, wxClientData *clientData)
|
|
|
|
{ int n = DoAppend(item); SetClientObject(n, clientData); return n; }
|
1999-10-22 18:00:39 +00:00
|
|
|
|
2003-08-18 09:57:02 +00:00
|
|
|
// only for rtti needs (separate name)
|
|
|
|
void AppendString( const wxString& item)
|
2005-02-13 16:29:31 +00:00
|
|
|
{ Append( item ); }
|
2003-08-18 09:57:02 +00:00
|
|
|
|
2002-01-20 15:20:57 +00:00
|
|
|
// append several items at once to the control
|
|
|
|
void Append(const wxArrayString& strings);
|
|
|
|
|
2006-03-23 22:05:23 +00:00
|
|
|
int Insert(const wxString& item, unsigned int pos)
|
2003-05-09 12:58:28 +00:00
|
|
|
{ return DoInsert(item, pos); }
|
2006-03-23 22:05:23 +00:00
|
|
|
int Insert(const wxString& item, unsigned int pos, void *clientData);
|
|
|
|
int Insert(const wxString& item, unsigned int pos, wxClientData *clientData);
|
2003-05-09 12:58:28 +00:00
|
|
|
|
1999-10-22 18:00:39 +00:00
|
|
|
// deleting items
|
|
|
|
// --------------
|
|
|
|
|
|
|
|
virtual void Clear() = 0;
|
2006-03-23 22:05:23 +00:00
|
|
|
virtual void Delete(unsigned int n) = 0;
|
1999-10-22 18:00:39 +00:00
|
|
|
|
|
|
|
// misc
|
|
|
|
// ----
|
|
|
|
|
|
|
|
// client data stuff
|
2006-03-23 22:05:23 +00:00
|
|
|
void SetClientData(unsigned int n, void* clientData);
|
|
|
|
void* GetClientData(unsigned int n) const;
|
1999-10-22 18:00:39 +00:00
|
|
|
|
2006-03-23 22:05:23 +00:00
|
|
|
void SetClientObject(unsigned int n, wxClientData* clientData);
|
|
|
|
wxClientData* GetClientObject(unsigned int n) const;
|
1999-10-22 18:00:39 +00:00
|
|
|
|
|
|
|
bool HasClientObjectData() const
|
2001-06-26 20:59:19 +00:00
|
|
|
{ return m_clientDataItemsType == wxClientData_Object; }
|
1999-10-22 18:00:39 +00:00
|
|
|
bool HasClientUntypedData() const
|
2001-06-26 20:59:19 +00:00
|
|
|
{ return m_clientDataItemsType == wxClientData_Void; }
|
1999-10-22 18:00:39 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual int DoAppend(const wxString& item) = 0;
|
2006-03-23 22:05:23 +00:00
|
|
|
virtual int DoInsert(const wxString& item, unsigned int pos) = 0;
|
1999-10-22 18:00:39 +00:00
|
|
|
|
2006-03-23 22:05:23 +00:00
|
|
|
virtual void DoSetItemClientData(unsigned int n, void* clientData) = 0;
|
|
|
|
virtual void* DoGetItemClientData(unsigned int n) const = 0;
|
|
|
|
virtual void DoSetItemClientObject(unsigned int n, wxClientData* clientData) = 0;
|
|
|
|
virtual wxClientData* DoGetItemClientObject(unsigned int n) const = 0;
|
1999-10-22 18:00:39 +00:00
|
|
|
|
2006-05-06 15:48:27 +00:00
|
|
|
|
1999-10-22 18:00:39 +00:00
|
|
|
// the type of the client data for the items
|
|
|
|
wxClientDataType m_clientDataItemsType;
|
|
|
|
};
|
|
|
|
|
2003-09-20 18:34:57 +00:00
|
|
|
// this macro must (unfortunately) be used in any class deriving from both
|
|
|
|
// wxItemContainer and wxControl because otherwise there is ambiguity when
|
|
|
|
// calling GetClientXXX() functions -- the compiler can't choose between the
|
|
|
|
// two versions
|
|
|
|
#define wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST \
|
|
|
|
void SetClientData(void *data) \
|
|
|
|
{ wxControl::SetClientData(data); } \
|
|
|
|
void *GetClientData() const \
|
|
|
|
{ return wxControl::GetClientData(); } \
|
|
|
|
void SetClientObject(wxClientData *data) \
|
|
|
|
{ wxControl::SetClientObject(data); } \
|
|
|
|
wxClientData *GetClientObject() const \
|
|
|
|
{ return wxControl::GetClientObject(); } \
|
2006-03-23 22:05:23 +00:00
|
|
|
void SetClientData(unsigned int n, void* clientData) \
|
2003-09-20 18:34:57 +00:00
|
|
|
{ wxItemContainer::SetClientData(n, clientData); } \
|
2006-03-23 22:05:23 +00:00
|
|
|
void* GetClientData(unsigned int n) const \
|
2003-09-20 18:34:57 +00:00
|
|
|
{ return wxItemContainer::GetClientData(n); } \
|
2006-03-23 22:05:23 +00:00
|
|
|
void SetClientObject(unsigned int n, wxClientData* clientData) \
|
2003-09-20 18:34:57 +00:00
|
|
|
{ wxItemContainer::SetClientObject(n, clientData); } \
|
2006-03-23 22:05:23 +00:00
|
|
|
wxClientData* GetClientObject(unsigned int n) const \
|
2003-09-20 18:34:57 +00:00
|
|
|
{ return wxItemContainer::GetClientObject(n); }
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
class WXDLLEXPORT wxControlWithItems : public wxControl, public wxItemContainer
|
|
|
|
{
|
|
|
|
public:
|
2004-01-15 13:49:22 +00:00
|
|
|
wxControlWithItems() { }
|
2002-05-11 17:14:46 +00:00
|
|
|
virtual ~wxControlWithItems();
|
2003-09-20 18:34:57 +00:00
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
// we have to redefine these functions here to avoid ambiguities in classes
|
|
|
|
// deriving from us which would arise otherwise because both base classses
|
|
|
|
// have the methods with the same names - hopefully, a smart compiler can
|
|
|
|
// optimize away these simple inline wrappers so we don't suffer much from
|
|
|
|
// this
|
2003-09-20 18:34:57 +00:00
|
|
|
wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST
|
2003-07-22 00:24:07 +00:00
|
|
|
|
2003-10-16 10:00:12 +00:00
|
|
|
// usually the controls like list/combo boxes have their own background
|
|
|
|
// colour
|
|
|
|
virtual bool ShouldInheritColours() const { return false; }
|
|
|
|
|
2004-05-03 12:40:29 +00:00
|
|
|
protected:
|
|
|
|
// we can't compute our best size before the items are added to the control
|
|
|
|
// which is done after calling SetInitialBestSize() (it is called from the
|
|
|
|
// base class ctor and the items are added in the derived class ctor), so
|
|
|
|
// don't do anything at all here as our size will be changed later anyhow
|
|
|
|
//
|
|
|
|
// of course, all derived classes *must* call SetBestSize() from their
|
|
|
|
// ctors for this to work!
|
|
|
|
virtual void SetInitialBestSize(const wxSize& WXUNUSED(size)) { }
|
|
|
|
|
2006-05-06 15:48:27 +00:00
|
|
|
// fill in the client object or data field of the event as appropriate
|
|
|
|
//
|
|
|
|
// calls InitCommandEvent() and, if n != wxNOT_FOUND, also sets the per
|
|
|
|
// item client data
|
|
|
|
void InitCommandEventWithItems(wxCommandEvent& event, int n);
|
|
|
|
|
2003-07-22 00:24:07 +00:00
|
|
|
private:
|
2005-12-23 00:58:32 +00:00
|
|
|
DECLARE_ABSTRACT_CLASS(wxControlWithItems)
|
2003-07-22 09:01:02 +00:00
|
|
|
DECLARE_NO_COPY_CLASS(wxControlWithItems)
|
2001-06-26 20:59:19 +00:00
|
|
|
};
|
|
|
|
|
2005-02-13 17:08:27 +00:00
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// inline functions
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
#endif // wxUSE_CONTROLS
|
1999-10-22 18:00:39 +00:00
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
#endif // _WX_CTRLSUB_H_BASE_
|