Notebook, Listbox, and Checklst updates
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@16951 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -23,55 +23,81 @@ class wxCheckListBoxItem; // fwd decl, define in checklst.cpp
|
|||||||
|
|
||||||
class WXDLLEXPORT wxCheckListBox : public wxListBox
|
class WXDLLEXPORT wxCheckListBox : public wxListBox
|
||||||
{
|
{
|
||||||
DECLARE_DYNAMIC_CLASS(wxCheckListBox)
|
|
||||||
public:
|
public:
|
||||||
// ctors
|
//
|
||||||
|
// Ctors
|
||||||
|
//
|
||||||
wxCheckListBox();
|
wxCheckListBox();
|
||||||
wxCheckListBox(wxWindow *parent, wxWindowID id,
|
wxCheckListBox( wxWindow* pParent
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
,wxWindowID vId
|
||||||
const wxSize& size = wxDefaultSize,
|
,const wxPoint& rPos = wxDefaultPosition
|
||||||
int nStrings = 0,
|
,const wxSize& vSize = wxDefaultSize
|
||||||
const wxString choices[] = NULL,
|
,int nStrings = 0
|
||||||
long style = 0,
|
,const wxString asChoices[] = NULL
|
||||||
|
,long lStyle = 0
|
||||||
#if wxUSE_VALIDATORS
|
#if wxUSE_VALIDATORS
|
||||||
const wxValidator& validator = wxDefaultValidator,
|
,const wxValidator& rValidator = wxDefaultValidator
|
||||||
#endif
|
#endif
|
||||||
const wxString& name = wxListBoxNameStr);
|
,const wxString& rsName = wxListBoxNameStr
|
||||||
|
);
|
||||||
|
|
||||||
// override base class virtuals
|
//
|
||||||
|
// Override base class virtuals
|
||||||
|
//
|
||||||
virtual void Delete(int n);
|
virtual void Delete(int n);
|
||||||
virtual void InsertItems(int nItems, const wxString items[], int pos);
|
virtual void InsertItems( int nItems
|
||||||
|
,const wxString asItems[]
|
||||||
|
,int nPos
|
||||||
|
);
|
||||||
|
|
||||||
virtual bool SetFont( const wxFont &font );
|
virtual bool SetFont(const wxFont &rFont);
|
||||||
|
|
||||||
// items may be checked
|
//
|
||||||
|
// Items may be checked
|
||||||
|
//
|
||||||
bool IsChecked(size_t uiIndex) const;
|
bool IsChecked(size_t uiIndex) const;
|
||||||
void Check(size_t uiIndex, bool bCheck = TRUE);
|
void Check( size_t uiIndex
|
||||||
|
,bool bCheck = TRUE
|
||||||
|
);
|
||||||
|
|
||||||
// accessors
|
//
|
||||||
size_t GetItemHeight() const { return m_nItemHeight; }
|
// Accessors
|
||||||
|
//
|
||||||
|
size_t GetItemHeight(void) const { return m_nItemHeight; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// we create our items ourselves and they have non-standard size,
|
//
|
||||||
|
// We create our items ourselves and they have non-standard size,
|
||||||
// so we need to override these functions
|
// so we need to override these functions
|
||||||
|
//
|
||||||
virtual wxOwnerDrawn* CreateItem(size_t n);
|
virtual wxOwnerDrawn* CreateItem(size_t n);
|
||||||
// virtual bool OS2OnMeasure(WXMEASUREITEMSTRUCT *item);
|
virtual bool OS2OnMeasure(WXMEASUREITEMSTRUCT* pItem);
|
||||||
|
|
||||||
// pressing space or clicking the check box toggles the item
|
//
|
||||||
void OnChar(wxKeyEvent& event);
|
// Pressing space or clicking the check box toggles the item
|
||||||
void OnLeftClick(wxMouseEvent& event);
|
//
|
||||||
|
void OnChar(wxKeyEvent& rEvent);
|
||||||
|
void OnLeftClick(wxMouseEvent& rEvent);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
size_t m_nItemHeight; // height of checklistbox items (the same for all)
|
size_t m_nItemHeight; // height of checklistbox items (the same for all)
|
||||||
|
|
||||||
|
//
|
||||||
// Virtual function hiding suppression, do not use
|
// Virtual function hiding suppression, do not use
|
||||||
virtual wxControl *CreateItem(const wxItemResource* childResource,
|
//
|
||||||
const wxItemResource* parentResource,
|
virtual wxControl* CreateItem( const wxItemResource* pChildResource
|
||||||
const wxResourceTable *table = (const wxResourceTable *) NULL)
|
,const wxItemResource* pParentResource
|
||||||
{ return(wxWindowBase::CreateItem(childResource, parentResource, table));};
|
,const wxResourceTable* pTable = (const wxResourceTable *) NULL
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return(wxWindowBase::CreateItem( pChildResource
|
||||||
|
,pParentResource
|
||||||
|
,pTable
|
||||||
|
));
|
||||||
|
}
|
||||||
|
DECLARE_DYNAMIC_CLASS(wxCheckListBox)
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
};
|
}; // end of CLASS wxCheckListBoxItem
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// _WX_CHECKLST_H_
|
// _WX_CHECKLST_H_
|
||||||
|
@@ -62,6 +62,7 @@ class WXDLLEXPORT wxStaticBitmap : public wxStaticBitmapBase
|
|||||||
,WXWPARAM wParam
|
,WXWPARAM wParam
|
||||||
,WXLPARAM lParam
|
,WXLPARAM lParam
|
||||||
);
|
);
|
||||||
|
void OnPaint(wxPaintEvent& rEvent);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
@@ -79,6 +80,7 @@ protected:
|
|||||||
wxGDIImage* m_pImage;
|
wxGDIImage* m_pImage;
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxStaticBitmap)
|
DECLARE_DYNAMIC_CLASS(wxStaticBitmap)
|
||||||
|
DECLARE_EVENT_TABLE()
|
||||||
}; // end of wxStaticBitmap
|
}; // end of wxStaticBitmap
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -227,9 +227,6 @@ public:
|
|||||||
void OnIdle(wxIdleEvent& rEvent);
|
void OnIdle(wxIdleEvent& rEvent);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// For hidden notebook pages, always TRUE for everything else
|
|
||||||
bool IsActivePage(void) const { return m_bIsActivePage; }
|
|
||||||
void SetActivePage(bool bActive) { m_bIsActivePage = bActive; }
|
|
||||||
|
|
||||||
// For implementation purposes - sometimes decorations make the client area
|
// For implementation purposes - sometimes decorations make the client area
|
||||||
// smaller
|
// smaller
|
||||||
@@ -606,7 +603,6 @@ private:
|
|||||||
HWND m_hWndScrollBarHorz;
|
HWND m_hWndScrollBarHorz;
|
||||||
HWND m_hWndScrollBarVert;
|
HWND m_hWndScrollBarVert;
|
||||||
SWP m_vWinSwp;
|
SWP m_vWinSwp;
|
||||||
bool m_bIsActivePage;
|
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxWindowOS2);
|
DECLARE_DYNAMIC_CLASS(wxWindowOS2);
|
||||||
DECLARE_NO_COPY_CLASS(wxWindowOS2)
|
DECLARE_NO_COPY_CLASS(wxWindowOS2)
|
||||||
|
@@ -54,185 +54,189 @@ class wxCheckListBoxItem : public wxOwnerDrawn
|
|||||||
{
|
{
|
||||||
friend class wxCheckListBox;
|
friend class wxCheckListBox;
|
||||||
public:
|
public:
|
||||||
|
//
|
||||||
// ctor
|
// ctor
|
||||||
wxCheckListBoxItem(wxCheckListBox *pParent, size_t nIndex);
|
//
|
||||||
|
wxCheckListBoxItem( wxCheckListBox* pParent
|
||||||
|
,size_t nIndex
|
||||||
|
);
|
||||||
|
|
||||||
// drawing functions
|
//
|
||||||
virtual bool OnDrawItem(wxDC& dc, const wxRect& rc, wxODAction act, wxODStatus stat);
|
// Drawing functions
|
||||||
|
//
|
||||||
|
virtual bool OnDrawItem( wxDC& rDc
|
||||||
|
,const wxRect& rRect
|
||||||
|
,wxODAction eAct
|
||||||
|
,wxODStatus eStat
|
||||||
|
);
|
||||||
|
|
||||||
// simple accessors
|
//
|
||||||
bool IsChecked() const { return m_bChecked; }
|
// Simple accessors
|
||||||
|
//
|
||||||
|
bool IsChecked(void) const { return m_bChecked; }
|
||||||
void Check(bool bCheck);
|
void Check(bool bCheck);
|
||||||
void Toggle() { Check(!IsChecked()); }
|
void Toggle(void) { Check(!IsChecked()); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool m_bChecked;
|
bool m_bChecked;
|
||||||
wxCheckListBox* m_pParent;
|
wxCheckListBox* m_pParent;
|
||||||
size_t m_nIndex;
|
size_t m_nIndex;
|
||||||
};
|
}; // end of CLASS wxCheckListBoxItem
|
||||||
|
|
||||||
wxCheckListBoxItem::wxCheckListBoxItem(wxCheckListBox *pParent, size_t nIndex)
|
wxCheckListBoxItem::wxCheckListBoxItem (
|
||||||
: wxOwnerDrawn("", TRUE) // checkable
|
wxCheckListBox* pParent
|
||||||
|
, size_t nIndex
|
||||||
|
)
|
||||||
|
: wxOwnerDrawn( ""
|
||||||
|
,TRUE // checkable
|
||||||
|
)
|
||||||
{
|
{
|
||||||
m_bChecked = FALSE;
|
m_bChecked = FALSE;
|
||||||
m_pParent = pParent;
|
m_pParent = pParent;
|
||||||
m_nIndex = nIndex;
|
m_nIndex = nIndex;
|
||||||
|
|
||||||
// we don't initialize m_nCheckHeight/Width vars because it's
|
//
|
||||||
|
// We don't initialize m_nCheckHeight/Width vars because it's
|
||||||
// done in OnMeasure while they are used only in OnDraw and we
|
// done in OnMeasure while they are used only in OnDraw and we
|
||||||
// know that there will always be OnMeasure before OnDraw
|
// know that there will always be OnMeasure before OnDraw
|
||||||
|
//
|
||||||
// fix appearance
|
|
||||||
SetMarginWidth(GetDefaultMarginWidth());
|
SetMarginWidth(GetDefaultMarginWidth());
|
||||||
}
|
} // end of wxCheckListBoxItem::wxCheckListBoxItem
|
||||||
|
|
||||||
/*
|
bool wxCheckListBoxItem::OnDrawItem (
|
||||||
* JACS - I've got the owner-draw stuff partially working with WIN16,
|
wxDC& rDc
|
||||||
* with a really horrible-looking cross for wxCheckListBox instead of a
|
, const wxRect& rRect
|
||||||
* check - could use a bitmap check-mark instead, defined in wx.rc.
|
, wxODAction eAct
|
||||||
* Also there's a refresh problem whereby it doesn't always draw the
|
, wxODStatus eStat
|
||||||
* check until you click to the right of it, which is OK for WIN32.
|
)
|
||||||
*/
|
|
||||||
|
|
||||||
bool wxCheckListBoxItem::OnDrawItem(wxDC& dc, const wxRect& rc,
|
|
||||||
wxODAction act, wxODStatus stat)
|
|
||||||
{
|
{
|
||||||
|
wxRect vRect = rRect;
|
||||||
|
|
||||||
if (IsChecked())
|
if (IsChecked())
|
||||||
stat = (wxOwnerDrawn::wxODStatus)(stat | wxOwnerDrawn::wxODChecked);
|
eStat = (wxOwnerDrawn::wxODStatus)(eStat | wxOwnerDrawn::wxODChecked);
|
||||||
|
|
||||||
// TODO:
|
//
|
||||||
/*
|
// Unfortunately PM doesn't quite get the text position exact. We need to alter
|
||||||
|
// it down and to the right, just a little bit. The coords in rRect are OS/2
|
||||||
|
// coords not wxWindows coords.
|
||||||
|
//
|
||||||
|
vRect.x += 5;
|
||||||
|
vRect.y -= 3;
|
||||||
|
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;
|
||||||
|
|
||||||
if ( wxOwnerDrawn::OnDrawItem(dc, rc, act, stat) ) {
|
m_pParent->GetSize( NULL
|
||||||
// ## using native API for performance and precision
|
,&nParentHeight
|
||||||
size_t nCheckWidth = GetDefaultMarginWidth(),
|
);
|
||||||
nCheckHeight = m_pParent->GetItemHeight();
|
::WinQueryWindowRect( m_pParent->GetHWND()
|
||||||
|
,&rDc.m_vRclPaint
|
||||||
|
);
|
||||||
|
|
||||||
int x = rc.GetX(),
|
nY = nParentHeight - nY - nCheckHeight;
|
||||||
y = rc.GetY();
|
vPenBack = wxPen(vColour, 1, wxSOLID);
|
||||||
|
vPenGray = wxPen(wxColour(127, 127, 127), 1, wxSOLID);
|
||||||
|
|
||||||
HDC hdc = (HDC)dc.GetHDC();
|
//
|
||||||
|
// Erase the 1-pixel border
|
||||||
|
//
|
||||||
|
rDc.SetPen(vPenBack);
|
||||||
|
rDc.DrawRectangle( nX
|
||||||
|
,nY
|
||||||
|
,nCheckWidth
|
||||||
|
,nCheckHeight
|
||||||
|
);
|
||||||
|
|
||||||
// create pens
|
//
|
||||||
HPEN hpenBack = CreatePen(PS_SOLID, 0, GetSysColor(COLOR_WINDOW)),
|
// Now we draw the smaller rectangle
|
||||||
hpenGray = CreatePen(PS_SOLID, 0, RGB(128, 128, 128)),
|
//
|
||||||
hpenPrev = (HPEN)SelectObject(hdc, hpenBack);
|
nY++;
|
||||||
|
|
||||||
// we erase the 1-pixel border
|
|
||||||
Rectangle(hdc, x, y, x + nCheckWidth, y + nCheckHeight);
|
|
||||||
|
|
||||||
// shift check mark 1 pixel to the right (it looks better like this)
|
|
||||||
x++;
|
|
||||||
|
|
||||||
if ( IsChecked() ) {
|
|
||||||
// first create a monochrome bitmap in a memory DC
|
|
||||||
HDC hdcMem = CreateCompatibleDC(hdc);
|
|
||||||
HBITMAP hbmpCheck = CreateBitmap(nCheckWidth, nCheckHeight, 1, 1, 0);
|
|
||||||
HBITMAP hbmpOld = (HBITMAP)SelectObject(hdcMem, hbmpCheck);
|
|
||||||
|
|
||||||
// then draw a check mark into it
|
|
||||||
RECT rect ;
|
|
||||||
rect.left = 0 ;
|
|
||||||
rect.top = 0 ;
|
|
||||||
rect.right = nCheckWidth ;
|
|
||||||
rect.bottom = nCheckHeight ;
|
|
||||||
|
|
||||||
#ifdef __WIN32__
|
|
||||||
#ifndef __SC__
|
|
||||||
DrawFrameControl(hdcMem, &rect, DFC_MENU, DFCS_MENUCHECK);
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
// In WIN16, draw a cross
|
|
||||||
HPEN blackPen = CreatePen(PS_SOLID, 1, RGB(0, 0, 0));
|
|
||||||
HPEN whiteBrush = (HPEN)GetStockObject(WHITE_BRUSH);
|
|
||||||
HPEN hPenOld = (HPEN)::SelectObject(hdcMem, blackPen);
|
|
||||||
HPEN hBrushOld = (HPEN)::SelectObject(hdcMem, whiteBrush);
|
|
||||||
::SetROP2(hdcMem, R2_COPYPEN);
|
|
||||||
Rectangle(hdcMem, 0, 0, nCheckWidth, nCheckHeight);
|
|
||||||
MoveTo(hdcMem, 0, 0);
|
|
||||||
LineTo(hdcMem, nCheckWidth, nCheckHeight);
|
|
||||||
MoveTo(hdcMem, nCheckWidth, 0);
|
|
||||||
LineTo(hdcMem, 0, nCheckHeight);
|
|
||||||
::SelectObject(hdcMem, hPenOld);
|
|
||||||
::SelectObject(hdcMem, hBrushOld);
|
|
||||||
::DeleteObject(blackPen);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// finally copy it to screen DC and clean up
|
|
||||||
BitBlt(hdc, x, y, nCheckWidth - 1, nCheckHeight,
|
|
||||||
hdcMem, 0, 0, SRCCOPY);
|
|
||||||
|
|
||||||
SelectObject(hdcMem, hbmpOld);
|
|
||||||
DeleteObject(hbmpCheck);
|
|
||||||
DeleteDC(hdcMem);
|
|
||||||
}
|
|
||||||
|
|
||||||
// now we draw the smaller rectangle
|
|
||||||
y++;
|
|
||||||
nCheckWidth -= 2;
|
nCheckWidth -= 2;
|
||||||
nCheckHeight -= 2;
|
nCheckHeight -= 2;
|
||||||
|
|
||||||
// draw hollow gray rectangle
|
|
||||||
(void)SelectObject(hdc, hpenGray);
|
|
||||||
HBRUSH hbrPrev = (HBRUSH)SelectObject(hdc, GetStockObject(NULL_BRUSH));
|
|
||||||
Rectangle(hdc, x, y, x + nCheckWidth, y + nCheckHeight);
|
|
||||||
|
|
||||||
// clean up
|
|
||||||
(void)SelectObject(hdc, hpenPrev);
|
|
||||||
(void)SelectObject(hdc, hbrPrev);
|
|
||||||
|
|
||||||
DeleteObject(hpenBack);
|
|
||||||
DeleteObject(hpenGray);
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// dc.DrawRectangle(x, y, nCheckWidth, nCheckHeight);
|
// Draw hollow gray rectangle
|
||||||
//
|
|
||||||
// if ( IsChecked() ) {
|
|
||||||
// dc.DrawLine(x, y, x + nCheckWidth, y + nCheckHeight);
|
|
||||||
// dc.DrawLine(x, y + nCheckHeight, x + nCheckWidth, y);
|
|
||||||
// }
|
|
||||||
//
|
//
|
||||||
|
rDc.SetPen(vPenGray);
|
||||||
|
rDc.DrawRectangle( nX
|
||||||
|
,nY
|
||||||
|
,nCheckWidth
|
||||||
|
,nCheckHeight
|
||||||
|
);
|
||||||
|
|
||||||
|
nX++;
|
||||||
|
if (IsChecked())
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// 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
|
||||||
|
);
|
||||||
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
} // end of wxCheckListBoxItem::OnDrawItem
|
||||||
|
|
||||||
// change the state of the item and redraw it
|
//
|
||||||
void wxCheckListBoxItem::Check(bool check)
|
// Change the state of the item and redraw it
|
||||||
|
//
|
||||||
|
void wxCheckListBoxItem::Check (
|
||||||
|
bool bCheck
|
||||||
|
)
|
||||||
{
|
{
|
||||||
m_bChecked = check;
|
m_bChecked = bCheck;
|
||||||
|
|
||||||
// index may be chanegd because new items were added/deleted
|
//
|
||||||
|
// Index may be chanegd because new items were added/deleted
|
||||||
|
//
|
||||||
if (m_pParent->GetItemIndex(this) != (int)m_nIndex)
|
if (m_pParent->GetItemIndex(this) != (int)m_nIndex)
|
||||||
{
|
{
|
||||||
// update it
|
//
|
||||||
int index = m_pParent->GetItemIndex(this);
|
// Update it
|
||||||
|
//
|
||||||
|
int nIndex = m_pParent->GetItemIndex(this);
|
||||||
|
|
||||||
wxASSERT_MSG( index != wxNOT_FOUND, wxT("what does this item do here?") );
|
wxASSERT_MSG(nIndex != wxNOT_FOUND, wxT("what does this item do here?"));
|
||||||
|
|
||||||
m_nIndex = (size_t)index;
|
m_nIndex = (size_t)nIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
HWND hwndListbox = (HWND)m_pParent->GetHWND();
|
HWND hWndListbox = (HWND)m_pParent->GetHWND();
|
||||||
|
RECTL rUpdate;
|
||||||
|
MRESULT mRc;
|
||||||
|
|
||||||
// TODO:
|
wxCommandEvent vEvent( wxEVT_COMMAND_CHECKLISTBOX_TOGGLED
|
||||||
/*
|
,m_pParent->GetId()
|
||||||
RECT rcUpdate;
|
);
|
||||||
if ( ::SendMessage(hwndListbox, LB_GETITEMRECT,
|
|
||||||
m_nIndex, (LPARAM)&rcUpdate) == LB_ERR )
|
|
||||||
{
|
|
||||||
wxLogDebug(wxT("LB_GETITEMRECT failed"));
|
|
||||||
}
|
|
||||||
|
|
||||||
InvalidateRect(hwndListbox, &rcUpdate, FALSE);
|
vEvent.SetInt(m_nIndex);
|
||||||
*/
|
vEvent.SetEventObject(m_pParent);
|
||||||
wxCommandEvent event(wxEVT_COMMAND_CHECKLISTBOX_TOGGLED, m_pParent->GetId());
|
m_pParent->ProcessCommand(vEvent);
|
||||||
event.SetInt(m_nIndex);
|
} // end of wxCheckListBoxItem::Check
|
||||||
event.SetEventObject(m_pParent);
|
|
||||||
m_pParent->ProcessCommand(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// implementation of wxCheckListBox class
|
// implementation of wxCheckListBox class
|
||||||
@@ -245,147 +249,228 @@ BEGIN_EVENT_TABLE(wxCheckListBox, wxListBox)
|
|||||||
EVT_LEFT_DOWN(wxCheckListBox::OnLeftClick)
|
EVT_LEFT_DOWN(wxCheckListBox::OnLeftClick)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
// control creation
|
//
|
||||||
|
// Control creation
|
||||||
// ----------------
|
// ----------------
|
||||||
|
//
|
||||||
|
|
||||||
// def ctor: use Create() to really create the control
|
//
|
||||||
wxCheckListBox::wxCheckListBox() : wxListBox()
|
// Default ctor: use Create() to really create the control
|
||||||
{
|
//
|
||||||
}
|
wxCheckListBox::wxCheckListBox()
|
||||||
|
|
||||||
// ctor which creates the associated control
|
|
||||||
wxCheckListBox::wxCheckListBox(wxWindow *parent, wxWindowID id,
|
|
||||||
const wxPoint& pos, const wxSize& size,
|
|
||||||
int nStrings, const wxString choices[],
|
|
||||||
#if wxUSE_VALIDATORS
|
|
||||||
long style, const wxValidator& val,
|
|
||||||
#endif
|
|
||||||
const wxString& name)
|
|
||||||
: wxListBox()
|
: wxListBox()
|
||||||
{
|
{
|
||||||
Create(parent, id, pos, size, nStrings, choices,
|
} // end of wxCheckListBox::wxCheckListBox
|
||||||
style | wxLB_OWNERDRAW, val, name);
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxCheckListBox::Delete(int N)
|
//
|
||||||
|
// 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
|
||||||
|
#if wxUSE_VALIDATORS
|
||||||
|
, const wxValidator& rVal
|
||||||
|
#endif
|
||||||
|
, const wxString& rsName
|
||||||
|
)
|
||||||
|
: wxListBox()
|
||||||
|
{
|
||||||
|
Create( pParent
|
||||||
|
,vId
|
||||||
|
,rPos
|
||||||
|
,rSize
|
||||||
|
,nStrings
|
||||||
|
,asChoices
|
||||||
|
,lStyle | wxLB_OWNERDRAW
|
||||||
|
#if wxUSE_VALIDATORS
|
||||||
|
,rVal
|
||||||
|
#endif
|
||||||
|
,rsName
|
||||||
|
);
|
||||||
|
} // end of wxCheckListBox::wxCheckListBox
|
||||||
|
|
||||||
|
void wxCheckListBox::Delete(
|
||||||
|
int N
|
||||||
|
)
|
||||||
{
|
{
|
||||||
wxCHECK_RET( N >= 0 && N < m_nNumItems,
|
wxCHECK_RET( N >= 0 && N < m_nNumItems,
|
||||||
wxT("invalid index in wxListBox::Delete") );
|
wxT("invalid index in wxListBox::Delete") );
|
||||||
|
|
||||||
wxListBox::Delete(N);
|
wxListBox::Delete(N);
|
||||||
|
|
||||||
// free memory
|
//
|
||||||
|
// Free memory
|
||||||
|
//
|
||||||
delete m_aItems[N];
|
delete m_aItems[N];
|
||||||
|
|
||||||
m_aItems.RemoveAt(N);
|
m_aItems.RemoveAt(N);
|
||||||
}
|
} // end of wxCheckListBox::Delete
|
||||||
|
|
||||||
void wxCheckListBox::InsertItems(int nItems, const wxString items[], int pos)
|
void wxCheckListBox::InsertItems (
|
||||||
|
int nItems
|
||||||
|
, const wxString asItems[]
|
||||||
|
, int nPos
|
||||||
|
)
|
||||||
{
|
{
|
||||||
wxCHECK_RET( pos >= 0 && pos <= m_nNumItems,
|
int i;
|
||||||
|
|
||||||
|
wxCHECK_RET( nPos >= 0 && nPos <= m_nNumItems,
|
||||||
wxT("invalid index in wxCheckListBox::InsertItems") );
|
wxT("invalid index in wxCheckListBox::InsertItems") );
|
||||||
|
|
||||||
wxListBox::InsertItems(nItems, items, pos);
|
wxListBox::InsertItems( nItems
|
||||||
|
,asItems
|
||||||
|
,nPos
|
||||||
|
);
|
||||||
|
for (i = 0; i < nItems; i++)
|
||||||
|
{
|
||||||
|
wxOwnerDrawn* pNewItem = CreateItem((size_t)(nPos + i));
|
||||||
|
|
||||||
int i;
|
pNewItem->SetName(asItems[i]);
|
||||||
for ( i = 0; i < nItems; i++ ) {
|
m_aItems.Insert(pNewItem, (size_t)(nPos + i));
|
||||||
wxOwnerDrawn *pNewItem = CreateItem((size_t)(pos + i));
|
::WinSendMsg( (HWND)GetHWND()
|
||||||
pNewItem->SetName(items[i]);
|
,LM_SETITEMHANDLE
|
||||||
m_aItems.Insert(pNewItem, (size_t)(pos + i));
|
,(MPARAM)(i + nPos)
|
||||||
// ListBox_SetItemData((HWND)GetHWND(), i + pos, pNewItem);
|
,MPFROMP(pNewItem)
|
||||||
}
|
);
|
||||||
}
|
}
|
||||||
|
} // end of wxCheckListBox::InsertItems
|
||||||
|
|
||||||
|
bool wxCheckListBox::SetFont (
|
||||||
bool wxCheckListBox::SetFont( const wxFont &font )
|
const wxFont& rFont
|
||||||
|
)
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
for (i = 0; i < m_aItems.GetCount(); i++)
|
for (i = 0; i < m_aItems.GetCount(); i++)
|
||||||
m_aItems[i]->SetFont(font);
|
m_aItems[i]->SetFont(rFont);
|
||||||
wxListBox::SetFont(font);
|
wxListBox::SetFont(rFont);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
} // end of wxCheckListBox::SetFont
|
||||||
|
|
||||||
// create/retrieve item
|
//
|
||||||
|
// Create/retrieve item
|
||||||
// --------------------
|
// --------------------
|
||||||
|
//
|
||||||
|
|
||||||
// create a check list box item
|
//
|
||||||
wxOwnerDrawn *wxCheckListBox::CreateItem(size_t nIndex)
|
// Create a check list box item
|
||||||
|
//
|
||||||
|
wxOwnerDrawn* wxCheckListBox::CreateItem (
|
||||||
|
size_t nIndex
|
||||||
|
)
|
||||||
{
|
{
|
||||||
wxCheckListBoxItem *pItem = new wxCheckListBoxItem(this, nIndex);
|
wxCheckListBoxItem* pItem = new wxCheckListBoxItem( this
|
||||||
|
,nIndex
|
||||||
|
);
|
||||||
return pItem;
|
return pItem;
|
||||||
}
|
} // end of wxCheckListBox::CreateItem
|
||||||
|
|
||||||
// return item size
|
//
|
||||||
|
// Return item size
|
||||||
// ----------------
|
// ----------------
|
||||||
// TODO:
|
//
|
||||||
/*
|
bool wxCheckListBox::OS2OnMeasure (
|
||||||
bool wxCheckListBox::MSWOnMeasure(WXMEASUREITEMSTRUCT *item)
|
WXMEASUREITEMSTRUCT* pItem
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if ( wxListBox::MSWOnMeasure(item) ) {
|
if (!pItem)
|
||||||
MEASUREITEMSTRUCT *pStruct = (MEASUREITEMSTRUCT *)item;
|
pItem = (WXMEASUREITEMSTRUCT*)new OWNERITEM;
|
||||||
|
if (wxListBox::OS2OnMeasure(pItem) )
|
||||||
|
{
|
||||||
|
POWNERITEM pStruct = (POWNERITEM)pItem;
|
||||||
|
|
||||||
// save item height
|
//
|
||||||
m_nItemHeight = pStruct->itemHeight;
|
// Save item height
|
||||||
|
//
|
||||||
// add place for the check mark
|
m_nItemHeight = pStruct->rclItem.yTop - pStruct->rclItem.yBottom;
|
||||||
pStruct->itemWidth += wxOwnerDrawn::GetDefaultMarginWidth();
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Add place for the check mark
|
||||||
|
//
|
||||||
|
pStruct->rclItem.xRight += wxOwnerDrawn::GetDefaultMarginWidth();
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
} // end of wxCheckListBox::CreateItem
|
||||||
*/
|
|
||||||
// check items
|
|
||||||
// -----------
|
|
||||||
|
|
||||||
bool wxCheckListBox::IsChecked(size_t uiIndex) const
|
//
|
||||||
|
// Check items
|
||||||
|
// -----------
|
||||||
|
//
|
||||||
|
bool wxCheckListBox::IsChecked (
|
||||||
|
size_t uiIndex
|
||||||
|
) const
|
||||||
{
|
{
|
||||||
return GetItem(uiIndex)->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);
|
GetItem(uiIndex)->Check(bCheck);
|
||||||
}
|
} // end of wxCheckListBox::Check
|
||||||
|
|
||||||
// process events
|
//
|
||||||
|
// Process events
|
||||||
// --------------
|
// --------------
|
||||||
|
//
|
||||||
void wxCheckListBox::OnChar(wxKeyEvent& event)
|
void wxCheckListBox::OnChar (
|
||||||
|
wxKeyEvent& rEvent
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if ( event.KeyCode() == WXK_SPACE )
|
if (rEvent.KeyCode() == WXK_SPACE)
|
||||||
GetItem(GetSelection())->Toggle();
|
GetItem(GetSelection())->Toggle();
|
||||||
else
|
else
|
||||||
event.Skip();
|
rEvent.Skip();
|
||||||
}
|
} // end of wxCheckListBox::OnChar
|
||||||
|
|
||||||
void wxCheckListBox::OnLeftClick(wxMouseEvent& event)
|
void wxCheckListBox::OnLeftClick (
|
||||||
|
wxMouseEvent& rEvent
|
||||||
|
)
|
||||||
{
|
{
|
||||||
// clicking on the item selects it, clicking on the checkmark toggles
|
//
|
||||||
if ( event.GetX() <= wxOwnerDrawn::GetDefaultMarginWidth() ) {
|
// Clicking on the item selects it, clicking on the checkmark toggles
|
||||||
// TODO:
|
//
|
||||||
/*
|
if (rEvent.GetX() <= wxOwnerDrawn::GetDefaultMarginWidth())
|
||||||
size_t nItem = (size_t)::SendMessage
|
{
|
||||||
(
|
int nParentHeight;
|
||||||
(HWND)GetHWND(),
|
wxScreenDC vDc;
|
||||||
LB_ITEMFROMPOINT,
|
wxCoord vHeight;
|
||||||
0,
|
|
||||||
MAKELPARAM(event.GetX(), event.GetY())
|
GetSize( NULL
|
||||||
|
,&nParentHeight
|
||||||
);
|
);
|
||||||
*/
|
vDc.SetFont(GetFont());
|
||||||
size_t nItem = 0;
|
vHeight = vDc.GetCharHeight() * 2.5;
|
||||||
|
|
||||||
|
//
|
||||||
|
// This, of course, will not work if the LB is scrolled
|
||||||
|
//
|
||||||
|
int nY = rEvent.GetY();
|
||||||
|
|
||||||
|
nY = nParentHeight - (nY + vHeight);
|
||||||
|
|
||||||
|
size_t nItem = (size_t)(nY / vHeight);
|
||||||
|
|
||||||
if (nItem < (size_t)m_nNumItems)
|
if (nItem < (size_t)m_nNumItems)
|
||||||
GetItem(nItem)->Toggle();
|
GetItem(nItem)->Toggle();
|
||||||
|
//
|
||||||
// else: it's not an error, just click outside of client zone
|
// else: it's not an error, just click outside of client zone
|
||||||
|
//
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
// implement default behaviour: clicking on the item selects it
|
{
|
||||||
event.Skip();
|
//
|
||||||
}
|
// Implement default behaviour: clicking on the item selects it
|
||||||
|
//
|
||||||
|
rEvent.Skip();
|
||||||
}
|
}
|
||||||
|
} // end of wxCheckListBox::OnLeftClick
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -49,7 +49,7 @@ bool wxComboBox::OS2Command(
|
|||||||
|
|
||||||
switch (uParam)
|
switch (uParam)
|
||||||
{
|
{
|
||||||
case LN_SELECT:
|
case CBN_LBSELECT:
|
||||||
if (GetSelection() > -1)
|
if (GetSelection() > -1)
|
||||||
{
|
{
|
||||||
wxCommandEvent vEvent( wxEVT_COMMAND_COMBOBOX_SELECTED
|
wxCommandEvent vEvent( wxEVT_COMMAND_COMBOBOX_SELECTED
|
||||||
@@ -63,7 +63,7 @@ bool wxComboBox::OS2Command(
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EN_CHANGE:
|
case CBN_EFCHANGE:
|
||||||
{
|
{
|
||||||
wxCommandEvent vEvent( wxEVT_COMMAND_TEXT_UPDATED
|
wxCommandEvent vEvent( wxEVT_COMMAND_TEXT_UPDATED
|
||||||
,GetId()
|
,GetId()
|
||||||
|
@@ -410,6 +410,8 @@ void wxListBox::SetSelection(
|
|||||||
,MPFROMLONG(N)
|
,MPFROMLONG(N)
|
||||||
,(MPARAM)bSelect
|
,(MPARAM)bSelect
|
||||||
);
|
);
|
||||||
|
if(m_windowStyle & wxLB_OWNERDRAW)
|
||||||
|
Refresh();
|
||||||
} // end of wxListBox::SetSelection
|
} // end of wxListBox::SetSelection
|
||||||
|
|
||||||
bool wxListBox::IsSelected(
|
bool wxListBox::IsSelected(
|
||||||
@@ -807,21 +809,152 @@ bool wxListBox::OS2Command(
|
|||||||
//
|
//
|
||||||
#define OWNER_DRAWN_LISTBOX_EXTRA_SPACE (1)
|
#define OWNER_DRAWN_LISTBOX_EXTRA_SPACE (1)
|
||||||
|
|
||||||
bool wxListBox::OS2OnMeasure(WXMEASUREITEMSTRUCT *item)
|
bool wxListBox::OS2OnMeasure(
|
||||||
|
WXMEASUREITEMSTRUCT* pItem
|
||||||
|
)
|
||||||
|
{
|
||||||
|
if (!pItem)
|
||||||
|
pItem = (WXMEASUREITEMSTRUCT*)new OWNERITEM;
|
||||||
|
|
||||||
|
POWNERITEM pMeasureStruct = (POWNERITEM)pItem;
|
||||||
|
wxScreenDC vDc;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Only owner-drawn control should receive this message
|
||||||
|
//
|
||||||
|
wxCHECK( ((m_windowStyle & wxLB_OWNERDRAW) == wxLB_OWNERDRAW), FALSE );
|
||||||
|
|
||||||
|
vDc.SetFont(GetFont());
|
||||||
|
|
||||||
|
wxCoord vHeight;
|
||||||
|
|
||||||
|
pMeasureStruct->rclItem.xRight = 0;
|
||||||
|
pMeasureStruct->rclItem.xLeft = 0;
|
||||||
|
pMeasureStruct->rclItem.yTop = 0;
|
||||||
|
pMeasureStruct->rclItem.yBottom = 0;
|
||||||
|
|
||||||
|
vHeight = vDc.GetCharHeight() * 2.5;
|
||||||
|
pMeasureStruct->rclItem.yTop = vHeight;
|
||||||
|
|
||||||
|
::WinSendMsg( GetHWND()
|
||||||
|
,LM_SETITEMHEIGHT
|
||||||
|
,MPFROMLONG(vHeight)
|
||||||
|
,MPFROMLONG(pMeasureStruct->idItem)
|
||||||
|
);
|
||||||
|
return TRUE;
|
||||||
|
} // end of wxListBox::OS2OnMeasure
|
||||||
|
|
||||||
|
bool wxListBox::OS2OnDraw (
|
||||||
|
WXDRAWITEMSTRUCT* pItem
|
||||||
|
)
|
||||||
|
{
|
||||||
|
POWNERITEM pDrawStruct = (POWNERITEM)pItem;
|
||||||
|
LONG lItemID = pDrawStruct->idItem;
|
||||||
|
int eAction = 0;
|
||||||
|
int eStatus = 0;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Only owner-drawn control should receive this message
|
||||||
|
//
|
||||||
|
wxCHECK(((m_windowStyle & wxLB_OWNERDRAW) == wxLB_OWNERDRAW), FALSE);
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// The item may be -1 for an empty listbox
|
||||||
|
//
|
||||||
|
if (lItemID == -1L)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
wxListBoxItem* pData = (wxListBoxItem*)PVOIDFROMMR( ::WinSendMsg( GetHwnd()
|
||||||
|
,LM_QUERYITEMHANDLE
|
||||||
|
,MPFROMLONG(pDrawStruct->idItem)
|
||||||
|
,(MPARAM)0
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
wxCHECK(pData, FALSE );
|
||||||
|
|
||||||
|
wxDC vDc;
|
||||||
|
wxRect vRect( wxPoint( pDrawStruct->rclItem.xLeft
|
||||||
|
,pDrawStruct->rclItem.yTop
|
||||||
|
)
|
||||||
|
,wxPoint( pDrawStruct->rclItem.xRight
|
||||||
|
,pDrawStruct->rclItem.yBottom
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
vDc.SetHPS(pDrawStruct->hps);
|
||||||
|
|
||||||
|
if (pDrawStruct->fsAttribute == pDrawStruct->fsAttributeOld)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// TODO: Get to this eventually
|
// Entire Item needs to be redrawn (either it has reappeared from
|
||||||
|
// behind another window or is being displayed for the first time
|
||||||
|
//
|
||||||
|
eAction = wxOwnerDrawn::wxODDrawAll;
|
||||||
|
|
||||||
|
if (pDrawStruct->fsAttribute & MIA_HILITED)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// If it is currently selected we let the system handle it
|
||||||
|
//
|
||||||
|
eStatus |= wxOwnerDrawn::wxODSelected;
|
||||||
|
}
|
||||||
|
if (pDrawStruct->fsAttribute & MIA_CHECKED)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// If it is currently checked we draw our own
|
||||||
|
//
|
||||||
|
eStatus |= wxOwnerDrawn::wxODChecked;
|
||||||
|
pDrawStruct->fsAttributeOld = pDrawStruct->fsAttribute &= ~MIA_CHECKED;
|
||||||
|
}
|
||||||
|
if (pDrawStruct->fsAttribute & MIA_DISABLED)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// If it is currently disabled we let the system handle it
|
||||||
|
//
|
||||||
|
eStatus |= wxOwnerDrawn::wxODDisabled;
|
||||||
|
}
|
||||||
|
//
|
||||||
|
// Don't really care about framed (indicationg focus) or NoDismiss
|
||||||
|
//
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (pDrawStruct->fsAttribute & MIA_HILITED)
|
||||||
|
{
|
||||||
|
eAction = wxOwnerDrawn::wxODDrawAll;
|
||||||
|
eStatus |= wxOwnerDrawn::wxODSelected;
|
||||||
|
//
|
||||||
|
// Keep the system from trying to highlight with its bogus colors
|
||||||
|
//
|
||||||
|
pDrawStruct->fsAttributeOld = pDrawStruct->fsAttribute &= ~MIA_HILITED;
|
||||||
|
}
|
||||||
|
else if (!(pDrawStruct->fsAttribute & MIA_HILITED))
|
||||||
|
{
|
||||||
|
eAction = wxOwnerDrawn::wxODDrawAll;
|
||||||
|
eStatus = 0;
|
||||||
|
//
|
||||||
|
// Keep the system from trying to highlight with its bogus colors
|
||||||
|
//
|
||||||
|
pDrawStruct->fsAttribute = pDrawStruct->fsAttributeOld &= ~MIA_HILITED;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// For now we don't care about anything else
|
||||||
|
// just ignore the entire message!
|
||||||
//
|
//
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxListBox::OS2OnDraw(WXDRAWITEMSTRUCT *item)
|
|
||||||
{
|
|
||||||
//
|
|
||||||
// TODO: Get to this eventually
|
|
||||||
//
|
|
||||||
return FALSE;
|
|
||||||
}
|
}
|
||||||
|
return pData->OnDrawItem( vDc
|
||||||
|
,vRect
|
||||||
|
,(wxOwnerDrawn::wxODAction)eAction
|
||||||
|
,(wxOwnerDrawn::wxODStatus)eStatus
|
||||||
|
);
|
||||||
|
} // end of wxListBox::OS2OnDraw
|
||||||
|
|
||||||
#endif // ndef for wxUSE_OWNER_DRAWN
|
#endif // ndef for wxUSE_OWNER_DRAWN
|
||||||
|
|
||||||
#endif // ndef for wxUSE_LISTBOX
|
#endif // ndef for wxUSE_LISTBOX
|
||||||
|
@@ -679,8 +679,20 @@ void wxNotebook::OnSize(
|
|||||||
wxSizeEvent& rEvent
|
wxSizeEvent& rEvent
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
if (m_nSelection < m_pages.Count() && m_nSelection >= 0)
|
int nPage;
|
||||||
m_pages[m_nSelection]->Refresh();
|
int nCount = (int)m_pages.Count();
|
||||||
|
|
||||||
|
for (nPage = 0; nPage < nCount; nPage++)
|
||||||
|
{
|
||||||
|
if (m_nSelection == nPage)
|
||||||
|
m_pages[nPage]->Refresh();
|
||||||
|
else
|
||||||
|
::WinSetWindowPos(m_pages[nPage]->GetHWND()
|
||||||
|
,NULLHANDLE
|
||||||
|
,0,0,0,0
|
||||||
|
,SWP_HIDE
|
||||||
|
);
|
||||||
|
}
|
||||||
rEvent.Skip();
|
rEvent.Skip();
|
||||||
} // end of wxNotebook::OnSize
|
} // end of wxNotebook::OnSize
|
||||||
|
|
||||||
@@ -693,22 +705,44 @@ void wxNotebook::OnSelChange (
|
|||||||
//
|
//
|
||||||
if (rEvent.GetEventObject() == this)
|
if (rEvent.GetEventObject() == this)
|
||||||
{
|
{
|
||||||
int nSel = rEvent.GetOldSelection();
|
int nPageCount = GetPageCount();
|
||||||
|
int nSel;
|
||||||
|
ULONG ulOS2Sel = (ULONG)rEvent.GetOldSelection();
|
||||||
|
bool bFound = FALSE;
|
||||||
|
|
||||||
if (nSel != -1)
|
for (nSel = 0; nSel < nPageCount; nSel++)
|
||||||
{
|
{
|
||||||
m_pages[nSel]->Show(FALSE);
|
if (ulOS2Sel == m_alPageId[nSel])
|
||||||
m_pages[nSel]->SetActivePage(FALSE);
|
{
|
||||||
|
bFound = TRUE;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
nSel = rEvent.GetSelection();
|
}
|
||||||
if (nSel != -1)
|
|
||||||
|
if (!bFound)
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_pages[nSel]->Show(FALSE);
|
||||||
|
|
||||||
|
ulOS2Sel = (ULONG)rEvent.GetSelection();
|
||||||
|
|
||||||
|
bFound = FALSE;
|
||||||
|
|
||||||
|
for (nSel = 0; nSel < nPageCount; nSel++)
|
||||||
{
|
{
|
||||||
|
if (ulOS2Sel == m_alPageId[nSel])
|
||||||
|
{
|
||||||
|
bFound = TRUE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!bFound)
|
||||||
|
return;
|
||||||
|
|
||||||
wxNotebookPage* pPage = m_pages[nSel];
|
wxNotebookPage* pPage = m_pages[nSel];
|
||||||
|
|
||||||
pPage->Show(TRUE);
|
pPage->Show(TRUE);
|
||||||
pPage->SetFocus();
|
|
||||||
m_pages[nSel]->SetActivePage(TRUE);
|
|
||||||
}
|
|
||||||
m_nSelection = nSel;
|
m_nSelection = nSel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -32,6 +32,10 @@
|
|||||||
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxStaticBitmap, wxControl)
|
IMPLEMENT_DYNAMIC_CLASS(wxStaticBitmap, wxControl)
|
||||||
|
|
||||||
|
BEGIN_EVENT_TABLE(wxStaticBitmap, wxWindow)
|
||||||
|
EVT_PAINT(wxStaticBitmap::OnPaint)
|
||||||
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
static wxGDIImage* ConvertImage(
|
static wxGDIImage* ConvertImage(
|
||||||
const wxGDIImage& rBitmap
|
const wxGDIImage& rBitmap
|
||||||
)
|
)
|
||||||
@@ -105,9 +109,8 @@ bool wxStaticBitmap::Create(
|
|||||||
//
|
//
|
||||||
int nWinstyle = SS_ICON;
|
int nWinstyle = SS_ICON;
|
||||||
|
|
||||||
sprintf(zId, "#%d", rBitmap.GetId());
|
|
||||||
m_hWnd = (WXHWND)::WinCreateWindow( pParent->GetHWND()
|
m_hWnd = (WXHWND)::WinCreateWindow( pParent->GetHWND()
|
||||||
,WC_STATIC
|
,wxCanvasClassName
|
||||||
,zId
|
,zId
|
||||||
,nWinstyle | WS_VISIBLE
|
,nWinstyle | WS_VISIBLE
|
||||||
,0,0,0,0
|
,0,0,0,0
|
||||||
@@ -129,6 +132,8 @@ bool wxStaticBitmap::Create(
|
|||||||
|
|
||||||
// Subclass again for purposes of dialog editing mode
|
// Subclass again for purposes of dialog editing mode
|
||||||
SubclassWin(m_hWnd);
|
SubclassWin(m_hWnd);
|
||||||
|
SetSize(nX, nY, m_pImage->GetWidth(), m_pImage->GetHeight());
|
||||||
|
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
} // end of wxStaticBitmap::Create
|
} // end of wxStaticBitmap::Create
|
||||||
|
|
||||||
@@ -153,6 +158,30 @@ wxSize wxStaticBitmap::DoGetBestSize() const
|
|||||||
return wxWindow::DoGetBestSize();
|
return wxWindow::DoGetBestSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxStaticBitmap::OnPaint (
|
||||||
|
wxPaintEvent& WXUNUSED(rEvent)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
wxPaintDC vDc(this);
|
||||||
|
int i;
|
||||||
|
wxBitmap* pBitmap;
|
||||||
|
|
||||||
|
if (m_pImage->IsKindOf(CLASSINFO(wxIcon)))
|
||||||
|
{
|
||||||
|
wxIcon* pIcon;
|
||||||
|
|
||||||
|
pIcon = wxDynamicCast(m_pImage, wxIcon);
|
||||||
|
pBitmap = new wxBitmap(*pIcon);
|
||||||
|
vDc.DrawBitmap(*pBitmap, 0, 0);
|
||||||
|
delete pBitmap;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pBitmap = wxDynamicCast(m_pImage, wxBitmap);
|
||||||
|
vDc.DrawBitmap(*pBitmap, 0, 0);
|
||||||
|
}
|
||||||
|
} // end of wxStaticBitmap::OnPaint
|
||||||
|
|
||||||
void wxStaticBitmap::SetImage(
|
void wxStaticBitmap::SetImage(
|
||||||
const wxGDIImage& rBitmap
|
const wxGDIImage& rBitmap
|
||||||
)
|
)
|
||||||
|
@@ -59,6 +59,10 @@
|
|||||||
#include "wx/tooltip.h"
|
#include "wx/tooltip.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if wxUSE_NOTEBOOK
|
||||||
|
#include "wx/notebook.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#if wxUSE_CARET
|
#if wxUSE_CARET
|
||||||
#include "wx/caret.h"
|
#include "wx/caret.h"
|
||||||
#endif // wxUSE_CARET
|
#endif // wxUSE_CARET
|
||||||
@@ -301,7 +305,6 @@ void wxWindowOS2::Init()
|
|||||||
m_bUseCtl3D = FALSE;
|
m_bUseCtl3D = FALSE;
|
||||||
m_bMouseInWindow = FALSE;
|
m_bMouseInWindow = FALSE;
|
||||||
m_bLastKeydownProcessed = FALSE;
|
m_bLastKeydownProcessed = FALSE;
|
||||||
m_bIsActivePage = TRUE;
|
|
||||||
m_pChildrenDisabled = NULL;
|
m_pChildrenDisabled = NULL;
|
||||||
|
|
||||||
//
|
//
|
||||||
@@ -2905,7 +2908,6 @@ MRESULT wxWindowOS2::OS2WindowProc(
|
|||||||
// Avoid duplicate messages to OnChar for these ASCII keys: they
|
// Avoid duplicate messages to OnChar for these ASCII keys: they
|
||||||
// will be translated by TranslateMessage() and received in WM_CHAR
|
// will be translated by TranslateMessage() and received in WM_CHAR
|
||||||
case VK_ESC:
|
case VK_ESC:
|
||||||
case VK_SPACE:
|
|
||||||
case VK_ENTER:
|
case VK_ENTER:
|
||||||
case VK_BACKSPACE:
|
case VK_BACKSPACE:
|
||||||
case VK_TAB:
|
case VK_TAB:
|
||||||
@@ -2966,7 +2968,41 @@ MRESULT wxWindowOS2::OS2WindowProc(
|
|||||||
case WM_CONTROL:
|
case WM_CONTROL:
|
||||||
switch(SHORT2FROMMP(wParam))
|
switch(SHORT2FROMMP(wParam))
|
||||||
{
|
{
|
||||||
case BN_CLICKED:
|
case BKN_PAGESELECTEDPENDING:
|
||||||
|
{
|
||||||
|
PPAGESELECTNOTIFY pPage = (PPAGESELECTNOTIFY)lParam;
|
||||||
|
|
||||||
|
if ((pPage->ulPageIdNew != pPage->ulPageIdCur) &&
|
||||||
|
(pPage->ulPageIdNew > 0L && pPage->ulPageIdCur > 0L))
|
||||||
|
{
|
||||||
|
wxWindowOS2* pWin = wxFindWinFromHandle(pPage->hwndBook);
|
||||||
|
wxNotebookEvent vEvent( wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED
|
||||||
|
,(int)SHORT1FROMMP(wParam)
|
||||||
|
,(int)pPage->ulPageIdNew
|
||||||
|
,(int)pPage->ulPageIdCur
|
||||||
|
);
|
||||||
|
if (!pWin)
|
||||||
|
{
|
||||||
|
bProcessed = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (pWin->IsKindOf(CLASSINFO(wxNotebook)))
|
||||||
|
{
|
||||||
|
wxNotebook* pNotebook = wxDynamicCast(pWin, wxNotebook);
|
||||||
|
|
||||||
|
vEvent.SetEventObject(pWin);
|
||||||
|
pNotebook->OnSelChange(vEvent);
|
||||||
|
bProcessed = TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
bProcessed = FALSE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
bProcessed = FALSE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case BN_CLICKED: // Dups as LN_SELECT and CBN_LBSELECT
|
||||||
{
|
{
|
||||||
HWND hWnd = ::WinWindowFromID((HWND)GetHwnd(), SHORT1FROMMP(wParam));
|
HWND hWnd = ::WinWindowFromID((HWND)GetHwnd(), SHORT1FROMMP(wParam));
|
||||||
wxWindowOS2* pWin = wxFindWinFromHandle(hWnd);
|
wxWindowOS2* pWin = wxFindWinFromHandle(hWnd);
|
||||||
@@ -3004,6 +3040,61 @@ MRESULT wxWindowOS2::OS2WindowProc(
|
|||||||
,(WXUINT)SHORT1FROMMP(wParam)
|
,(WXUINT)SHORT1FROMMP(wParam)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
if (pWin->IsKindOf(CLASSINFO(wxListBox)))
|
||||||
|
{
|
||||||
|
wxListBox* pListBox = wxDynamicCast(pWin, wxListBox);
|
||||||
|
|
||||||
|
pListBox->OS2Command( (WXUINT)SHORT2FROMMP(wParam)
|
||||||
|
,(WXUINT)SHORT1FROMMP(wParam)
|
||||||
|
);
|
||||||
|
if (pListBox->GetWindowStyle() & wxLB_OWNERDRAW)
|
||||||
|
Refresh();
|
||||||
|
}
|
||||||
|
if (pWin->IsKindOf(CLASSINFO(wxComboBox)))
|
||||||
|
{
|
||||||
|
wxComboBox* pComboBox = wxDynamicCast(pWin, wxComboBox);
|
||||||
|
|
||||||
|
pComboBox->OS2Command( (WXUINT)SHORT2FROMMP(wParam)
|
||||||
|
,(WXUINT)SHORT1FROMMP(wParam)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case LN_ENTER: /* dups as CBN_EFCHANGE */
|
||||||
|
{
|
||||||
|
HWND hWnd = HWNDFROMMP(lParam);
|
||||||
|
wxWindowOS2* pWin = wxFindWinFromHandle(hWnd);
|
||||||
|
|
||||||
|
if (!pWin)
|
||||||
|
{
|
||||||
|
bProcessed = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
//
|
||||||
|
// Simulate a WM_COMMAND here, as wxWindows expects all control
|
||||||
|
// button clicks to generate WM_COMMAND msgs, not WM_CONTROL
|
||||||
|
//
|
||||||
|
if (pWin->IsKindOf(CLASSINFO(wxListBox)))
|
||||||
|
{
|
||||||
|
wxListBox* pListBox = wxDynamicCast(pWin, wxListBox);
|
||||||
|
|
||||||
|
pListBox->OS2Command( (WXUINT)SHORT2FROMMP(wParam)
|
||||||
|
,(WXUINT)SHORT1FROMMP(wParam)
|
||||||
|
);
|
||||||
|
if (pListBox->GetWindowStyle() & wxLB_OWNERDRAW)
|
||||||
|
Refresh();
|
||||||
|
|
||||||
|
}
|
||||||
|
if (pWin->IsKindOf(CLASSINFO(wxComboBox)))
|
||||||
|
{
|
||||||
|
wxComboBox* pComboBox = wxDynamicCast(pWin, wxComboBox);
|
||||||
|
|
||||||
|
pComboBox->OS2Command( (WXUINT)SHORT2FROMMP(wParam)
|
||||||
|
,(WXUINT)SHORT1FROMMP(wParam)
|
||||||
|
);
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -3755,7 +3846,10 @@ bool wxWindowOS2::OS2OnMeasureItem(
|
|||||||
|
|
||||||
if (pItem && pItem->IsKindOf(CLASSINFO(wxControl)))
|
if (pItem && pItem->IsKindOf(CLASSINFO(wxControl)))
|
||||||
{
|
{
|
||||||
return ((wxControl *)pItem)->OS2OnMeasure(pItemStruct);
|
OWNERITEM vItem;
|
||||||
|
|
||||||
|
vItem.idItem = (LONG)pItemStruct;
|
||||||
|
return ((wxControl *)pItem)->OS2OnMeasure((WXMEASUREITEMSTRUCT*)&vItem);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
lId = lId;
|
lId = lId;
|
||||||
@@ -3902,9 +3996,7 @@ bool wxWindowOS2::HandlePaint()
|
|||||||
,0L
|
,0L
|
||||||
,NULL
|
,NULL
|
||||||
);
|
);
|
||||||
|
if (::WinIsWindowVisible(GetHWND()))
|
||||||
if (::WinIsWindowVisible(GetHWND()) && m_bIsActivePage)
|
|
||||||
{
|
|
||||||
::WinFillRect(hPS, &vRect, GetBackgroundColour().GetPixel());
|
::WinFillRect(hPS, &vRect, GetBackgroundColour().GetPixel());
|
||||||
if (m_dwExStyle)
|
if (m_dwExStyle)
|
||||||
{
|
{
|
||||||
@@ -3930,7 +4022,6 @@ bool wxWindowOS2::HandlePaint()
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
::WinEndPaint(hPS);
|
::WinEndPaint(hPS);
|
||||||
bProcessed = TRUE;
|
bProcessed = TRUE;
|
||||||
}
|
}
|
||||||
@@ -3967,7 +4058,7 @@ bool wxWindowOS2::HandlePaint()
|
|||||||
,NULL
|
,NULL
|
||||||
);
|
);
|
||||||
|
|
||||||
if (::WinIsWindowVisible(GetHWND()) && m_bIsActivePage)
|
if (::WinIsWindowVisible(GetHWND()))
|
||||||
::WinFillRect(hPS, &vRect, GetBackgroundColour().GetPixel());
|
::WinFillRect(hPS, &vRect, GetBackgroundColour().GetPixel());
|
||||||
}
|
}
|
||||||
::WinEndPaint(hPS);
|
::WinEndPaint(hPS);
|
||||||
@@ -4327,7 +4418,7 @@ bool wxWindowOS2::HandleChar(
|
|||||||
// ctrlDown. IOW, Ctrl-C should result in keycode == 3 and
|
// ctrlDown. IOW, Ctrl-C should result in keycode == 3 and
|
||||||
// ControlDown() == TRUE.
|
// ControlDown() == TRUE.
|
||||||
//
|
//
|
||||||
vId = (int)wParam;
|
vId = SHORT1FROMMP(lParam);
|
||||||
if ((vId > 0) && (vId < 27))
|
if ((vId > 0) && (vId < 27))
|
||||||
{
|
{
|
||||||
switch (vId)
|
switch (vId)
|
||||||
@@ -4352,7 +4443,7 @@ bool wxWindowOS2::HandleChar(
|
|||||||
}
|
}
|
||||||
else // we're called from WM_KEYDOWN
|
else // we're called from WM_KEYDOWN
|
||||||
{
|
{
|
||||||
vId = wxCharCodeOS2ToWX((int)wParam);
|
vId = wxCharCodeOS2ToWX((int)SHORT2FROMMP(lParam));
|
||||||
if (vId == 0)
|
if (vId == 0)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@@ -4374,14 +4465,14 @@ bool wxWindowOS2::HandleKeyDown(
|
|||||||
, WXLPARAM lParam
|
, WXLPARAM lParam
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
int nId = wxCharCodeOS2ToWX((int)wParam);
|
int nId = wxCharCodeOS2ToWX((int)SHORT2FROMMP(lParam));
|
||||||
|
|
||||||
if (!nId)
|
if (!nId)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// Normal ASCII char
|
// Normal ASCII char
|
||||||
//
|
//
|
||||||
nId = (int)wParam;
|
nId = SHORT1FROMMP(lParam);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nId != -1)
|
if (nId != -1)
|
||||||
@@ -4405,7 +4496,7 @@ bool wxWindowOS2::HandleKeyUp(
|
|||||||
, WXLPARAM lParam
|
, WXLPARAM lParam
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
int nId = wxCharCodeOS2ToWX((int)wParam);
|
int nId = wxCharCodeOS2ToWX((int)SHORT2FROMMP(lParam));
|
||||||
|
|
||||||
if (!nId)
|
if (!nId)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user