1 ///////////////////////////////////////////////////////////////////////////////
2 // Name: src/generic/choicbkg.cpp
3 // Purpose: generic implementation of wxChoicebook
4 // Author: Vadim Zeitlin
5 // Modified by: Wlodzimierz ABX Skiba from generic/listbkg.cpp
8 // Copyright: (c) Vadim Zeitlin, Wlodzimierz Skiba
9 // Licence: wxWindows licence
10 ///////////////////////////////////////////////////////////////////////////////
12 // ============================================================================
14 // ============================================================================
16 // ----------------------------------------------------------------------------
18 // ----------------------------------------------------------------------------
20 // For compilers that support precompilation, includes "wx.h".
21 #include "wx/wxprec.h"
29 #include "wx/choicebk.h"
32 #include "wx/settings.h"
33 #include "wx/choice.h"
37 #include "wx/imaglist.h"
39 // ----------------------------------------------------------------------------
40 // various wxWidgets macros
41 // ----------------------------------------------------------------------------
43 // check that the page index is valid
44 #define IS_VALID_PAGE(nPage) ((nPage) < GetPageCount())
46 // ----------------------------------------------------------------------------
48 // ----------------------------------------------------------------------------
50 IMPLEMENT_DYNAMIC_CLASS(wxChoicebook
, wxBookCtrlBase
)
52 wxDEFINE_EVENT( wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING
, wxBookCtrlEvent
);
53 wxDEFINE_EVENT( wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED
, wxBookCtrlEvent
);
55 BEGIN_EVENT_TABLE(wxChoicebook
, wxBookCtrlBase
)
56 EVT_CHOICE(wxID_ANY
, wxChoicebook
::OnChoiceSelected
)
59 // ============================================================================
60 // wxChoicebook implementation
61 // ============================================================================
63 // ----------------------------------------------------------------------------
64 // wxChoicebook creation
65 // ----------------------------------------------------------------------------
67 void wxChoicebook
::Init()
69 m_selection
= wxNOT_FOUND
;
73 wxChoicebook
::Create(wxWindow
*parent
,
80 if ( (style
& wxBK_ALIGN_MASK
) == wxBK_DEFAULT
)
85 // no border for this control, it doesn't look nice together with
87 style
&= ~wxBORDER_MASK
;
88 style
|= wxBORDER_NONE
;
90 if ( !wxControl
::Create(parent
, id
, pos
, size
, style
,
91 wxDefaultValidator
, name
) )
94 m_bookctrl
= new wxChoice
102 wxSizer
* mainSizer
= new wxBoxSizer(IsVertical() ? wxVERTICAL
: wxHORIZONTAL
);
104 if (style
& wxBK_RIGHT
|| style
& wxBK_BOTTOM
)
105 mainSizer
->Add(0, 0, 1, wxEXPAND
, 0);
107 m_controlSizer
= new wxBoxSizer(IsVertical() ? wxHORIZONTAL
: wxVERTICAL
);
108 m_controlSizer
->Add(m_bookctrl
, 1, (IsVertical() ? wxALIGN_CENTRE_VERTICAL
: wxALIGN_CENTRE
) |wxGROW
, 0);
109 mainSizer
->Add(m_controlSizer
, 0, (IsVertical() ?
(int) wxGROW
: (int) wxALIGN_CENTRE_VERTICAL
)|wxALL
, m_controlMargin
);
114 // ----------------------------------------------------------------------------
115 // wxChoicebook geometry management
116 // ----------------------------------------------------------------------------
118 wxSize wxChoicebook
::CalcSizeFromPage(const wxSize
& sizePage
) const
120 // we need to add the size of the choice control and the border between
121 const wxSize sizeChoice
= GetControllerSize();
123 wxSize size
= sizePage
;
126 if ( sizeChoice
.x
> sizePage
.x
)
127 size
.x
= sizeChoice
.x
;
128 size
.y
+= sizeChoice
.y
+ GetInternalBorder();
130 else // left/right aligned
132 size
.x
+= sizeChoice
.x
+ GetInternalBorder();
133 if ( sizeChoice
.y
> sizePage
.y
)
134 size
.y
= sizeChoice
.y
;
141 // ----------------------------------------------------------------------------
142 // accessing the pages
143 // ----------------------------------------------------------------------------
145 bool wxChoicebook
::SetPageText(size_t n
, const wxString
& strText
)
147 GetChoiceCtrl()->SetString(n
, strText
);
152 wxString wxChoicebook
::GetPageText(size_t n
) const
154 return GetChoiceCtrl()->GetString(n
);
157 int wxChoicebook
::GetPageImage(size_t WXUNUSED(n
)) const
162 bool wxChoicebook
::SetPageImage(size_t WXUNUSED(n
), int WXUNUSED(imageId
))
164 // fail silently, the code may be written to use one of several book
165 // classes and call SetPageImage() unconditionally, it's better to just
166 // ignore it (which is the best we can do short of rewriting this class to
167 // use wxBitmapComboBox anyhow) than complain loudly about a rather
173 // ----------------------------------------------------------------------------
174 // miscellaneous other stuff
175 // ----------------------------------------------------------------------------
177 void wxChoicebook
::DoSetWindowVariant(wxWindowVariant variant
)
179 wxBookCtrlBase
::DoSetWindowVariant(variant
);
181 m_bookctrl
->SetWindowVariant(variant
);
184 void wxChoicebook
::SetImageList(wxImageList
*imageList
)
186 // TODO: can be implemented in form of static bitmap near choice control
188 wxBookCtrlBase
::SetImageList(imageList
);
191 // ----------------------------------------------------------------------------
193 // ----------------------------------------------------------------------------
195 int wxChoicebook
::GetSelection() const
200 wxBookCtrlEvent
* wxChoicebook
::CreatePageChangingEvent() const
202 return new wxBookCtrlEvent(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGING
, m_windowId
);
205 void wxChoicebook
::MakeChangedEvent(wxBookCtrlEvent
&event
)
207 event
.SetEventType(wxEVT_COMMAND_CHOICEBOOK_PAGE_CHANGED
);
210 // ----------------------------------------------------------------------------
211 // adding/removing the pages
212 // ----------------------------------------------------------------------------
215 wxChoicebook
::InsertPage(size_t n
,
217 const wxString
& text
,
221 if ( !wxBookCtrlBase
::InsertPage(n
, page
, text
, bSelect
, imageId
) )
224 GetChoiceCtrl()->Insert(text
, n
);
226 // if the inserted page is before the selected one, we must update the
227 // index of the selected page
228 if ( int(n
) <= m_selection
)
230 // one extra page added
232 GetChoiceCtrl()->Select(m_selection
);
235 // some page should be selected: either this one or the first one if there
236 // is still no selection
237 int selNew
= wxNOT_FOUND
;
240 else if ( m_selection
== wxNOT_FOUND
)
243 if ( selNew
!= m_selection
)
246 if ( selNew
!= wxNOT_FOUND
)
247 SetSelection(selNew
);
252 wxWindow
*wxChoicebook
::DoRemovePage(size_t page
)
254 wxWindow
*win
= wxBookCtrlBase
::DoRemovePage(page
);
258 GetChoiceCtrl()->Delete(page
);
260 if ( m_selection
>= (int)page
)
262 // ensure that the selection is valid
264 if ( GetPageCount() == 0 )
267 sel
= m_selection ? m_selection
- 1 : 0;
269 // if deleting current page we shouldn't try to hide it
270 m_selection
= m_selection
== (int)page ? wxNOT_FOUND
273 if ( sel
!= wxNOT_FOUND
&& sel
!= m_selection
)
282 bool wxChoicebook
::DeleteAllPages()
284 m_selection
= wxNOT_FOUND
;
285 GetChoiceCtrl()->Clear();
286 return wxBookCtrlBase
::DeleteAllPages();
289 // ----------------------------------------------------------------------------
290 // wxChoicebook events
291 // ----------------------------------------------------------------------------
293 void wxChoicebook
::OnChoiceSelected(wxCommandEvent
& eventChoice
)
295 if ( eventChoice
.GetEventObject() != m_bookctrl
)
301 const int selNew
= eventChoice
.GetSelection();
303 if ( selNew
== m_selection
)
305 // this event can only come from our own Select(m_selection) below
306 // which we call when the page change is vetoed, so we should simply
311 SetSelection(selNew
);
313 // change wasn't allowed, return to previous state
314 if (m_selection
!= selNew
)
315 GetChoiceCtrl()->Select(m_selection
);
318 #endif // wxUSE_CHOICEBOOK