added wxVListBox::OnDrawBackground(); fixed warnings

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@22394 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2003-07-30 21:36:38 +00:00
parent 6839868c86
commit 27d0dcd033
6 changed files with 44 additions and 21 deletions

View File

@@ -120,6 +120,7 @@ private:
DECLARE_EVENT_TABLE()
DECLARE_NO_COPY_CLASS(wxHtmlListBox)
};
#endif // _WX_HTMLLBOX_H_

View File

@@ -202,6 +202,14 @@ protected:
// the base class version doesn't do anything
virtual void OnDrawSeparator(wxDC& dc, wxRect& rect, size_t n) const;
// this method is used to draw the items background and, maybe, a border
// around it
//
// the base class version implements a reasonable default behaviour which
// consists in drawing the selected item with the standard background
// colour and drawing a border around the item if it is either selected or
// current
virtual void OnDrawBackground(wxDC& dc, const wxRect& rect, size_t n) const;
// we implement OnGetLineHeight() in terms of OnMeasureItem() because this
// allows us to add borders to the items easily
@@ -269,6 +277,7 @@ private:
DECLARE_EVENT_TABLE()
DECLARE_NO_COPY_CLASS(wxVListBox)
};
#endif // _WX_VLBOX_H_

View File

@@ -146,7 +146,8 @@ protected:
//
// finally note that lineMin is inclusive, while lineMax is exclusive, as
// usual
virtual void OnGetLinesHint(size_t lineMin, size_t lineMax) const { }
virtual void OnGetLinesHint(size_t WXUNUSED(lineMin),
size_t WXUNUSED(lineMax)) const { }
// when the number of lines changes, we try to estimate the total height
// of all lines which is a rather expensive operation in terms of lines
@@ -194,6 +195,7 @@ private:
DECLARE_EVENT_TABLE()
DECLARE_NO_COPY_CLASS(wxVScrolledWindow)
};
#endif // _WX_VSCROLL_H_

View File

@@ -45,7 +45,7 @@
// you can also have a file containing HTML strings for testing, enable this if
// you want to use it
//#define USE_HTML_FILE
#define USE_HTML_FILE
#ifdef USE_HTML_FILE
#include "wx/textfile.h"
#endif
@@ -84,6 +84,8 @@ protected:
#ifdef USE_HTML_FILE
wxTextFile m_file;
#endif
DECLARE_NO_COPY_CLASS(MyHtmlListBox)
};
class MyFrame : public wxFrame

View File

@@ -144,6 +144,8 @@ public:
private:
const wxHtmlListBox& m_hlbox;
DECLARE_NO_COPY_CLASS(wxHtmlListBoxStyle)
};

View File

@@ -319,7 +319,30 @@ void wxVListBox::OnDrawSeparator(wxDC& WXUNUSED(dc),
{
}
void wxVListBox::OnPaint(wxPaintEvent& event)
void wxVListBox::OnDrawBackground(wxDC& dc, const wxRect& rect, size_t n) const
{
// we need to render selected and current items differently
const bool isSelected = IsSelected(n),
isCurrent = IsCurrent(n);
if ( isSelected || isCurrent )
{
if ( isSelected )
{
dc.SetBrush(wxBrush(m_colBgSel, wxSOLID));
}
else // !selected
{
dc.SetBrush(*wxTRANSPARENT_BRUSH);
}
dc.SetPen(*(isCurrent ? wxBLACK_PEN : wxTRANSPARENT_PEN));
dc.DrawRectangle(rect);
}
//else: do nothing for the normal items
}
void wxVListBox::OnPaint(wxPaintEvent& WXUNUSED(event))
{
wxPaintDC dc(this);
@@ -344,25 +367,9 @@ void wxVListBox::OnPaint(wxPaintEvent& event)
// don't allow drawing outside of the lines rectangle
wxDCClipper clip(dc, rectLine);
// we need to render selected and current items differently
const bool isSelected = IsSelected(line);
if ( isSelected || IsCurrent(line) )
{
if ( isSelected )
{
dc.SetBrush(wxBrush(m_colBgSel, wxSOLID));
}
else // !selected
{
dc.SetBrush(*wxTRANSPARENT_BRUSH);
}
dc.SetPen(*(IsCurrent(line) ? wxBLACK_PEN : wxTRANSPARENT_PEN));
dc.DrawRectangle(rectLine);
}
wxRect rect = rectLine;
OnDrawBackground(dc, rect, line);
OnDrawSeparator(dc, rect, line);
rect.Deflate(m_ptMargins.x, m_ptMargins.y);