git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@54318
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
void MakeChangedEvent(wxBookCtrlBaseEvent &event);
wxBookCtrlBaseEvent* CreatePageChangingEvent() const;
void MakeChangedEvent(wxBookCtrlBaseEvent &event);
+ // get flags for different list control modes
+ long GetListCtrlIconViewFlags() const;
+ long GetListCtrlReportViewFlags() const;
+
// event handlers
void OnListSelected(wxListEvent& event);
void OnSize(wxSizeEvent& event);
// event handlers
void OnListSelected(wxListEvent& event);
void OnSize(wxSizeEvent& event);
#include "wx/statline.h"
#include "wx/imaglist.h"
#include "wx/statline.h"
#include "wx/imaglist.h"
+// FIXME: native OS X wxListCtrl hangs if this code is used for it so disable
+// it for now
+#if !defined(__WXMAC__)
+ #define CAN_USE_REPORT_VIEW
+#endif
+
// ----------------------------------------------------------------------------
// various wxWidgets macros
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// various wxWidgets macros
// ----------------------------------------------------------------------------
wxID_ANY,
wxDefaultPosition,
wxDefaultSize,
wxID_ANY,
wxDefaultPosition,
wxDefaultSize,
- wxLC_SINGLE_SEL | wxLC_REPORT | wxLC_NO_HEADER
+ wxLC_SINGLE_SEL |
+#ifdef CAN_USE_REPORT_VIEW
+ GetListCtrlReportViewFlags()
+#else // !CAN_USE_REPORT_VIEW
+ GetListCtrlIconViewFlags()
+#endif // CAN_USE_REPORT_VIEW/!CAN_USE_REPORT_VIEW
+#ifdef CAN_USE_REPORT_VIEW
GetListView()->InsertColumn(0, wxT("Pages"));
GetListView()->InsertColumn(0, wxT("Pages"));
+#endif // CAN_USE_REPORT_VIEW
#ifdef __WXMSW__
// On XP with themes enabled the GetViewRect used in GetControllerSize() to
#ifdef __WXMSW__
// On XP with themes enabled the GetViewRect used in GetControllerSize() to
+// ----------------------------------------------------------------------------
+// wxListCtrl flags
+// ----------------------------------------------------------------------------
+
+long wxListbook::GetListCtrlIconViewFlags() const
+{
+ return (IsVertical() ? wxLC_ALIGN_LEFT : wxLC_ALIGN_TOP) | wxLC_ICON;
+}
+
+#ifdef CAN_USE_REPORT_VIEW
+
+long wxListbook::GetListCtrlReportViewFlags() const
+{
+ return wxLC_REPORT | wxLC_NO_HEADER;
+}
+
+#endif // CAN_USE_REPORT_VIEW
+
// ----------------------------------------------------------------------------
// wxListbook geometry management
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// wxListbook geometry management
// ----------------------------------------------------------------------------
{
wxListView * const list = GetListView();
{
wxListView * const list = GetListView();
+#ifdef CAN_USE_REPORT_VIEW
// If imageList presence has changed, we update the list control view
if ( (imageList != NULL) != (GetImageList() != NULL) )
{
// If imageList presence has changed, we update the list control view
if ( (imageList != NULL) != (GetImageList() != NULL) )
{
long style = wxLC_SINGLE_SEL;
if ( imageList )
{
long style = wxLC_SINGLE_SEL;
if ( imageList )
{
- list->SetWindowStyleFlag(style |
- (IsVertical() ? wxLC_ALIGN_LEFT
- : wxLC_ALIGN_TOP) |
- wxLC_ICON);
+ style |= GetListCtrlIconViewFlags();
}
else // no image list
{
}
else // no image list
{
- list->SetWindowStyleFlag(style | wxLC_REPORT | wxLC_NO_HEADER);
- list->InsertColumn(0, wxT("Pages"));
+ style |= GetListCtrlReportViewFlags();
+ list->SetWindowStyleFlag(style);
+ if ( !imageList )
+ list->InsertColumn(0, wxT("Pages"));
+
// Add back the list control items
for ( i = 0; i < GetPageCount(); i++ )
{
// Add back the list control items
for ( i = 0; i < GetPageCount(); i++ )
{
}
list->SetImageList(imageList, wxIMAGE_LIST_NORMAL);
}
list->SetImageList(imageList, wxIMAGE_LIST_NORMAL);
+#endif // CAN_USE_REPORT_VIEW
wxBookCtrlBase::SetImageList(imageList);
}
wxBookCtrlBase::SetImageList(imageList);
}