2003-06-01 09:35:26 -04: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$
|
2004-05-23 10:56:36 -04:00
|
|
|
// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
|
2004-05-23 16:53:33 -04:00
|
|
|
// Licence: wxWindows licence
|
2003-06-01 09:35:26 -04:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_HTMLLBOX_H_
|
|
|
|
#define _WX_HTMLLBOX_H_
|
|
|
|
|
|
|
|
#include "wx/vlbox.h" // base class
|
2006-04-13 18:08:28 -04:00
|
|
|
#include "wx/html/htmlwin.h"
|
2006-10-22 18:09:16 -04:00
|
|
|
#include "wx/ctrlsub.h"
|
2003-06-01 09:35:26 -04:00
|
|
|
|
2004-04-30 18:44:03 -04:00
|
|
|
#if wxUSE_FILESYSTEM
|
|
|
|
#include "wx/filesys.h"
|
|
|
|
#endif // wxUSE_FILESYSTEM
|
|
|
|
|
2007-07-09 06:09:52 -04:00
|
|
|
class WXDLLIMPEXP_FWD_HTML wxHtmlCell;
|
|
|
|
class WXDLLIMPEXP_FWD_HTML wxHtmlWinParser;
|
|
|
|
class WXDLLIMPEXP_FWD_HTML wxHtmlListBoxCache;
|
|
|
|
class WXDLLIMPEXP_FWD_HTML wxHtmlListBoxStyle;
|
2003-06-01 09:35:26 -04:00
|
|
|
|
2008-11-02 17:16:14 -05:00
|
|
|
extern WXDLLIMPEXP_DATA_HTML(const char) wxHtmlListBoxNameStr[];
|
|
|
|
extern WXDLLIMPEXP_DATA_HTML(const char) wxSimpleHtmlListBoxNameStr[];
|
2006-10-22 18:09:16 -04:00
|
|
|
|
2003-06-01 09:35:26 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxHtmlListBox
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2006-04-13 18:08:28 -04:00
|
|
|
class WXDLLIMPEXP_HTML wxHtmlListBox : public wxVListBox,
|
|
|
|
public wxHtmlWindowInterface,
|
2006-04-14 16:43:06 -04:00
|
|
|
public wxHtmlWindowMouseHelper
|
2003-06-01 09:35:26 -04:00
|
|
|
{
|
2003-08-08 17:23:33 -04:00
|
|
|
DECLARE_ABSTRACT_CLASS(wxHtmlListBox)
|
2003-06-01 09:35:26 -04:00
|
|
|
public:
|
|
|
|
// constructors and such
|
|
|
|
// ---------------------
|
|
|
|
|
|
|
|
// default constructor, you must call Create() later
|
2006-04-13 18:08:28 -04:00
|
|
|
wxHtmlListBox();
|
2003-06-01 09:35:26 -04:00
|
|
|
|
|
|
|
// normal constructor which calls Create() internally
|
|
|
|
wxHtmlListBox(wxWindow *parent,
|
|
|
|
wxWindowID id = wxID_ANY,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
2006-10-22 18:09:16 -04:00
|
|
|
const wxString& name = wxHtmlListBoxNameStr);
|
2003-06-01 09:35:26 -04:00
|
|
|
|
|
|
|
// really creates the control and sets the initial number of items in it
|
|
|
|
// (which may be changed later with SetItemCount())
|
|
|
|
//
|
2003-06-11 07:47:09 -04:00
|
|
|
// the only special style which may be specified here is wxLB_MULTIPLE
|
2003-06-01 09:35:26 -04: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,
|
2006-10-22 18:09:16 -04:00
|
|
|
const wxString& name = wxHtmlListBoxNameStr);
|
2003-06-01 09:35:26 -04:00
|
|
|
|
|
|
|
// destructor cleans up whatever resources we use
|
|
|
|
virtual ~wxHtmlListBox();
|
|
|
|
|
2003-06-26 06:05:13 -04:00
|
|
|
// override some base class virtuals
|
2007-04-08 09:55:36 -04:00
|
|
|
virtual void RefreshRow(size_t line);
|
|
|
|
virtual void RefreshRows(size_t from, size_t to);
|
2003-06-02 19:02:12 -04:00
|
|
|
virtual void RefreshAll();
|
2003-06-26 06:05:13 -04:00
|
|
|
virtual void SetItemCount(size_t count);
|
2003-06-02 19:02:12 -04:00
|
|
|
|
2004-04-30 18:44:03 -04:00
|
|
|
#if wxUSE_FILESYSTEM
|
|
|
|
// retrieve the file system used by the wxHtmlWinParser: if you use
|
|
|
|
// relative paths in your HTML, you should use its ChangePathTo() method
|
|
|
|
wxFileSystem& GetFileSystem() { return m_filesystem; }
|
|
|
|
const wxFileSystem& GetFileSystem() const { return m_filesystem; }
|
|
|
|
#endif // wxUSE_FILESYSTEM
|
|
|
|
|
2006-04-13 18:08:28 -04:00
|
|
|
virtual void OnInternalIdle();
|
|
|
|
|
2003-06-01 09:35:26 -04: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 18:26:45 -04: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 09:35:26 -04: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;
|
|
|
|
|
2008-03-02 18:05:35 -05:00
|
|
|
// override this one to draw custom background for selected items correctly
|
|
|
|
virtual void OnDrawBackground(wxDC& dc, const wxRect& rect, size_t n) const;
|
|
|
|
|
|
|
|
// this method may be overridden to handle clicking on a link in the
|
|
|
|
// listbox (by default, clicks on links are simply ignored)
|
2006-10-29 15:26:03 -05:00
|
|
|
virtual void OnLinkClicked(size_t n, const wxHtmlLinkInfo& link);
|
2003-06-01 09:35:26 -04:00
|
|
|
|
2003-06-02 19:02:12 -04:00
|
|
|
// event handlers
|
|
|
|
void OnSize(wxSizeEvent& event);
|
2006-04-13 18:08:28 -04:00
|
|
|
void OnMouseMove(wxMouseEvent& event);
|
|
|
|
void OnLeftDown(wxMouseEvent& event);
|
2003-06-02 19:02:12 -04:00
|
|
|
|
|
|
|
|
2003-06-01 09:35:26 -04:00
|
|
|
// common part of all ctors
|
|
|
|
void Init();
|
|
|
|
|
|
|
|
// ensure that the given item is cached
|
|
|
|
void CacheItem(size_t n) const;
|
|
|
|
|
2006-04-13 18:08:28 -04:00
|
|
|
private:
|
|
|
|
// wxHtmlWindowInterface methods:
|
|
|
|
virtual void SetHTMLWindowTitle(const wxString& title);
|
|
|
|
virtual void OnHTMLLinkClicked(const wxHtmlLinkInfo& link);
|
|
|
|
virtual wxHtmlOpeningStatus OnHTMLOpeningURL(wxHtmlURLType type,
|
|
|
|
const wxString& url,
|
|
|
|
wxString *redirect) const;
|
|
|
|
virtual wxPoint HTMLCoordsToWindow(wxHtmlCell *cell,
|
|
|
|
const wxPoint& pos) const;
|
|
|
|
virtual wxWindow* GetHTMLWindow();
|
|
|
|
virtual wxColour GetHTMLBackgroundColour() const;
|
|
|
|
virtual void SetHTMLBackgroundColour(const wxColour& clr);
|
|
|
|
virtual void SetHTMLBackgroundImage(const wxBitmap& bmpBg);
|
|
|
|
virtual void SetHTMLStatusText(const wxString& text);
|
2006-04-14 07:38:36 -04:00
|
|
|
virtual wxCursor GetHTMLCursor(HTMLCursor type) const;
|
2006-04-13 18:08:28 -04:00
|
|
|
|
|
|
|
// returns index of item that contains given HTML cell
|
|
|
|
size_t GetItemForCell(const wxHtmlCell *cell) const;
|
|
|
|
|
|
|
|
// return physical coordinates of root wxHtmlCell of n-th item
|
|
|
|
wxPoint GetRootCellCoords(size_t n) const;
|
|
|
|
|
|
|
|
// Converts physical coordinates stored in @a pos into coordinates
|
|
|
|
// relative to the root cell of the item under mouse cursor, if any. If no
|
|
|
|
// cell is found under the cursor, returns false. Otherwise stores the new
|
|
|
|
// coordinates back into @a pos and pointer to the cell under cursor into
|
|
|
|
// @a cell and returns true.
|
|
|
|
bool PhysicalCoordsToCell(wxPoint& pos, wxHtmlCell*& cell) const;
|
|
|
|
|
|
|
|
// The opposite of PhysicalCoordsToCell: converts coordinates relative to
|
|
|
|
// given cell to physical coordinates in the window
|
|
|
|
wxPoint CellCoordsToPhysical(const wxPoint& pos, wxHtmlCell *cell) const;
|
|
|
|
|
2003-06-01 09:35:26 -04:00
|
|
|
private:
|
2003-06-13 18:26:45 -04:00
|
|
|
// this class caches the pre-parsed HTML to speed up display
|
2003-06-01 09:35:26 -04:00
|
|
|
wxHtmlListBoxCache *m_cache;
|
|
|
|
|
|
|
|
// HTML parser we use
|
|
|
|
wxHtmlWinParser *m_htmlParser;
|
2003-06-02 19:02:12 -04:00
|
|
|
|
2004-04-30 18:44:03 -04:00
|
|
|
#if wxUSE_FILESYSTEM
|
|
|
|
// file system used by m_htmlParser
|
|
|
|
wxFileSystem m_filesystem;
|
|
|
|
#endif // wxUSE_FILESYSTEM
|
|
|
|
|
2003-06-13 18:26:45 -04: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;
|
2006-04-13 18:08:28 -04:00
|
|
|
friend class wxHtmlListBoxWinInterface;
|
2003-06-13 18:26:45 -04:00
|
|
|
|
2003-06-02 19:02:12 -04:00
|
|
|
|
|
|
|
DECLARE_EVENT_TABLE()
|
2009-02-08 06:45:59 -05:00
|
|
|
wxDECLARE_NO_COPY_CLASS(wxHtmlListBox);
|
2003-06-01 09:35:26 -04:00
|
|
|
};
|
|
|
|
|
2006-10-22 18:09:16 -04:00
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxSimpleHtmlListBox
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#define wxHLB_DEFAULT_STYLE wxBORDER_SUNKEN
|
|
|
|
#define wxHLB_MULTIPLE wxLB_MULTIPLE
|
|
|
|
|
|
|
|
class WXDLLIMPEXP_HTML wxSimpleHtmlListBox : public wxHtmlListBox,
|
|
|
|
public wxItemContainer
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// wxListbox-compatible constructors
|
|
|
|
// ---------------------------------
|
|
|
|
|
|
|
|
wxSimpleHtmlListBox() { }
|
|
|
|
|
|
|
|
wxSimpleHtmlListBox(wxWindow *parent,
|
|
|
|
wxWindowID id,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
int n = 0, const wxString choices[] = NULL,
|
|
|
|
long style = wxHLB_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
|
|
|
const wxString& name = wxSimpleHtmlListBoxNameStr)
|
|
|
|
{
|
|
|
|
Create(parent, id, pos, size, n, choices, style, validator, name);
|
|
|
|
}
|
|
|
|
|
|
|
|
wxSimpleHtmlListBox(wxWindow *parent,
|
|
|
|
wxWindowID id,
|
|
|
|
const wxPoint& pos,
|
|
|
|
const wxSize& size,
|
|
|
|
const wxArrayString& choices,
|
|
|
|
long style = wxHLB_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
|
|
|
const wxString& name = wxSimpleHtmlListBoxNameStr)
|
|
|
|
{
|
|
|
|
Create(parent, id, pos, size, choices, style, validator, name);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Create(wxWindow *parent, wxWindowID id,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
int n = 0, const wxString choices[] = NULL,
|
|
|
|
long style = wxHLB_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
|
|
|
const wxString& name = wxSimpleHtmlListBoxNameStr);
|
|
|
|
bool Create(wxWindow *parent, wxWindowID id,
|
|
|
|
const wxPoint& pos,
|
|
|
|
const wxSize& size,
|
|
|
|
const wxArrayString& choices,
|
|
|
|
long style = wxHLB_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
|
|
|
const wxString& name = wxSimpleHtmlListBoxNameStr);
|
2006-10-23 03:06:11 -04:00
|
|
|
|
2006-10-22 18:09:16 -04:00
|
|
|
virtual ~wxSimpleHtmlListBox();
|
|
|
|
|
|
|
|
// these must be overloaded otherwise the compiler will complain
|
|
|
|
// about wxItemContainerImmutable::[G|S]etSelection being pure virtuals...
|
|
|
|
void SetSelection(int n)
|
2006-10-23 03:06:11 -04:00
|
|
|
{ wxVListBox::SetSelection(n); }
|
2006-10-22 18:09:16 -04:00
|
|
|
int GetSelection() const
|
|
|
|
{ return wxVListBox::GetSelection(); }
|
|
|
|
|
|
|
|
// see ctrlsub.h for more info about this:
|
|
|
|
wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST
|
|
|
|
|
|
|
|
|
|
|
|
// accessing strings
|
|
|
|
// -----------------
|
|
|
|
|
|
|
|
virtual unsigned int GetCount() const
|
|
|
|
{ return m_items.GetCount(); }
|
|
|
|
|
|
|
|
virtual wxString GetString(unsigned int n) const;
|
|
|
|
|
|
|
|
// override default unoptimized wxItemContainer::GetStrings() function
|
|
|
|
wxArrayString GetStrings() const
|
|
|
|
{ return m_items; }
|
|
|
|
|
|
|
|
virtual void SetString(unsigned int n, const wxString& s);
|
|
|
|
|
2008-01-08 14:24:08 -05:00
|
|
|
// resolve ambiguity between wxItemContainer and wxVListBox versions
|
|
|
|
void Clear();
|
2006-10-22 18:09:16 -04:00
|
|
|
|
|
|
|
protected:
|
2007-07-26 09:54:14 -04:00
|
|
|
virtual int DoInsertItems(const wxArrayStringsAdapter & items,
|
|
|
|
unsigned int pos,
|
|
|
|
void **clientData, wxClientDataType type);
|
2006-10-22 18:09:16 -04:00
|
|
|
|
|
|
|
virtual void DoSetItemClientData(unsigned int n, void *clientData)
|
2006-10-29 18:57:13 -05:00
|
|
|
{ m_HTMLclientData[n] = clientData; }
|
2006-10-22 18:09:16 -04:00
|
|
|
|
|
|
|
virtual void *DoGetItemClientData(unsigned int n) const
|
2006-10-29 18:57:13 -05:00
|
|
|
{ return m_HTMLclientData[n]; }
|
2006-10-22 18:09:16 -04:00
|
|
|
|
2008-01-08 14:24:08 -05:00
|
|
|
// wxItemContainer methods
|
|
|
|
virtual void DoClear();
|
|
|
|
virtual void DoDeleteOneItem(unsigned int n);
|
|
|
|
|
2006-10-22 18:09:16 -04:00
|
|
|
// calls wxHtmlListBox::SetItemCount() and RefreshAll()
|
|
|
|
void UpdateCount();
|
|
|
|
|
2008-01-08 14:24:08 -05:00
|
|
|
// override these functions just to change their visibility: users of
|
2006-10-22 18:09:16 -04:00
|
|
|
// wxSimpleHtmlListBox shouldn't be allowed to call them directly!
|
|
|
|
virtual void SetItemCount(size_t count)
|
2006-10-23 03:06:11 -04:00
|
|
|
{ wxHtmlListBox::SetItemCount(count); }
|
2007-04-07 21:58:16 -04:00
|
|
|
virtual void SetRowCount(size_t count)
|
|
|
|
{ wxHtmlListBox::SetRowCount(count); }
|
2006-10-22 18:09:16 -04:00
|
|
|
|
|
|
|
virtual wxString OnGetItem(size_t n) const
|
|
|
|
{ return m_items[n]; }
|
|
|
|
|
2008-12-29 11:06:53 -05:00
|
|
|
virtual void InitEvent(wxCommandEvent& event, int n)
|
|
|
|
{
|
|
|
|
// we're not a virtual control and we can include the string
|
|
|
|
// of the item which was clicked:
|
|
|
|
event.SetString(m_items[n]);
|
|
|
|
wxVListBox::InitEvent(event, n);
|
|
|
|
}
|
|
|
|
|
2006-12-04 03:26:24 -05:00
|
|
|
wxArrayString m_items;
|
|
|
|
wxArrayPtrVoid m_HTMLclientData;
|
|
|
|
|
2006-10-29 18:57:13 -05:00
|
|
|
// Note: For the benefit of old compilers (like gcc-2.8) this should
|
|
|
|
// not be named m_clientdata as that clashes with the name of an
|
|
|
|
// anonymous struct member in wxEvtHandler, which we derive from.
|
2006-10-22 18:09:16 -04:00
|
|
|
|
2009-02-08 06:45:59 -05:00
|
|
|
wxDECLARE_NO_COPY_CLASS(wxSimpleHtmlListBox);
|
2006-10-22 18:09:16 -04:00
|
|
|
};
|
|
|
|
|
2003-06-01 09:35:26 -04:00
|
|
|
#endif // _WX_HTMLLBOX_H_
|
|
|
|
|