1 ///////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxHtmlListBox is a listbox whose items are wxHtmlCells
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
9 // Licence: wxWindows licence
10 ///////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_HTMLLBOX_H_
13 #define _WX_HTMLLBOX_H_
15 #include "wx/vlbox.h" // base class
16 #include "wx/html/htmlwin.h"
17 #include "wx/ctrlsub.h"
20 #include "wx/filesys.h"
21 #endif // wxUSE_FILESYSTEM
23 class WXDLLIMPEXP_FWD_HTML wxHtmlCell
;
24 class WXDLLIMPEXP_FWD_HTML wxHtmlWinParser
;
25 class WXDLLIMPEXP_FWD_HTML wxHtmlListBoxCache
;
26 class WXDLLIMPEXP_FWD_HTML wxHtmlListBoxStyle
;
28 extern WXDLLIMPEXP_DATA_HTML(const wxChar
) wxHtmlListBoxNameStr
[];
29 extern WXDLLIMPEXP_DATA_HTML(const wxChar
) wxSimpleHtmlListBoxNameStr
[];
31 // ----------------------------------------------------------------------------
33 // ----------------------------------------------------------------------------
35 class WXDLLIMPEXP_HTML wxHtmlListBox
: public wxVListBox
,
36 public wxHtmlWindowInterface
,
37 public wxHtmlWindowMouseHelper
39 DECLARE_ABSTRACT_CLASS(wxHtmlListBox
)
41 // constructors and such
42 // ---------------------
44 // default constructor, you must call Create() later
47 // normal constructor which calls Create() internally
48 wxHtmlListBox(wxWindow
*parent
,
49 wxWindowID id
= wxID_ANY
,
50 const wxPoint
& pos
= wxDefaultPosition
,
51 const wxSize
& size
= wxDefaultSize
,
53 const wxString
& name
= wxHtmlListBoxNameStr
);
55 // really creates the control and sets the initial number of items in it
56 // (which may be changed later with SetItemCount())
58 // the only special style which may be specified here is wxLB_MULTIPLE
60 // returns true on success or false if the control couldn't be created
61 bool Create(wxWindow
*parent
,
62 wxWindowID id
= wxID_ANY
,
63 const wxPoint
& pos
= wxDefaultPosition
,
64 const wxSize
& size
= wxDefaultSize
,
66 const wxString
& name
= wxHtmlListBoxNameStr
);
68 // destructor cleans up whatever resources we use
69 virtual ~wxHtmlListBox();
71 // override some base class virtuals
72 virtual void RefreshRow(size_t line
);
73 virtual void RefreshRows(size_t from
, size_t to
);
74 virtual void RefreshAll();
75 virtual void SetItemCount(size_t count
);
78 // retrieve the file system used by the wxHtmlWinParser: if you use
79 // relative paths in your HTML, you should use its ChangePathTo() method
80 wxFileSystem
& GetFileSystem() { return m_filesystem
; }
81 const wxFileSystem
& GetFileSystem() const { return m_filesystem
; }
82 #endif // wxUSE_FILESYSTEM
84 virtual void OnInternalIdle();
87 // this method must be implemented in the derived class and should return
88 // the body (i.e. without <html>) of the HTML for the given item
89 virtual wxString
OnGetItem(size_t n
) const = 0;
91 // this function may be overridden to decorate HTML returned by OnGetItem()
92 virtual wxString
OnGetItemMarkup(size_t n
) const;
95 // this method allows to customize the selection appearance: it may be used
96 // to specify the colour of the text which normally has the given colour
97 // colFg when it is inside the selection
99 // by default, the original colour is not used at all and all text has the
100 // same (default for this system) colour inside selection
101 virtual wxColour
GetSelectedTextColour(const wxColour
& colFg
) const;
103 // this is the same as GetSelectedTextColour() but allows to customize the
104 // background colour -- this is even more rarely used as you can change it
105 // globally using SetSelectionBackground()
106 virtual wxColour
GetSelectedTextBgColour(const wxColour
& colBg
) const;
109 // we implement both of these functions in terms of OnGetItem(), they are
110 // not supposed to be overridden by our descendants
111 virtual void OnDrawItem(wxDC
& dc
, const wxRect
& rect
, size_t n
) const;
112 virtual wxCoord
OnMeasureItem(size_t n
) const;
114 // This method may be overriden to handle clicking on a link in
115 // the listbox. By default, clicking links is ignored.
116 virtual void OnLinkClicked(size_t n
, const wxHtmlLinkInfo
& link
);
119 void OnSize(wxSizeEvent
& event
);
120 void OnMouseMove(wxMouseEvent
& event
);
121 void OnLeftDown(wxMouseEvent
& event
);
124 // common part of all ctors
127 // ensure that the given item is cached
128 void CacheItem(size_t n
) const;
131 // wxHtmlWindowInterface methods:
132 virtual void SetHTMLWindowTitle(const wxString
& title
);
133 virtual void OnHTMLLinkClicked(const wxHtmlLinkInfo
& link
);
134 virtual wxHtmlOpeningStatus
OnHTMLOpeningURL(wxHtmlURLType type
,
136 wxString
*redirect
) const;
137 virtual wxPoint
HTMLCoordsToWindow(wxHtmlCell
*cell
,
138 const wxPoint
& pos
) const;
139 virtual wxWindow
* GetHTMLWindow();
140 virtual wxColour
GetHTMLBackgroundColour() const;
141 virtual void SetHTMLBackgroundColour(const wxColour
& clr
);
142 virtual void SetHTMLBackgroundImage(const wxBitmap
& bmpBg
);
143 virtual void SetHTMLStatusText(const wxString
& text
);
144 virtual wxCursor
GetHTMLCursor(HTMLCursor type
) const;
146 // returns index of item that contains given HTML cell
147 size_t GetItemForCell(const wxHtmlCell
*cell
) const;
149 // return physical coordinates of root wxHtmlCell of n-th item
150 wxPoint
GetRootCellCoords(size_t n
) const;
152 // Converts physical coordinates stored in @a pos into coordinates
153 // relative to the root cell of the item under mouse cursor, if any. If no
154 // cell is found under the cursor, returns false. Otherwise stores the new
155 // coordinates back into @a pos and pointer to the cell under cursor into
156 // @a cell and returns true.
157 bool PhysicalCoordsToCell(wxPoint
& pos
, wxHtmlCell
*& cell
) const;
159 // The opposite of PhysicalCoordsToCell: converts coordinates relative to
160 // given cell to physical coordinates in the window
161 wxPoint
CellCoordsToPhysical(const wxPoint
& pos
, wxHtmlCell
*cell
) const;
164 // this class caches the pre-parsed HTML to speed up display
165 wxHtmlListBoxCache
*m_cache
;
167 // HTML parser we use
168 wxHtmlWinParser
*m_htmlParser
;
171 // file system used by m_htmlParser
172 wxFileSystem m_filesystem
;
173 #endif // wxUSE_FILESYSTEM
175 // rendering style for the parser which allows us to customize our colours
176 wxHtmlListBoxStyle
*m_htmlRendStyle
;
179 // it calls our GetSelectedTextColour() and GetSelectedTextBgColour()
180 friend class wxHtmlListBoxStyle
;
181 friend class wxHtmlListBoxWinInterface
;
184 DECLARE_EVENT_TABLE()
185 DECLARE_NO_COPY_CLASS(wxHtmlListBox
)
189 // ----------------------------------------------------------------------------
190 // wxSimpleHtmlListBox
191 // ----------------------------------------------------------------------------
193 #define wxHLB_DEFAULT_STYLE wxBORDER_SUNKEN
194 #define wxHLB_MULTIPLE wxLB_MULTIPLE
196 class WXDLLIMPEXP_HTML wxSimpleHtmlListBox
: public wxHtmlListBox
,
197 public wxItemContainer
200 // wxListbox-compatible constructors
201 // ---------------------------------
203 wxSimpleHtmlListBox() { }
205 wxSimpleHtmlListBox(wxWindow
*parent
,
207 const wxPoint
& pos
= wxDefaultPosition
,
208 const wxSize
& size
= wxDefaultSize
,
209 int n
= 0, const wxString choices
[] = NULL
,
210 long style
= wxHLB_DEFAULT_STYLE
,
211 const wxValidator
& validator
= wxDefaultValidator
,
212 const wxString
& name
= wxSimpleHtmlListBoxNameStr
)
214 Create(parent
, id
, pos
, size
, n
, choices
, style
, validator
, name
);
217 wxSimpleHtmlListBox(wxWindow
*parent
,
221 const wxArrayString
& choices
,
222 long style
= wxHLB_DEFAULT_STYLE
,
223 const wxValidator
& validator
= wxDefaultValidator
,
224 const wxString
& name
= wxSimpleHtmlListBoxNameStr
)
226 Create(parent
, id
, pos
, size
, choices
, style
, validator
, name
);
229 bool Create(wxWindow
*parent
, wxWindowID id
,
230 const wxPoint
& pos
= wxDefaultPosition
,
231 const wxSize
& size
= wxDefaultSize
,
232 int n
= 0, const wxString choices
[] = NULL
,
233 long style
= wxHLB_DEFAULT_STYLE
,
234 const wxValidator
& validator
= wxDefaultValidator
,
235 const wxString
& name
= wxSimpleHtmlListBoxNameStr
);
236 bool Create(wxWindow
*parent
, wxWindowID id
,
239 const wxArrayString
& choices
,
240 long style
= wxHLB_DEFAULT_STYLE
,
241 const wxValidator
& validator
= wxDefaultValidator
,
242 const wxString
& name
= wxSimpleHtmlListBoxNameStr
);
244 virtual ~wxSimpleHtmlListBox();
246 // these must be overloaded otherwise the compiler will complain
247 // about wxItemContainerImmutable::[G|S]etSelection being pure virtuals...
248 void SetSelection(int n
)
249 { wxVListBox::SetSelection(n
); }
250 int GetSelection() const
251 { return wxVListBox::GetSelection(); }
253 // see ctrlsub.h for more info about this:
254 wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST
260 virtual unsigned int GetCount() const
261 { return m_items
.GetCount(); }
263 virtual wxString
GetString(unsigned int n
) const;
265 // override default unoptimized wxItemContainer::GetStrings() function
266 wxArrayString
GetStrings() const
269 virtual void SetString(unsigned int n
, const wxString
& s
);
271 virtual void Clear();
272 virtual void Delete(unsigned int n
);
274 // override default unoptimized wxItemContainer::Append() function
275 void Append(const wxArrayString
& strings
);
277 // since we override one Append() overload, we need to overload all others too
278 int Append(const wxString
& item
)
279 { return wxItemContainer::Append(item
); }
280 int Append(const wxString
& item
, void *clientData
)
281 { return wxItemContainer::Append(item
, clientData
); }
282 int Append(const wxString
& item
, wxClientData
*clientData
)
283 { return wxItemContainer::Append(item
, clientData
); }
288 virtual int DoAppend(const wxString
& item
);
289 virtual int DoInsert(const wxString
& item
, unsigned int pos
);
291 virtual void DoSetItemClientData(unsigned int n
, void *clientData
)
292 { m_HTMLclientData
[n
] = clientData
; }
294 virtual void *DoGetItemClientData(unsigned int n
) const
295 { return m_HTMLclientData
[n
]; }
296 virtual void DoSetItemClientObject(unsigned int n
, wxClientData
*clientData
)
297 { m_HTMLclientData
[n
] = (void *)clientData
; }
298 virtual wxClientData
*DoGetItemClientObject(unsigned int n
) const
299 { return (wxClientData
*)m_HTMLclientData
[n
]; }
301 // calls wxHtmlListBox::SetItemCount() and RefreshAll()
304 // overload these functions just to change their visibility: users of
305 // wxSimpleHtmlListBox shouldn't be allowed to call them directly!
306 virtual void SetItemCount(size_t count
)
307 { wxHtmlListBox::SetItemCount(count
); }
308 virtual void SetRowCount(size_t count
)
309 { wxHtmlListBox::SetRowCount(count
); }
311 virtual wxString
OnGetItem(size_t n
) const
312 { return m_items
[n
]; }
314 wxArrayString m_items
;
315 wxArrayPtrVoid m_HTMLclientData
;
317 // Note: For the benefit of old compilers (like gcc-2.8) this should
318 // not be named m_clientdata as that clashes with the name of an
319 // anonymous struct member in wxEvtHandler, which we derive from.
321 DECLARE_NO_COPY_CLASS(wxSimpleHtmlListBox
)
324 #endif // _WX_HTMLLBOX_H_