2003-06-01 13:35:26 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/htmllbox.h
|
|
|
|
// Purpose: wxHtmlListBox is a listbox whose items are wxHtmlCells
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 31.05.03
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwindows.org>
|
|
|
|
// Licence: wxWindows licence
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_HTMLLBOX_H_
|
|
|
|
#define _WX_HTMLLBOX_H_
|
|
|
|
|
|
|
|
#include "wx/vlbox.h" // base class
|
|
|
|
|
2003-07-04 13:04:05 +00:00
|
|
|
class WXDLLIMPEXP_HTML wxHtmlCell;
|
|
|
|
class WXDLLIMPEXP_HTML wxHtmlWinParser;
|
|
|
|
class WXDLLIMPEXP_HTML wxHtmlListBoxCache;
|
|
|
|
class WXDLLIMPEXP_HTML wxHtmlListBoxStyle;
|
2003-06-01 13:35:26 +00:00
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxHtmlListBox
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2003-07-04 13:04:05 +00:00
|
|
|
class WXDLLIMPEXP_HTML wxHtmlListBox : public wxVListBox
|
2003-06-01 13:35:26 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// constructors and such
|
|
|
|
// ---------------------
|
|
|
|
|
|
|
|
// default constructor, you must call Create() later
|
|
|
|
wxHtmlListBox() { Init(); }
|
|
|
|
|
|
|
|
// normal constructor which calls Create() internally
|
|
|
|
wxHtmlListBox(wxWindow *parent,
|
|
|
|
wxWindowID id = wxID_ANY,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
|
|
|
const wxString& name = wxVListBoxNameStr)
|
|
|
|
{
|
|
|
|
Init();
|
|
|
|
|
2003-06-11 11:47:09 +00:00
|
|
|
(void)Create(parent, id, pos, size, style, name);
|
2003-06-01 13:35:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// really creates the control and sets the initial number of items in it
|
|
|
|
// (which may be changed later with SetItemCount())
|
|
|
|
//
|
2003-06-11 11:47:09 +00:00
|
|
|
// the only special style which may be specified here is wxLB_MULTIPLE
|
2003-06-01 13:35:26 +00:00
|
|
|
//
|
|
|
|
// returns true on success or false if the control couldn't be created
|
|
|
|
bool Create(wxWindow *parent,
|
|
|
|
wxWindowID id = wxID_ANY,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
|
|
|
const wxString& name = wxVListBoxNameStr);
|
|
|
|
|
|
|
|
// destructor cleans up whatever resources we use
|
|
|
|
virtual ~wxHtmlListBox();
|
|
|
|
|
2003-06-26 10:05:13 +00:00
|
|
|
// override some base class virtuals
|
2003-06-02 23:02:12 +00:00
|
|
|
virtual void RefreshAll();
|
2003-06-26 10:05:13 +00:00
|
|
|
virtual void SetItemCount(size_t count);
|
2003-06-02 23:02:12 +00:00
|
|
|
|
2003-06-01 13:35:26 +00:00
|
|
|
protected:
|
|
|
|
// this method must be implemented in the derived class and should return
|
|
|
|
// the body (i.e. without <html>) of the HTML for the given item
|
|
|
|
virtual wxString OnGetItem(size_t n) const = 0;
|
|
|
|
|
|
|
|
// this function may be overridden to decorate HTML returned by OnGetItem()
|
|
|
|
virtual wxString OnGetItemMarkup(size_t n) const;
|
|
|
|
|
|
|
|
|
2003-06-13 22:26:45 +00:00
|
|
|
// this method allows to customize the selection appearance: it may be used
|
|
|
|
// to specify the colour of the text which normally has the given colour
|
|
|
|
// colFg when it is inside the selection
|
|
|
|
//
|
|
|
|
// by default, the original colour is not used at all and all text has the
|
|
|
|
// same (default for this system) colour inside selection
|
|
|
|
virtual wxColour GetSelectedTextColour(const wxColour& colFg) const;
|
|
|
|
|
|
|
|
// this is the same as GetSelectedTextColour() but allows to customize the
|
|
|
|
// background colour -- this is even more rarely used as you can change it
|
|
|
|
// globally using SetSelectionBackground()
|
|
|
|
virtual wxColour GetSelectedTextBgColour(const wxColour& colBg) const;
|
|
|
|
|
|
|
|
|
2003-06-01 13:35:26 +00:00
|
|
|
// we implement both of these functions in terms of OnGetItem(), they are
|
|
|
|
// not supposed to be overridden by our descendants
|
|
|
|
virtual void OnDrawItem(wxDC& dc, const wxRect& rect, size_t n) const;
|
|
|
|
virtual wxCoord OnMeasureItem(size_t n) const;
|
|
|
|
|
|
|
|
|
2003-06-02 23:02:12 +00:00
|
|
|
// event handlers
|
|
|
|
void OnSize(wxSizeEvent& event);
|
|
|
|
|
|
|
|
|
2003-06-01 13:35:26 +00:00
|
|
|
// common part of all ctors
|
|
|
|
void Init();
|
|
|
|
|
|
|
|
// ensure that the given item is cached
|
|
|
|
void CacheItem(size_t n) const;
|
|
|
|
|
|
|
|
private:
|
2003-06-13 22:26:45 +00:00
|
|
|
// this class caches the pre-parsed HTML to speed up display
|
2003-06-01 13:35:26 +00:00
|
|
|
wxHtmlListBoxCache *m_cache;
|
|
|
|
|
|
|
|
// HTML parser we use
|
|
|
|
wxHtmlWinParser *m_htmlParser;
|
2003-06-02 23:02:12 +00:00
|
|
|
|
2003-06-13 22:26:45 +00:00
|
|
|
// rendering style for the parser which allows us to customize our colours
|
|
|
|
wxHtmlListBoxStyle *m_htmlRendStyle;
|
|
|
|
|
|
|
|
|
|
|
|
// it calls our GetSelectedTextColour() and GetSelectedTextBgColour()
|
|
|
|
friend class wxHtmlListBoxStyle;
|
|
|
|
|
2003-06-02 23:02:12 +00:00
|
|
|
|
|
|
|
DECLARE_EVENT_TABLE()
|
2003-06-01 13:35:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _WX_HTMLLBOX_H_
|
|
|
|
|