]> git.saurik.com Git - wxWidgets.git/blame - src/generic/choicbkg.cpp
fix memory leak while testing for correct Clone() implementation (closes #10304)
[wxWidgets.git] / src / generic / choicbkg.cpp
CommitLineData
f5e0b4bc 1///////////////////////////////////////////////////////////////////////////////
2ddb4d13 2// Name: src/generic/choicbkg.cpp
f5e0b4bc
WS
3// Purpose: generic implementation of wxChoicebook
4// Author: Vadim Zeitlin
5// Modified by: Wlodzimierz ABX Skiba from generic/listbkg.cpp
6// Created: 15.09.04
7// RCS-ID: $Id$
8// Copyright: (c) Vadim Zeitlin, Wlodzimierz Skiba
9// Licence: wxWindows licence
10///////////////////////////////////////////////////////////////////////////////
11
12// ============================================================================
13// declarations
14// ============================================================================
15
16// ----------------------------------------------------------------------------
17// headers
18// ----------------------------------------------------------------------------
19
f5e0b4bc
WS
20// For compilers that support precompilation, includes "wx.h".
21#include "wx/wxprec.h"
22
23#ifdef __BORLANDC__
24 #pragma hdrstop
25#endif
26
27#if wxUSE_CHOICEBOOK
28
f5e0b4bc 29#include "wx/choicebk.h"
9eddec69
WS
30
31#ifndef WX_PRECOMP
32 #include "wx/settings.h"
b36e08d0 33 #include "wx/choice.h"
ed2fbeb8 34 #include "wx/sizer.h"
9eddec69
WS
35#endif
36
f5e0b4bc 37#include "wx/imaglist.h"
f5e0b4bc 38
f5e0b4bc
WS
39// ----------------------------------------------------------------------------
40// various wxWidgets macros
41// ----------------------------------------------------------------------------
42
1f30c176
WS
43// check that the page index is valid
44#define IS_VALID_PAGE(nPage) ((nPage) < GetPageCount())
45
46// ----------------------------------------------------------------------------
47// event table
48// ----------------------------------------------------------------------------
49
2ddb4d13 50IMPLEMENT_DYNAMIC_CLASS(wxChoicebook, wxBookCtrlBase)
f5e0b4bc
WS
51
52const wxEventType wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING = wxNewEventType();
53const wxEventType wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED = wxNewEventType();
f5e0b4bc 54
61c083e7 55BEGIN_EVENT_TABLE(wxChoicebook, wxBookCtrlBase)
447325a4 56 EVT_CHOICE(wxID_ANY, wxChoicebook::OnChoiceSelected)
f5e0b4bc
WS
57END_EVENT_TABLE()
58
59// ============================================================================
60// wxChoicebook implementation
61// ============================================================================
62
63// ----------------------------------------------------------------------------
64// wxChoicebook creation
65// ----------------------------------------------------------------------------
66
67void wxChoicebook::Init()
68{
f5e0b4bc
WS
69 m_selection = wxNOT_FOUND;
70}
71
72bool
73wxChoicebook::Create(wxWindow *parent,
74 wxWindowID id,
75 const wxPoint& pos,
76 const wxSize& size,
77 long style,
78 const wxString& name)
79{
2ddb4d13 80 if ( (style & wxBK_ALIGN_MASK) == wxBK_DEFAULT )
f5e0b4bc 81 {
2ddb4d13 82 style |= wxBK_TOP;
f5e0b4bc
WS
83 }
84
85 // no border for this control, it doesn't look nice together with
86 // wxChoice border
87 style &= ~wxBORDER_MASK;
88 style |= wxBORDER_NONE;
89
90 if ( !wxControl::Create(parent, id, pos, size, style,
91 wxDefaultValidator, name) )
92 return false;
93
2ddb4d13 94 m_bookctrl = new wxChoice
f5e0b4bc
WS
95 (
96 this,
447325a4 97 wxID_ANY,
f5e0b4bc
WS
98 wxDefaultPosition,
99 wxDefaultSize
100 );
101
87cf52d8 102 wxSizer* mainSizer = new wxBoxSizer(IsVertical() ? wxVERTICAL : wxHORIZONTAL);
e0d5d9af
WS
103
104 if (style & wxBK_RIGHT || style & wxBK_BOTTOM)
87cf52d8 105 mainSizer->Add(0, 0, 1, wxEXPAND, 0);
e0d5d9af 106
87cf52d8
JS
107 m_controlSizer = new wxBoxSizer(IsVertical() ? wxHORIZONTAL : wxVERTICAL);
108 m_controlSizer->Add(m_bookctrl, 1, (IsVertical() ? wxALIGN_CENTRE_VERTICAL : wxALIGN_CENTRE) |wxGROW, 0);
f2b29c64 109 mainSizer->Add(m_controlSizer, 0, (IsVertical() ? (int) wxGROW : (int) wxALIGN_CENTRE_VERTICAL)|wxALL, m_controlMargin);
87cf52d8 110 SetSizer(mainSizer);
f5e0b4bc
WS
111 return true;
112}
113
114// ----------------------------------------------------------------------------
115// wxChoicebook geometry management
116// ----------------------------------------------------------------------------
117
2ddb4d13 118wxSize wxChoicebook::GetControllerSize() const
f5e0b4bc
WS
119{
120 const wxSize sizeClient = GetClientSize(),
87cf52d8 121 sizeChoice = m_controlSizer->CalcMin();
f5e0b4bc
WS
122
123 wxSize size;
124 if ( IsVertical() )
125 {
126 size.x = sizeClient.x;
127 size.y = sizeChoice.y;
128 }
129 else // left/right aligned
130 {
131 size.x = sizeChoice.x;
132 size.y = sizeClient.y;
133 }
134
135 return size;
136}
137
f5e0b4bc
WS
138wxSize wxChoicebook::CalcSizeFromPage(const wxSize& sizePage) const
139{
159e6235 140 // we need to add the size of the choice control and the border between
2ddb4d13 141 const wxSize sizeChoice = GetControllerSize();
f5e0b4bc
WS
142
143 wxSize size = sizePage;
144 if ( IsVertical() )
145 {
159e6235 146 size.y += sizeChoice.y + GetInternalBorder();
f5e0b4bc
WS
147 }
148 else // left/right aligned
149 {
159e6235 150 size.x += sizeChoice.x + GetInternalBorder();
f5e0b4bc
WS
151 }
152
153 return size;
154}
155
156
157// ----------------------------------------------------------------------------
158// accessing the pages
159// ----------------------------------------------------------------------------
160
161bool wxChoicebook::SetPageText(size_t n, const wxString& strText)
162{
2ddb4d13 163 GetChoiceCtrl()->SetString(n, strText);
f5e0b4bc
WS
164
165 return true;
166}
167
168wxString wxChoicebook::GetPageText(size_t n) const
169{
2ddb4d13 170 return GetChoiceCtrl()->GetString(n);
f5e0b4bc
WS
171}
172
173int wxChoicebook::GetPageImage(size_t WXUNUSED(n)) const
174{
175 wxFAIL_MSG( _T("wxChoicebook::GetPageImage() not implemented") );
176
9f29226d 177 return wxNOT_FOUND;
f5e0b4bc
WS
178}
179
180bool wxChoicebook::SetPageImage(size_t WXUNUSED(n), int WXUNUSED(imageId))
181{
182 wxFAIL_MSG( _T("wxChoicebook::SetPageImage() not implemented") );
183
184 return false;
185}
186
187// ----------------------------------------------------------------------------
188// image list stuff
189// ----------------------------------------------------------------------------
190
191void wxChoicebook::SetImageList(wxImageList *imageList)
192{
193 // TODO: can be implemented in form of static bitmap near choice control
194
61c083e7 195 wxBookCtrlBase::SetImageList(imageList);
f5e0b4bc
WS
196}
197
198// ----------------------------------------------------------------------------
199// selection
200// ----------------------------------------------------------------------------
201
202int wxChoicebook::GetSelection() const
203{
204 return m_selection;
205}
206
3e97a905 207wxBookCtrlEvent* wxChoicebook::CreatePageChangingEvent() const
f5e0b4bc 208{
3e97a905 209 return new wxBookCtrlEvent(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING, m_windowId);
deb325e3
VZ
210}
211
3e97a905 212void wxChoicebook::MakeChangedEvent(wxBookCtrlEvent &event)
deb325e3
VZ
213{
214 event.SetEventType(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED);
f5e0b4bc
WS
215}
216
f5e0b4bc
WS
217// ----------------------------------------------------------------------------
218// adding/removing the pages
219// ----------------------------------------------------------------------------
220
221bool
222wxChoicebook::InsertPage(size_t n,
223 wxWindow *page,
224 const wxString& text,
225 bool bSelect,
226 int imageId)
227{
61c083e7 228 if ( !wxBookCtrlBase::InsertPage(n, page, text, bSelect, imageId) )
f5e0b4bc
WS
229 return false;
230
2ddb4d13 231 GetChoiceCtrl()->Insert(text, n);
f5e0b4bc 232
716dc245
WS
233 // if the inserted page is before the selected one, we must update the
234 // index of the selected page
235 if ( int(n) <= m_selection )
f5e0b4bc 236 {
716dc245
WS
237 // one extra page added
238 m_selection++;
2ddb4d13 239 GetChoiceCtrl()->Select(m_selection);
f5e0b4bc 240 }
716dc245
WS
241
242 // some page should be selected: either this one or the first one if there
243 // is still no selection
159e6235 244 int selNew = wxNOT_FOUND;
716dc245
WS
245 if ( bSelect )
246 selNew = n;
159e6235 247 else if ( m_selection == wxNOT_FOUND )
716dc245
WS
248 selNew = 0;
249
250 if ( selNew != m_selection )
f5e0b4bc 251 page->Hide();
716dc245 252
159e6235 253 if ( selNew != wxNOT_FOUND )
716dc245 254 SetSelection(selNew);
f5e0b4bc 255
f5e0b4bc
WS
256 return true;
257}
258
259wxWindow *wxChoicebook::DoRemovePage(size_t page)
260{
61c083e7 261 wxWindow *win = wxBookCtrlBase::DoRemovePage(page);
bb08a4a1 262
f5e0b4bc
WS
263 if ( win )
264 {
2ddb4d13 265 GetChoiceCtrl()->Delete(page);
bb08a4a1 266
4922c5f0 267 if ( m_selection >= (int)page )
bb08a4a1 268 {
4922c5f0
VZ
269 // ensure that the selection is valid
270 int sel;
271 if ( GetPageCount() == 0 )
bb08a4a1 272 sel = wxNOT_FOUND;
4922c5f0
VZ
273 else
274 sel = m_selection ? m_selection - 1 : 0;
bb08a4a1 275
4922c5f0
VZ
276 // if deleting current page we shouldn't try to hide it
277 m_selection = m_selection == (int)page ? wxNOT_FOUND
278 : m_selection - 1;
bb08a4a1 279
4922c5f0 280 if ( sel != wxNOT_FOUND && sel != m_selection )
bb08a4a1 281 SetSelection(sel);
4922c5f0 282 }
f5e0b4bc
WS
283 }
284
285 return win;
286}
287
288
289bool wxChoicebook::DeleteAllPages()
290{
4922c5f0 291 m_selection = wxNOT_FOUND;
2ddb4d13 292 GetChoiceCtrl()->Clear();
61c083e7 293 return wxBookCtrlBase::DeleteAllPages();
f5e0b4bc
WS
294}
295
296// ----------------------------------------------------------------------------
297// wxChoicebook events
298// ----------------------------------------------------------------------------
299
300void wxChoicebook::OnChoiceSelected(wxCommandEvent& eventChoice)
301{
447325a4
VZ
302 if ( eventChoice.GetEventObject() != m_bookctrl )
303 {
304 eventChoice.Skip();
305 return;
306 }
307
f5e0b4bc
WS
308 const int selNew = eventChoice.GetSelection();
309
310 if ( selNew == m_selection )
311 {
312 // this event can only come from our own Select(m_selection) below
313 // which we call when the page change is vetoed, so we should simply
314 // ignore it
315 return;
316 }
317
bb08a4a1 318 SetSelection(selNew);
f5e0b4bc 319
716dc245
WS
320 // change wasn't allowed, return to previous state
321 if (m_selection != selNew)
2ddb4d13 322 GetChoiceCtrl()->Select(m_selection);
f5e0b4bc
WS
323}
324
325#endif // wxUSE_CHOICEBOOK