git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@35761
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
///////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////
+// Name: wx/os2/checklst.h
// Purpose: wxCheckListBox class - a listbox with checkable items
// Note: this is an optional class.
// Author: David Webster
// Purpose: wxCheckListBox class - a listbox with checkable items
// Note: this is an optional class.
// Author: David Webster
class wxOwnerDrawn; // so the compiler knows, it is a class.
class wxOwnerDrawn; // so the compiler knows, it is a class.
-class wxCheckListBoxItem; // fwd decl, define in checklst.cpp
-
-class WXDLLEXPORT wxCheckListBox : public wxListBox
+class WXDLLEXPORT wxCheckListBox : public wxCheckListBoxBase
// Override base class virtuals
//
virtual void Delete(int n);
// Override base class virtuals
//
virtual void Delete(int n);
- virtual void InsertItems( int nItems
- ,const wxString asItems[]
- ,int nPos
- );
virtual bool SetFont(const wxFont &rFont);
virtual bool SetFont(const wxFont &rFont);
//
bool IsChecked(size_t uiIndex) const;
void Check( size_t uiIndex
//
bool IsChecked(size_t uiIndex) const;
void Check( size_t uiIndex
virtual wxOwnerDrawn* CreateItem(size_t n);
virtual long OS2OnMeasure(WXMEASUREITEMSTRUCT* pItem);
virtual wxOwnerDrawn* CreateItem(size_t n);
virtual long OS2OnMeasure(WXMEASUREITEMSTRUCT* pItem);
+ virtual void DoInsertItems(const wxArrayString& items, int pos);
+
//
// Pressing space or clicking the check box toggles the item
//
//
// Pressing space or clicking the check box toggles the item
//
DECLARE_DYNAMIC_CLASS(wxCheckListBox)
DECLARE_EVENT_TABLE()
DECLARE_DYNAMIC_CLASS(wxCheckListBox)
DECLARE_EVENT_TABLE()
-}; // end of CLASS wxCheckListBoxItem
+}; // end of CLASS wxCheckListBox
#endif
// _WX_CHECKLST_H_
#endif
// _WX_CHECKLST_H_
///////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////
+// Name: src/os2/checklst.cpp
// Purpose: implementation of wxCheckListBox class
// Author: David Webster
// Modified by:
// Purpose: implementation of wxCheckListBox class
// Author: David Webster
// Modified by:
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
+#if wxUSE_CHECKLISTBOX && wxUSE_OWNER_DRAWN
#include "wx/object.h"
#include "wx/colour.h"
#include "wx/object.h"
#include "wx/colour.h"
#include "wx/settings.h"
#include "wx/dcmemory.h"
#include "wx/dcscreen.h"
#include "wx/settings.h"
#include "wx/dcmemory.h"
#include "wx/dcscreen.h"
-#include "wx/os2/checklst.h"
+#include "wx/checklst.h"
#include "wx/log.h"
#define INCL_PM
#include "wx/log.h"
#define INCL_PM
- wxCheckListBoxItem( wxCheckListBox* pParent
- ,size_t nIndex
+ wxCheckListBoxItem( wxCheckListBox* pParent,
+ size_t nIndex
);
//
// Drawing functions
//
);
//
// Drawing functions
//
- virtual bool OnDrawItem( wxDC& rDc
- ,const wxRect& rRect
- ,wxODAction eAct
- ,wxODStatus eStat
+ virtual bool OnDrawItem( wxDC& rDc,
+ const wxRect& rRect,
+ wxODAction eAct,
+ wxODStatus eStat
void Toggle(void) { Check(!IsChecked()); }
private:
void Toggle(void) { Check(!IsChecked()); }
private:
- bool m_bChecked;
- wxCheckListBox* m_pParent;
- size_t m_nIndex;
+ bool m_bChecked;
+ wxCheckListBox* m_pParent;
+ size_t m_nIndex;
}; // end of CLASS wxCheckListBoxItem
}; // end of CLASS wxCheckListBoxItem
-wxCheckListBoxItem::wxCheckListBoxItem (
- wxCheckListBox* pParent
-, size_t nIndex
-)
-: wxOwnerDrawn( wxEmptyString
- ,TRUE // checkable
- )
+
+
+wxCheckListBoxItem::wxCheckListBoxItem ( wxCheckListBox* pParent,
+ size_t nIndex)
+ :wxOwnerDrawn( wxEmptyString, true /* checkable */ )
m_pParent = pParent;
m_nIndex = nIndex;
m_pParent = pParent;
m_nIndex = nIndex;
SetMarginWidth(GetDefaultMarginWidth());
} // end of wxCheckListBoxItem::wxCheckListBoxItem
SetMarginWidth(GetDefaultMarginWidth());
} // end of wxCheckListBoxItem::wxCheckListBoxItem
-bool wxCheckListBoxItem::OnDrawItem (
- wxDC& rDc
-, const wxRect& rRect
-, wxODAction eAct
-, wxODStatus eStat
-)
+
+
+bool wxCheckListBoxItem::OnDrawItem ( wxDC& rDc,
+ const wxRect& rRect,
+ wxODAction eAct,
+ wxODStatus eStat )
- ::WinQueryWindowRect( m_pParent->GetHWND()
- ,&rDc.m_vRclPaint
- );
+ ::WinQueryWindowRect( m_pParent->GetHWND(), &rDc.m_vRclPaint );
if (IsChecked())
eStat = (wxOwnerDrawn::wxODStatus)(eStat | wxOwnerDrawn::wxODChecked);
if (IsChecked())
eStat = (wxOwnerDrawn::wxODStatus)(eStat | wxOwnerDrawn::wxODChecked);
//
vRect.x += 5;
vRect.y -= 3;
//
vRect.x += 5;
vRect.y -= 3;
- if (wxOwnerDrawn::OnDrawItem( rDc
- ,vRect
- ,eAct
- ,eStat))
+ if (wxOwnerDrawn::OnDrawItem( rDc, vRect, eAct, eStat))
- size_t nCheckWidth = GetDefaultMarginWidth();
- size_t nCheckHeight = m_pParent->GetItemHeight();
- int nParentHeight;
- int nX = rRect.GetX();
- int nY = rRect.GetY();
- int nOldY = nY;
- wxColour vColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
- wxPen vPenBack;
- wxPen vPenGray;
- wxPen vPenPrev;
-
- m_pParent->GetSize( NULL
- ,&nParentHeight
- );
+ size_t nCheckWidth = GetDefaultMarginWidth();
+ size_t nCheckHeight = m_pParent->GetItemHeight();
+ int nParentHeight;
+ int nX = rRect.GetX();
+ int nY = rRect.GetY();
+ int nOldY = nY;
+ wxColour vColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
+ wxPen vPenBack;
+ wxPen vPenPrev;
+
+ m_pParent->GetSize( NULL, &nParentHeight);
nY = nParentHeight - nY - nCheckHeight;
vPenBack = wxPen(vColour, 1, wxSOLID);
nY = nParentHeight - nY - nCheckHeight;
vPenBack = wxPen(vColour, 1, wxSOLID);
- vPenGray = wxPen(wxColour(127, 127, 127), 1, wxSOLID);
//
// Erase the 1-pixel border
//
rDc.SetPen(vPenBack);
//
// Erase the 1-pixel border
//
rDc.SetPen(vPenBack);
- rDc.DrawRectangle( nX
- ,nY
- ,nCheckWidth
- ,nCheckHeight
- );
+ rDc.DrawRectangle( nX, nY, nCheckWidth, nCheckHeight );
//
// Now we draw the smaller rectangle
//
// Now we draw the smaller rectangle
//
// Draw hollow gray rectangle
//
//
// Draw hollow gray rectangle
//
- rDc.SetPen(vPenGray);
- rDc.DrawRectangle( nX
- ,nY
- ,nCheckWidth
- ,nCheckHeight
- );
+ rDc.SetPen(*wxGREY_PEN);
+ rDc.DrawRectangle( nX, nY, nCheckWidth, nCheckHeight );
//
// Draw the check by loading the sys standard bitmap and drawing it
//
//
// Draw the check by loading the sys standard bitmap and drawing it
//
- HBITMAP hChkBmp = ::WinGetSysBitmap( HWND_DESKTOP
- ,SBMP_MENUCHECK
- );
- POINTL vPoint = {nX, nOldY + 3};
-
- ::WinDrawBitmap( rDc.GetHPS()
- ,hChkBmp
- ,NULL
- ,&vPoint
- ,NULL
- ,NULL
- ,DBM_NORMAL
+ HBITMAP hChkBmp = ::WinGetSysBitmap( HWND_DESKTOP, SBMP_MENUCHECK );
+ POINTL vPoint = {nX, nOldY + 3};
+
+ ::WinDrawBitmap( rDc.GetHPS(),
+ hChkBmp,
+ NULL,
+ &vPoint,
+ NULL,
+ NULL,
+ DBM_NORMAL
} // end of wxCheckListBoxItem::OnDrawItem
//
// Change the state of the item and redraw it
//
} // end of wxCheckListBoxItem::OnDrawItem
//
// Change the state of the item and redraw it
//
-void wxCheckListBoxItem::Check (
- bool bCheck
-)
+void wxCheckListBoxItem::Check ( bool bCheck )
- int nIndex = m_pParent->GetItemIndex(this);
+ int nIndex = m_pParent->GetItemIndex(this);
wxASSERT_MSG(nIndex != wxNOT_FOUND, wxT("what does this item do here?"));
wxASSERT_MSG(nIndex != wxNOT_FOUND, wxT("what does this item do here?"));
- wxCommandEvent vEvent( wxEVT_COMMAND_CHECKLISTBOX_TOGGLED
- ,m_pParent->GetId()
- );
+ wxCommandEvent vEvent( wxEVT_COMMAND_CHECKLISTBOX_TOGGLED,m_pParent->GetId());
vEvent.SetInt(m_nIndex);
vEvent.SetEventObject(m_pParent);
m_pParent->ProcessCommand(vEvent);
} // end of wxCheckListBoxItem::Check
vEvent.SetInt(m_nIndex);
vEvent.SetEventObject(m_pParent);
m_pParent->ProcessCommand(vEvent);
} // end of wxCheckListBoxItem::Check
// ----------------------------------------------------------------------------
// implementation of wxCheckListBox class
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// implementation of wxCheckListBox class
// ----------------------------------------------------------------------------
// define event table
// ------------------
BEGIN_EVENT_TABLE(wxCheckListBox, wxListBox)
// define event table
// ------------------
BEGIN_EVENT_TABLE(wxCheckListBox, wxListBox)
- EVT_CHAR(wxCheckListBox::OnChar)
- EVT_LEFT_DOWN(wxCheckListBox::OnLeftClick)
+ EVT_CHAR(wxCheckListBox::OnChar)
+ EVT_LEFT_DOWN(wxCheckListBox::OnLeftClick)
//
// Control creation
// ----------------
//
// Control creation
// ----------------
// Default ctor: use Create() to really create the control
//
wxCheckListBox::wxCheckListBox()
// Default ctor: use Create() to really create the control
//
wxCheckListBox::wxCheckListBox()
{
} // end of wxCheckListBox::wxCheckListBox
//
// Ctor which creates the associated control
//
{
} // end of wxCheckListBox::wxCheckListBox
//
// Ctor which creates the associated control
//
-wxCheckListBox::wxCheckListBox (
- wxWindow* pParent
-, wxWindowID vId
-, const wxPoint& rPos
-, const wxSize& rSize
-, int nStrings
-, const wxString asChoices[]
-, long lStyle
-, const wxValidator& rVal
-, const wxString& rsName
-)
- : wxListBox()
+wxCheckListBox::wxCheckListBox ( wxWindow* pParent,
+ wxWindowID vId,
+ const wxPoint& rPos,
+ const wxSize& rSize,
+ int nStrings,
+ const wxString asChoices[],
+ long lStyle,
+ const wxValidator& rVal,
+ const wxString& rsName)
+ :wxCheckListBoxBase()
- Create( pParent
- ,vId
- ,rPos
- ,rSize
- ,nStrings
- ,asChoices
- ,lStyle | wxLB_OWNERDRAW
- ,rVal
- ,rsName
- );
+ Create( pParent, vId, rPos, rSize, nStrings, asChoices, lStyle | wxLB_OWNERDRAW, rVal, rsName );
} // end of wxCheckListBox::wxCheckListBox
} // end of wxCheckListBox::wxCheckListBox
-wxCheckListBox::wxCheckListBox (
- wxWindow* pParent
-, wxWindowID vId
-, const wxPoint& rPos
-, const wxSize& rSize
-, const wxArrayString& asChoices
-, long lStyle
-, const wxValidator& rVal
-, const wxString& rsName
-)
- : wxListBox()
+wxCheckListBox::wxCheckListBox ( wxWindow* pParent,
+ wxWindowID vId,
+ const wxPoint& rPos,
+ const wxSize& rSize,
+ const wxArrayString& asChoices,
+ long lStyle,
+ const wxValidator& rVal,
+ const wxString& rsName )
+ :wxCheckListBoxBase()
{
wxCArrayString chs(asChoices);
{
wxCArrayString chs(asChoices);
- Create( pParent
- ,vId
- ,rPos
- ,rSize
- ,chs.GetCount()
- ,chs.GetStrings()
- ,lStyle | wxLB_OWNERDRAW
- ,rVal
- ,rsName
- );
+ Create( pParent, vId, rPos, rSize, chs.GetCount(), chs.GetStrings(),
+ lStyle | wxLB_OWNERDRAW, rVal, rsName );
} // end of wxCheckListBox::wxCheckListBox
} // end of wxCheckListBox::wxCheckListBox
-void wxCheckListBox::Delete(
- int N
-)
+void wxCheckListBox::Delete( int n )
- wxCHECK_RET( N >= 0 && N < m_nNumItems,
- wxT("invalid index in wxListBox::Delete") );
- wxListBox::Delete(N);
+ wxCHECK_RET( n >= 0 && n < m_nNumItems,
+ wxT("invalid index in wxCheckListBox::Delete") );
+ wxListBox::Delete(n);
- delete m_aItems[N];
- m_aItems.RemoveAt(N);
+ delete m_aItems[n];
+ m_aItems.RemoveAt(n);
} // end of wxCheckListBox::Delete
} // end of wxCheckListBox::Delete
-void wxCheckListBox::InsertItems (
- int nItems
-, const wxString asItems[]
-, int nPos
-)
+void wxCheckListBox::DoInsertItems(const wxArrayString& items, int pos)
- int i;
-
- wxCHECK_RET( nPos >= 0 && nPos <= m_nNumItems,
- wxT("invalid index in wxCheckListBox::InsertItems") );
-
- wxListBox::InsertItems( nItems
- ,asItems
- ,nPos
- );
- for (i = 0; i < nItems; i++)
+ // pos is validated in wxListBox
+ wxListBox::DoInsertItems( items, pos );
+ int n = items.GetCount();
+ for (int i = 0; i < n; i++)
- wxOwnerDrawn* pNewItem = CreateItem((size_t)(nPos + i));
-
- pNewItem->SetName(asItems[i]);
- m_aItems.Insert(pNewItem, (size_t)(nPos + i));
- ::WinSendMsg( (HWND)GetHWND()
- ,LM_SETITEMHANDLE
- ,(MPARAM)(i + nPos)
- ,MPFROMP(pNewItem)
+ wxOwnerDrawn* pNewItem = CreateItem((size_t)(pos + i));
+
+ pNewItem->SetName(items[i]);
+ m_aItems.Insert(pNewItem, (size_t)(pos + i));
+ ::WinSendMsg( (HWND)GetHWND(),
+ LM_SETITEMHANDLE,
+ (MPARAM)(i + pos),
+ MPFROMP(pNewItem)
);
}
} // end of wxCheckListBox::InsertItems
);
}
} // end of wxCheckListBox::InsertItems
-bool wxCheckListBox::SetFont (
- const wxFont& rFont
-)
+bool wxCheckListBox::SetFont ( const wxFont& rFont )
- size_t i;
-
- for (i = 0; i < m_aItems.GetCount(); i++)
+ for (size_t i = 0; i < m_aItems.GetCount(); i++)
m_aItems[i]->SetFont(rFont);
wxListBox::SetFont(rFont);
m_aItems[i]->SetFont(rFont);
wxListBox::SetFont(rFont);
} // end of wxCheckListBox::SetFont
} // end of wxCheckListBox::SetFont
//
// Create/retrieve item
// --------------------
//
// Create/retrieve item
// --------------------
//
// Create a check list box item
//
//
// Create a check list box item
//
-wxOwnerDrawn* wxCheckListBox::CreateItem (
- size_t nIndex
-)
+wxOwnerDrawn* wxCheckListBox::CreateItem ( size_t nIndex )
- wxCheckListBoxItem* pItem = new wxCheckListBoxItem( this
- ,nIndex
- );
+ wxCheckListBoxItem* pItem = new wxCheckListBoxItem( this, nIndex );
return pItem;
} // end of wxCheckListBox::CreateItem
return pItem;
} // end of wxCheckListBox::CreateItem
//
// Return item size
// ----------------
//
//
// Return item size
// ----------------
//
-long wxCheckListBox::OS2OnMeasure (
- WXMEASUREITEMSTRUCT* pItem
-)
+long wxCheckListBox::OS2OnMeasure ( WXMEASUREITEMSTRUCT* pItem )
{
if (!pItem)
pItem = (WXMEASUREITEMSTRUCT*)new OWNERITEM;
{
if (!pItem)
pItem = (WXMEASUREITEMSTRUCT*)new OWNERITEM;
- if (wxListBox::OS2OnMeasure(pItem) )
+ if (wxListBox::OS2OnMeasure(pItem))
- POWNERITEM pStruct = (POWNERITEM)pItem;
+ POWNERITEM pStruct = (POWNERITEM)pItem;
return 0L;
} // end of wxCheckListBox::CreateItem
return 0L;
} // end of wxCheckListBox::CreateItem
//
// Check items
// -----------
//
//
// Check items
// -----------
//
-bool wxCheckListBox::IsChecked (
- size_t uiIndex
-) const
+bool wxCheckListBox::IsChecked ( size_t uiIndex) const
{
return GetItem(uiIndex)->IsChecked();
} // end of wxCheckListBox::IsChecked
{
return GetItem(uiIndex)->IsChecked();
} // end of wxCheckListBox::IsChecked
-void wxCheckListBox::Check (
- size_t uiIndex
-, bool bCheck
-)
+void wxCheckListBox::Check ( size_t uiIndex, bool bCheck )
{
GetItem(uiIndex)->Check(bCheck);
} // end of wxCheckListBox::Check
{
GetItem(uiIndex)->Check(bCheck);
} // end of wxCheckListBox::Check
//
// Process events
// --------------
//
//
// Process events
// --------------
//
-void wxCheckListBox::OnChar (
- wxKeyEvent& rEvent
-)
+void wxCheckListBox::OnChar ( wxKeyEvent& rEvent )
{
if (rEvent.GetKeyCode() == WXK_SPACE)
GetItem(GetSelection())->Toggle();
{
if (rEvent.GetKeyCode() == WXK_SPACE)
GetItem(GetSelection())->Toggle();
rEvent.Skip();
} // end of wxCheckListBox::OnChar
rEvent.Skip();
} // end of wxCheckListBox::OnChar
-void wxCheckListBox::OnLeftClick (
- wxMouseEvent& rEvent
-)
+void wxCheckListBox::OnLeftClick ( wxMouseEvent& rEvent )
{
//
// Clicking on the item selects it, clicking on the checkmark toggles
{
//
// Clicking on the item selects it, clicking on the checkmark toggles
wxScreenDC vDc;
wxCoord vHeight;
wxScreenDC vDc;
wxCoord vHeight;
- GetSize( NULL
- ,&nParentHeight
- );
+ GetSize( NULL, &nParentHeight );
vDc.SetFont(GetFont());
vHeight = (wxCoord)(vDc.GetCharHeight() * 2.5);
//
// This, of course, will not work if the LB is scrolled
//
vDc.SetFont(GetFont());
vHeight = (wxCoord)(vDc.GetCharHeight() * 2.5);
//
// This, of course, will not work if the LB is scrolled
//
- int nY = rEvent.GetY();
+ int nY = rEvent.GetY();
nY = nParentHeight - (nY + vHeight);
nY = nParentHeight - (nY + vHeight);
- size_t nItem = (size_t)(nY / vHeight);
+ size_t nItem = (size_t)(nY / vHeight);
if (nItem < (size_t)m_nNumItems)
GetItem(nItem)->Toggle();
if (nItem < (size_t)m_nNumItems)
GetItem(nItem)->Toggle();
}
} // end of wxCheckListBox::OnLeftClick
}
} // end of wxCheckListBox::OnLeftClick
+#endif // wxUSE_CHECKLISTBOX && wxUSE_OWNER_DRAWN