2008-03-08 08:52:38 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: htmllbox.h
|
2008-03-10 11:24:38 -04:00
|
|
|
// Purpose: interface of wxHtmlListBox
|
2008-03-08 08:52:38 -05:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxHtmlListBox
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
wxHtmlListBox is an implementation of wxVListBox which
|
|
|
|
shows HTML content in the listbox rows. This is still an abstract base class
|
|
|
|
and you will need to derive your own class from it (see htlbox sample for the
|
|
|
|
example) but you will only need to override a single
|
|
|
|
wxHtmlListBox::OnGetItem function.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@library{wxhtml}
|
|
|
|
@category{ctrl}
|
2008-05-02 00:52:42 -04:00
|
|
|
<!-- @appearance{htmllistbox.png} -->
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-10 11:24:38 -04:00
|
|
|
@see wxSimpleHtmlListBox
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
class wxHtmlListBox : public wxVListBox
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Default constructor, you must call Create()
|
|
|
|
later.
|
|
|
|
*/
|
|
|
|
wxHtmlListBox(wxWindow* parent, wxWindowID id = wxID_ANY,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
|
|
|
const wxString& name = wxHtmlListBoxNameStr);
|
2008-03-08 09:43:31 -05:00
|
|
|
wxHtmlListBox();
|
2008-03-08 08:52:38 -05:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor cleans up whatever resources we use.
|
|
|
|
*/
|
|
|
|
~wxHtmlListBox();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates the control and optionally sets the initial number of items in it
|
|
|
|
(it may also be set or changed later with
|
|
|
|
wxVListBox::SetItemCount).
|
|
|
|
There are no special styles defined for wxHtmlListBox, in particular the
|
|
|
|
wxListBox styles (with the exception of @c wxLB_MULTIPLE) can not be used here.
|
|
|
|
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 = wxHtmlListBoxNameStr);
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Returns the wxFileSystem used by the HTML parser of
|
|
|
|
this object. The file system object is used to resolve the paths in HTML
|
|
|
|
fragments displayed in the control and you should use
|
|
|
|
wxFileSystem::ChangePathTo if you use
|
|
|
|
relative paths for the images or other resources embedded in your HTML.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxFileSystem GetFileSystem() const;
|
|
|
|
const wxFileSystem GetFileSystem() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
This virtual function may be overridden to change the appearance of the
|
|
|
|
background of the selected cells in the same way as
|
|
|
|
GetSelectedTextColour().
|
|
|
|
It should be rarely, if ever, used because
|
|
|
|
wxVListBox::SetSelectionBackground allows to
|
|
|
|
change the selection background for all cells at once and doing anything more
|
|
|
|
fancy is probably going to look strangely.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2008-03-09 08:33:59 -04:00
|
|
|
@see GetSelectedTextColour()
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxColour GetSelectedTextBgColour(const wxColour& colBg) const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
This virtual function may be overridden to customize the appearance of the
|
2008-03-09 08:33:59 -04:00
|
|
|
selected cells. It is used to determine how the colour @a colFg is going to
|
2008-03-08 08:52:38 -05:00
|
|
|
look inside selection. By default all original colours are completely ignored
|
|
|
|
and the standard, system-dependent, selection colour is used but the program
|
|
|
|
may wish to override this to achieve some custom appearance.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2008-03-09 08:33:59 -04:00
|
|
|
@see GetSelectedTextBgColour(),
|
|
|
|
wxVListBox::SetSelectionBackground, wxSystemSettings::GetColour
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxColour GetSelectedTextColour(const wxColour& colFg) const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
This method must be implemented in the derived class and should return
|
|
|
|
the body (i.e. without @c html nor @c body tags) of the HTML fragment
|
|
|
|
for the given item.
|
2008-03-09 08:33:59 -04:00
|
|
|
Note that this function should always return a text fragment for the @a n item
|
2008-03-08 08:52:38 -05:00
|
|
|
which renders with the same height both when it is selected and when it's not:
|
|
|
|
i.e. if you call, inside your OnGetItem() implementation, @c IsSelected(n) to
|
|
|
|
make the items appear differently when they are selected, then you should make
|
|
|
|
sure
|
|
|
|
that the returned HTML fragment will render with the same height or else you'll
|
|
|
|
see some artifacts when the user selects an item.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxString OnGetItem(size_t n) const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
This function may be overridden to decorate HTML returned by
|
|
|
|
OnGetItem().
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxString OnGetItemMarkup(size_t n) const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Called when the user clicks on hypertext link. Does nothing by default.
|
|
|
|
Overloading this method is deprecated; intercept the event instead.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2008-03-08 09:43:31 -05:00
|
|
|
@param n
|
2008-03-09 08:33:59 -04:00
|
|
|
Index of the item containing the link.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param link
|
2008-03-09 08:33:59 -04:00
|
|
|
Description of the link.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2008-03-09 08:33:59 -04:00
|
|
|
@see See also wxHtmlLinkInfo.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
virtual void OnLinkClicked(size_t n, const wxHtmlLinkInfo& link);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 11:24:38 -04:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
/**
|
|
|
|
@class wxSimpleHtmlListBox
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
wxSimpleHtmlListBox is an implementation of wxHtmlListBox which
|
|
|
|
shows HTML content in the listbox rows.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
Unlike wxHtmlListBox, this is not an abstract class and thus it
|
|
|
|
has the advantage that you can use it without deriving your own class from it.
|
|
|
|
However, it also has the disadvantage that this is not a virtual control and
|
|
|
|
thus it's not
|
|
|
|
well-suited for those cases where you need to show a huge number of items:
|
|
|
|
every time you
|
|
|
|
add/insert a string, it will be stored internally and thus will take memory.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
The interface exposed by wxSimpleHtmlListBox fully implements the
|
|
|
|
wxControlWithItems interface, thus you should refer to
|
|
|
|
wxControlWithItems's documentation for the API reference
|
|
|
|
for adding/removing/retrieving items in the listbox.
|
|
|
|
Also note that the wxVListBox::SetItemCount function is
|
|
|
|
@c protected in wxSimpleHtmlListBox's context so that you cannot call it
|
|
|
|
directly,
|
|
|
|
wxSimpleHtmlListBox will do it for you.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
Note: in case you need to append a lot of items to the control at once, make
|
|
|
|
sure to use the
|
|
|
|
@ref wxControlWithItems::append "Append(const wxArrayString )" function.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
Thus the only difference between a wxListBox and a wxSimpleHtmlListBox
|
|
|
|
is that the latter stores strings which can contain HTML fragments (see the
|
|
|
|
list of
|
|
|
|
@ref overview_htmltagssupported "tags supported by wxHTML").
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
Note that the HTML strings you fetch to wxSimpleHtmlListBox should not contain
|
2008-03-08 09:43:31 -05:00
|
|
|
the @c html
|
2008-03-08 08:52:38 -05:00
|
|
|
or @c body tags.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@beginStyleTable
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxHLB_DEFAULT_STYLE}
|
2008-03-08 08:52:38 -05:00
|
|
|
The default style: wxBORDER_SUNKEN
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxHLB_MULTIPLE}
|
2008-03-08 08:52:38 -05:00
|
|
|
Multiple-selection list: the user can toggle multiple items on and
|
|
|
|
off.
|
|
|
|
@endStyleTable
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@library{wxhtml}
|
|
|
|
@category{ctrl}
|
2008-05-02 00:52:42 -04:00
|
|
|
<!-- @appearance{simplehtmllistbox.png} -->
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-10 11:24:38 -04:00
|
|
|
@see wxSimpleHtmlListBox::Create
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
class wxSimpleHtmlListBox : public wxHtmlListBox
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Default constructor, you must call Create()
|
|
|
|
later.
|
|
|
|
*/
|
|
|
|
wxHtmlListBox(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
int n = 0,
|
2008-03-09 08:33:59 -04:00
|
|
|
const wxString choices[] = NULL,
|
2008-03-08 08:52:38 -05:00
|
|
|
long style = wxHLB_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
|
|
|
const wxString& name = "simpleHtmlListBox");
|
2008-03-08 09:43:31 -05:00
|
|
|
wxHtmlListBox(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 = "simpleHtmlListBox");
|
|
|
|
See also
|
|
|
|
wxSimpleHtmlListBox::Create
|
|
|
|
|
|
|
|
wxSimpleHtmlListBox();
|
2008-03-08 08:52:38 -05:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Frees the array of stored items and relative client data.
|
|
|
|
*/
|
|
|
|
~wxSimpleHtmlListBox();
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
2008-03-08 09:43:31 -05:00
|
|
|
Creates the HTML listbox for two-step construction.
|
2008-03-08 08:52:38 -05:00
|
|
|
See wxSimpleHtmlListBox() for further details.
|
|
|
|
*/
|
|
|
|
bool Create(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
int n,
|
2008-03-09 08:33:59 -04:00
|
|
|
const wxString choices[] = NULL,
|
2008-03-08 08:52:38 -05:00
|
|
|
long style = wxHLB_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
|
|
|
const wxString& name = "simpleHtmlListBox");
|
2008-03-08 09:43:31 -05:00
|
|
|
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 = "simpleHtmlListBox");
|
2008-03-08 08:52:38 -05:00
|
|
|
//@}
|
|
|
|
};
|
2008-03-10 11:24:38 -04:00
|
|
|
|