1 /////////////////////////////////////////////////////////////////////////////
2 // Name: src/propgrid/manager.cpp
3 // Purpose: wxPropertyGridManager
4 // Author: Jaakko Salli
8 // Copyright: (c) Jaakko Salli
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 // For compilers that support precompilation, includes "wx/wx.h".
13 #include "wx/wxprec.h"
23 #include "wx/object.h"
25 #include "wx/string.h"
28 #include "wx/window.h"
33 #include "wx/cursor.h"
34 #include "wx/settings.h"
35 #include "wx/textctrl.h"
37 #include "wx/statusbr.h"
41 // This define is necessary to prevent macro clearing
42 #define __wxPG_SOURCE_FILE__
44 #include "wx/propgrid/propgrid.h"
46 #include "wx/propgrid/manager.h"
49 #define wxPG_MAN_ALTERNATE_BASE_ID 11249 // Needed for wxID_ANY madnesss
52 // -----------------------------------------------------------------------
54 // For wxMSW cursor consistency, we must do mouse capturing even
55 // when using custom controls
57 #define BEGIN_MOUSE_CAPTURE \
58 if ( !(m_iFlags & wxPG_FL_MOUSE_CAPTURED) ) \
61 m_iFlags |= wxPG_FL_MOUSE_CAPTURED; \
64 #define END_MOUSE_CAPTURE \
65 if ( m_iFlags & wxPG_FL_MOUSE_CAPTURED ) \
68 m_iFlags &= ~(wxPG_FL_MOUSE_CAPTURED); \
71 // -----------------------------------------------------------------------
72 // wxPropertyGridManager
73 // -----------------------------------------------------------------------
75 const char wxPropertyGridManagerNameStr
[] = "wxPropertyGridManager";
78 // Categoric Mode Icon
79 static const char* const gs_xpm_catmode
[] = {
104 // Alphabetic Mode Icon
105 static const char* const gs_xpm_noncatmode
[] = {
130 // Default Page Icon.
131 static const char* const gs_xpm_defpage
[] = {
156 // -----------------------------------------------------------------------
157 // wxPropertyGridPage
158 // -----------------------------------------------------------------------
161 IMPLEMENT_CLASS(wxPropertyGridPage
, wxEvtHandler
)
164 BEGIN_EVENT_TABLE(wxPropertyGridPage
, wxEvtHandler
)
168 wxPropertyGridPage::wxPropertyGridPage()
169 : wxEvtHandler(), wxPropertyGridInterface(), wxPropertyGridPageState()
171 m_pState
= this; // wxPropertyGridInterface to point to State
176 wxPropertyGridPage::~wxPropertyGridPage()
180 void wxPropertyGridPage::Clear()
182 GetStatePtr()->DoClear();
185 wxSize
wxPropertyGridPage::FitColumns()
187 wxSize sz
= DoFitColumns();
191 void wxPropertyGridPage::RefreshProperty( wxPGProperty
* p
)
194 m_manager
->RefreshProperty(p
);
197 void wxPropertyGridPage::OnShow()
201 void wxPropertyGridPage::SetSplitterPosition( int splitterPos
, int col
)
203 wxPropertyGrid
* pg
= GetGrid();
204 if ( pg
->GetState() == this )
205 pg
->SetSplitterPosition(splitterPos
);
207 DoSetSplitterPosition(splitterPos
, col
, false);
210 void wxPropertyGridPage::DoSetSplitterPosition( int pos
,
214 if ( (flags
& wxPG_SPLITTER_ALL_PAGES
) && m_manager
->GetPageCount() )
215 m_manager
->SetSplitterPosition( pos
, splitterColumn
);
217 wxPropertyGridPageState::DoSetSplitterPosition( pos
,
222 // -----------------------------------------------------------------------
224 // -----------------------------------------------------------------------
228 class wxPGHeaderCtrl
: public wxHeaderCtrl
231 wxPGHeaderCtrl(wxPropertyGridManager
* manager
) :
235 EnsureColumnCount(2);
237 // Seed titles with defaults
238 m_columns
[0]->SetTitle(_("Property"));
239 m_columns
[1]->SetTitle(_("Value"));
242 virtual ~wxPGHeaderCtrl()
244 for (unsigned int i
=0; i
<m_columns
.size(); i
++ )
248 int DetermineColumnWidth(unsigned int idx
, int* pMinWidth
) const
250 const wxPropertyGridPage
* page
= m_page
;
251 int colWidth
= page
->GetColumnWidth(idx
);
252 int colMinWidth
= page
->GetColumnMinWidth(idx
);
255 wxPropertyGrid
* pg
= m_manager
->GetGrid();
256 int margin
= pg
->GetMarginWidth();
258 // Compensate for the internal border
259 margin
+= (pg
->GetSize().x
- pg
->GetClientSize().x
) / 2;
262 colMinWidth
+= margin
;
264 *pMinWidth
= colMinWidth
;
268 void OnPageChanged(const wxPropertyGridPage
* page
)
276 // Get column info from the page
277 const wxPropertyGridPage
* page
= m_page
;
278 unsigned int colCount
= page
->GetColumnCount();
279 EnsureColumnCount(colCount
);
281 for ( unsigned int i
=0; i
<colCount
; i
++ )
283 wxHeaderColumnSimple
* colInfo
= m_columns
[i
];
285 int colWidth
= DetermineColumnWidth(i
, &colMinWidth
);
286 colInfo
->SetWidth(colWidth
);
287 colInfo
->SetMinWidth(colMinWidth
);
290 SetColumnCount(colCount
);
293 void OnColumWidthsChanged()
295 const wxPropertyGridPage
* page
= m_page
;
296 unsigned int colCount
= page
->GetColumnCount();
298 for ( unsigned int i
=0; i
<colCount
; i
++ )
300 wxHeaderColumnSimple
* colInfo
= m_columns
[i
];
302 int colWidth
= DetermineColumnWidth(i
, &colMinWidth
);
303 colInfo
->SetWidth(colWidth
);
304 colInfo
->SetMinWidth(colMinWidth
);
309 virtual const wxHeaderColumn
& GetColumn(unsigned int idx
) const
311 return *m_columns
[idx
];
314 void SetColumnTitle(unsigned int idx
, const wxString
& title
)
316 EnsureColumnCount(idx
+1);
317 m_columns
[idx
]->SetTitle(title
);
321 void EnsureColumnCount(unsigned int count
)
323 while ( m_columns
.size() < count
)
325 wxHeaderColumnSimple
* colInfo
= new wxHeaderColumnSimple("");
326 m_columns
.push_back(colInfo
);
330 void OnSetColumnWidth(int col
, int colWidth
)
332 wxPropertyGrid
* pg
= m_manager
->GetGrid();
334 // Compensate for the internal border
335 int x
= -((pg
->GetSize().x
- pg
->GetClientSize().x
) / 2);
337 for ( int i
=0; i
<col
; i
++ )
338 x
+= m_columns
[i
]->GetWidth();
342 pg
->DoSetSplitterPosition(x
, col
,
343 wxPG_SPLITTER_REFRESH
|
344 wxPG_SPLITTER_FROM_EVENT
);
347 virtual bool ProcessEvent( wxEvent
& event
)
349 if ( event
.IsKindOf(wxCLASSINFO(wxHeaderCtrlEvent
)) )
351 wxHeaderCtrlEvent
& hcEvent
=
352 static_cast<wxHeaderCtrlEvent
&>(event
);
354 wxPropertyGrid
* pg
= m_manager
->GetGrid();
355 int col
= hcEvent
.GetColumn();
356 int evtType
= event
.GetEventType();
358 if ( evtType
== wxEVT_HEADER_RESIZING
)
360 int colWidth
= hcEvent
.GetWidth();
362 OnSetColumnWidth(col
, colWidth
);
364 pg
->SendEvent(wxEVT_PG_COL_DRAGGING
,
370 else if ( evtType
== wxEVT_HEADER_BEGIN_RESIZE
)
372 // Never allow column resize if layout is static
373 if ( m_manager
->HasFlag(wxPG_STATIC_SPLITTER
) )
375 // Allow application to veto dragging
376 else if ( pg
->SendEvent(wxEVT_PG_COL_BEGIN_DRAG
,
383 else if ( evtType
== wxEVT_HEADER_END_RESIZE
)
385 pg
->SendEvent(wxEVT_PG_COL_END_DRAG
,
393 return wxHeaderCtrl::ProcessEvent(event
);
396 wxPropertyGridManager
* m_manager
;
397 const wxPropertyGridPage
* m_page
;
398 wxVector
<wxHeaderColumnSimple
*> m_columns
;
401 #endif // wxUSE_HEADERCTRL
403 // -----------------------------------------------------------------------
404 // wxPropertyGridManager
405 // -----------------------------------------------------------------------
407 // Final default splitter y is client height minus this.
408 #define wxPGMAN_DEFAULT_NEGATIVE_SPLITTER_Y 100
410 // -----------------------------------------------------------------------
412 IMPLEMENT_CLASS(wxPropertyGridManager
, wxPanel
)
414 // -----------------------------------------------------------------------
416 BEGIN_EVENT_TABLE(wxPropertyGridManager
, wxPanel
)
417 EVT_MOTION(wxPropertyGridManager::OnMouseMove
)
418 EVT_SIZE(wxPropertyGridManager::OnResize
)
419 EVT_PAINT(wxPropertyGridManager::OnPaint
)
420 EVT_LEFT_DOWN(wxPropertyGridManager::OnMouseClick
)
421 EVT_LEFT_UP(wxPropertyGridManager::OnMouseUp
)
422 EVT_LEAVE_WINDOW(wxPropertyGridManager::OnMouseEntry
)
423 //EVT_ENTER_WINDOW(wxPropertyGridManager::OnMouseEntry)
426 // -----------------------------------------------------------------------
428 wxPropertyGridManager::wxPropertyGridManager()
434 // -----------------------------------------------------------------------
436 wxPropertyGridManager::wxPropertyGridManager( wxWindow
*parent
,
441 const wxString
& name
)
445 Create(parent
,id
,pos
,size
,style
,name
);
448 // -----------------------------------------------------------------------
450 bool wxPropertyGridManager::Create( wxWindow
*parent
,
455 const wxString
& name
)
458 m_pPropGrid
= CreatePropertyGrid();
460 bool res
= wxPanel::Create( parent
, id
, pos
, size
,
461 (style
&0xFFFF0000)|wxWANTS_CHARS
,
465 // FIXME: this changes call ordering so wxPropertyGrid is created
466 // immediately, before SetExtraStyle has a chance to be called. However,
467 // without it, we may get assertions if size is wxDefaultSize.
468 //SetInitialSize(size);
473 // -----------------------------------------------------------------------
476 // Initialize values to defaults
478 void wxPropertyGridManager::Init1()
487 m_pHeaderCtrl
= NULL
;
488 m_showHeader
= false;
490 m_pTxtHelpCaption
= NULL
;
491 m_pTxtHelpContent
= NULL
;
497 m_width
= m_height
= 0;
499 m_splitterHeight
= 5;
501 m_splitterY
= -1; // -1 causes default to be set.
503 m_nextDescBoxSize
= -1;
505 m_categorizedModeToolId
= -1;
506 m_alphabeticModeToolId
= -1;
514 // -----------------------------------------------------------------------
516 // These flags are always used in wxPropertyGrid integrated in wxPropertyGridManager.
517 #define wxPG_MAN_PROPGRID_FORCED_FLAGS ( wxBORDER_THEME | \
518 wxNO_FULL_REPAINT_ON_RESIZE| \
521 // Which flags can be passed to underlying wxPropertyGrid.
522 #define wxPG_MAN_PASS_FLAGS_MASK (0xFFF0|wxTAB_TRAVERSAL)
525 // Initialize after parent etc. set
527 void wxPropertyGridManager::Init2( int style
)
530 if ( m_iFlags
& wxPG_FL_INITIALIZED
)
533 m_windowStyle
|= (style
&0x0000FFFF);
535 wxSize csz
= GetClientSize();
537 m_cursorSizeNS
= wxCursor(wxCURSOR_SIZENS
);
539 // Prepare the first page
540 // NB: But just prepare - you still need to call Add/InsertPage
541 // to actually add properties on it.
542 wxPropertyGridPage
* pd
= new wxPropertyGridPage();
543 pd
->m_isDefault
= true;
544 pd
->m_manager
= this;
545 wxPropertyGridPageState
* state
= pd
->GetStatePtr();
546 state
->m_pPropGrid
= m_pPropGrid
;
547 m_arrPages
.push_back( pd
);
548 m_pPropGrid
->m_pState
= state
;
550 wxWindowID baseId
= GetId();
551 wxWindowID useId
= baseId
;
553 baseId
= wxPG_MAN_ALTERNATE_BASE_ID
;
556 // Smaller controls on Mac
557 SetWindowVariant(wxWINDOW_VARIANT_SMALL
);
560 long propGridFlags
= (m_windowStyle
&wxPG_MAN_PASS_FLAGS_MASK
)
561 |wxPG_MAN_PROPGRID_FORCED_FLAGS
;
563 propGridFlags
&= ~wxBORDER_MASK
;
565 if ((style
& wxPG_NO_INTERNAL_BORDER
) == 0)
567 propGridFlags
|= wxBORDER_THEME
;
571 propGridFlags
|= wxBORDER_NONE
;
572 wxWindow::SetExtraStyle(wxPG_EX_TOOLBAR_SEPARATOR
);
575 // Create propertygrid.
576 m_pPropGrid
->Create(this,baseId
,wxPoint(0,0),csz
, propGridFlags
);
578 m_pPropGrid
->m_eventObject
= this;
580 m_pPropGrid
->SetId(useId
);
582 m_pPropGrid
->m_iFlags
|= wxPG_FL_IN_MANAGER
;
584 m_pState
= m_pPropGrid
->m_pState
;
586 m_pPropGrid
->SetExtraStyle(wxPG_EX_INIT_NOCAT
);
588 // Connect to property grid onselect event.
589 // NB: Even if wxID_ANY is used, this doesn't connect properly in wxPython
590 // (see wxPropertyGridManager::ProcessEvent).
591 Connect(m_pPropGrid
->GetId(),
593 wxPropertyGridEventHandler(wxPropertyGridManager::OnPropertyGridSelect
));
595 Connect(m_pPropGrid
->GetId(),
596 wxEVT_PG_COL_DRAGGING
,
597 wxPropertyGridEventHandler(wxPropertyGridManager::OnPGColDrag
));
599 // Optional initial controls.
602 m_iFlags
|= wxPG_FL_INITIALIZED
;
606 // -----------------------------------------------------------------------
608 wxPropertyGridManager::~wxPropertyGridManager()
612 //m_pPropGrid->ClearSelection();
613 wxDELETE(m_pPropGrid
);
616 for ( i
=0; i
<m_arrPages
.size(); i
++ )
618 delete m_arrPages
[i
];
624 // -----------------------------------------------------------------------
626 wxPropertyGrid
* wxPropertyGridManager::CreatePropertyGrid() const
628 return new wxPropertyGrid();
631 // -----------------------------------------------------------------------
633 void wxPropertyGridManager::SetId( wxWindowID winid
)
635 wxWindow::SetId(winid
);
637 // TODO: Reconnect propgrid event handler(s).
639 m_pPropGrid
->SetId(winid
);
642 // -----------------------------------------------------------------------
644 wxSize
wxPropertyGridManager::DoGetBestSize() const
646 return wxSize(60,150);
649 // -----------------------------------------------------------------------
651 bool wxPropertyGridManager::SetFont( const wxFont
& font
)
653 bool res
= wxWindow::SetFont(font
);
654 m_pPropGrid
->SetFont(font
);
656 // TODO: Need to do caption recacalculations for other pages as well.
658 for ( i
=0; i
<m_arrPages
.size(); i
++ )
660 wxPropertyGridPage
* page
= GetPage(i
);
662 if ( page
!= m_pPropGrid
->GetState() )
663 page
->CalculateFontAndBitmapStuff(-1);
669 // -----------------------------------------------------------------------
671 void wxPropertyGridManager::SetExtraStyle( long exStyle
)
673 wxWindow::SetExtraStyle( exStyle
);
674 m_pPropGrid
->SetExtraStyle( exStyle
& 0xFFFFF000 );
676 if ( (exStyle
& wxPG_EX_NO_FLAT_TOOLBAR
) && m_pToolbar
)
681 // -----------------------------------------------------------------------
683 void wxPropertyGridManager::Freeze()
685 m_pPropGrid
->Freeze();
689 // -----------------------------------------------------------------------
691 void wxPropertyGridManager::Thaw()
697 // -----------------------------------------------------------------------
699 void wxPropertyGridManager::SetWindowStyleFlag( long style
)
701 int oldWindowStyle
= GetWindowStyleFlag();
703 wxWindow::SetWindowStyleFlag( style
);
704 m_pPropGrid
->SetWindowStyleFlag( (m_pPropGrid
->GetWindowStyleFlag()&~(wxPG_MAN_PASS_FLAGS_MASK
)) |
705 (style
&wxPG_MAN_PASS_FLAGS_MASK
) );
707 // Need to re-position windows?
708 if ( (oldWindowStyle
& (wxPG_TOOLBAR
|wxPG_DESCRIPTION
)) !=
709 (style
& (wxPG_TOOLBAR
|wxPG_DESCRIPTION
)) )
715 // -----------------------------------------------------------------------
717 bool wxPropertyGridManager::Reparent( wxWindowBase
*newParent
)
720 m_pPropGrid
->OnTLPChanging((wxWindow
*)newParent
);
722 bool res
= wxPanel::Reparent(newParent
);
727 // -----------------------------------------------------------------------
729 // Actually shows given page.
730 bool wxPropertyGridManager::DoSelectPage( int index
)
732 // -1 means no page was selected
733 //wxASSERT( m_selPage >= 0 );
735 wxCHECK_MSG( index
>= -1 && index
< (int)GetPageCount(),
737 wxT("invalid page index") );
739 if ( m_selPage
== index
)
742 if ( m_pPropGrid
->GetSelection() )
744 if ( !m_pPropGrid
->ClearSelection() )
749 wxPropertyGridPage
* prevPage
;
751 if ( m_selPage
>= 0 )
752 prevPage
= GetPage(m_selPage
);
754 prevPage
= m_emptyPage
;
757 wxPropertyGridPage
* nextPage
;
761 nextPage
= m_arrPages
[index
];
769 m_emptyPage
= new wxPropertyGridPage();
770 m_emptyPage
->m_pPropGrid
= m_pPropGrid
;
773 nextPage
= m_emptyPage
;
776 m_iFlags
|= wxPG_FL_DESC_REFRESH_REQUIRED
;
778 m_pPropGrid
->SwitchState( nextPage
->GetStatePtr() );
780 m_pState
= m_pPropGrid
->m_pState
;
788 m_pToolbar
->ToggleTool( nextPage
->m_toolId
, true );
790 m_pToolbar
->ToggleTool( prevPage
->m_toolId
, false );
796 m_pHeaderCtrl
->OnPageChanged(nextPage
);
802 // -----------------------------------------------------------------------
804 // Changes page *and* set the target page for insertion operations.
805 void wxPropertyGridManager::SelectPage( int index
)
810 // -----------------------------------------------------------------------
812 int wxPropertyGridManager::GetPageByName( const wxString
& name
) const
815 for ( i
=0; i
<GetPageCount(); i
++ )
817 if ( m_arrPages
[i
]->m_label
== name
)
823 // -----------------------------------------------------------------------
825 int wxPropertyGridManager::GetPageByState( const wxPropertyGridPageState
* pState
) const
830 for ( i
=0; i
<GetPageCount(); i
++ )
832 if ( pState
== m_arrPages
[i
]->GetStatePtr() )
839 // -----------------------------------------------------------------------
841 const wxString
& wxPropertyGridManager::GetPageName( int index
) const
843 wxASSERT( index
>= 0 && index
< (int)GetPageCount() );
844 return m_arrPages
[index
]->m_label
;
847 // -----------------------------------------------------------------------
849 wxPropertyGridPageState
* wxPropertyGridManager::GetPageState( int page
) const
851 // Do not change this into wxCHECK because returning NULL is important
852 // for wxPropertyGridInterface page enumeration mechanics.
853 if ( page
>= (int)GetPageCount() )
858 return m_arrPages
[page
];
861 // -----------------------------------------------------------------------
863 void wxPropertyGridManager::Clear()
865 m_pPropGrid
->ClearSelection(false);
867 m_pPropGrid
->Freeze();
870 for ( i
=(int)GetPageCount()-1; i
>=0; i
-- )
876 // -----------------------------------------------------------------------
878 void wxPropertyGridManager::ClearPage( int page
)
880 wxASSERT( page
>= 0 );
881 wxASSERT( page
< (int)GetPageCount() );
883 if ( page
>= 0 && page
< (int)GetPageCount() )
885 wxPropertyGridPageState
* state
= m_arrPages
[page
];
887 if ( state
== m_pPropGrid
->GetState() )
888 m_pPropGrid
->Clear();
894 // -----------------------------------------------------------------------
896 int wxPropertyGridManager::GetColumnCount( int page
) const
898 wxASSERT( page
>= -1 );
899 wxASSERT( page
< (int)GetPageCount() );
901 return GetPageState(page
)->GetColumnCount();
904 // -----------------------------------------------------------------------
906 void wxPropertyGridManager::SetColumnCount( int colCount
, int page
)
908 wxASSERT( page
>= -1 );
909 wxASSERT( page
< (int)GetPageCount() );
911 GetPageState(page
)->SetColumnCount( colCount
);
912 GetGrid()->Refresh();
916 m_pHeaderCtrl
->OnPageUpdated();
919 // -----------------------------------------------------------------------
921 size_t wxPropertyGridManager::GetPageCount() const
923 if ( !(m_iFlags
& wxPG_MAN_FL_PAGE_INSERTED
) )
926 return m_arrPages
.size();
929 // -----------------------------------------------------------------------
931 wxPropertyGridPage
* wxPropertyGridManager::InsertPage( int index
,
932 const wxString
& label
,
934 wxPropertyGridPage
* pageObj
)
937 index
= GetPageCount();
939 wxCHECK_MSG( (size_t)index
== GetPageCount(), NULL
,
940 wxT("wxPropertyGridManager currently only supports appending pages (due to wxToolBar limitation)."));
942 bool needInit
= true;
943 bool isPageInserted
= m_iFlags
& wxPG_MAN_FL_PAGE_INSERTED
? true : false;
945 wxASSERT( index
== 0 || isPageInserted
);
949 // No custom page object was given, so we will either re-use the default base
950 // page (if index==0), or create a new default page object.
951 if ( !isPageInserted
)
953 pageObj
= GetPage(0);
954 // Of course, if the base page was custom, we need to delete and
956 if ( !pageObj
->m_isDefault
)
959 pageObj
= new wxPropertyGridPage();
960 m_arrPages
[0] = pageObj
;
966 pageObj
= new wxPropertyGridPage();
968 pageObj
->m_isDefault
= true;
972 if ( !isPageInserted
)
974 // Initial page needs to be deleted and replaced
976 m_arrPages
[0] = pageObj
;
977 m_pPropGrid
->m_pState
= pageObj
->GetStatePtr();
981 wxPropertyGridPageState
* state
= pageObj
->GetStatePtr();
983 pageObj
->m_manager
= this;
987 state
->m_pPropGrid
= m_pPropGrid
;
988 state
->InitNonCatMode();
991 if ( !label
.empty() )
993 wxASSERT_MSG( !pageObj
->m_label
.length(),
994 wxT("If page label is given in constructor, empty label must be given in AddPage"));
995 pageObj
->m_label
= label
;
998 pageObj
->m_toolId
= -1;
1000 if ( !HasFlag(wxPG_SPLITTER_AUTO_CENTER
) )
1001 pageObj
->m_dontCenterSplitter
= true;
1003 if ( isPageInserted
)
1004 m_arrPages
.push_back( pageObj
);
1007 if ( m_windowStyle
& wxPG_TOOLBAR
)
1012 if ( !(GetExtraStyle()&wxPG_EX_HIDE_PAGE_BUTTONS
) )
1014 wxASSERT( m_pToolbar
);
1016 // Add separator before first page.
1017 if ( GetPageCount() < 2 && (GetExtraStyle()&wxPG_EX_MODE_BUTTONS
) &&
1018 m_pToolbar
->GetToolsCount() < 3 )
1019 m_pToolbar
->AddSeparator();
1021 wxToolBarToolBase
* tool
;
1023 if ( &bmp
!= &wxNullBitmap
)
1024 tool
= m_pToolbar
->AddTool(wxID_ANY
, label
, bmp
,
1025 label
, wxITEM_RADIO
);
1027 tool
= m_pToolbar
->AddTool(wxID_ANY
, label
,
1028 wxBitmap(gs_xpm_defpage
),
1029 label
, wxITEM_RADIO
);
1031 pageObj
->m_toolId
= tool
->GetId();
1033 // Connect to toolbar button events.
1034 Connect(pageObj
->m_toolId
,
1036 wxCommandEventHandler(
1037 wxPropertyGridManager::OnToolbarClick
));
1039 m_pToolbar
->Realize();
1046 // If selected page was above the point of insertion, fix the current page index
1047 if ( isPageInserted
)
1049 if ( m_selPage
>= index
)
1056 // Set this value only when adding the first page
1062 m_iFlags
|= wxPG_MAN_FL_PAGE_INSERTED
;
1064 wxASSERT( pageObj
->GetGrid() );
1069 // -----------------------------------------------------------------------
1071 bool wxPropertyGridManager::IsAnyModified() const
1074 for ( i
=0; i
<GetPageCount(); i
++ )
1076 if ( m_arrPages
[i
]->GetStatePtr()->m_anyModified
)
1082 // -----------------------------------------------------------------------
1084 bool wxPropertyGridManager::IsPageModified( size_t index
) const
1086 if ( m_arrPages
[index
]->GetStatePtr()->m_anyModified
)
1091 // -----------------------------------------------------------------------
1093 #if wxUSE_HEADERCTRL
1094 void wxPropertyGridManager::ShowHeader(bool show
)
1096 if ( show
!= m_showHeader
)
1098 m_showHeader
= show
;
1104 // -----------------------------------------------------------------------
1106 #if wxUSE_HEADERCTRL
1107 void wxPropertyGridManager::SetColumnTitle( int idx
, const wxString
& title
)
1109 if ( !m_pHeaderCtrl
)
1112 m_pHeaderCtrl
->SetColumnTitle(idx
, title
);
1116 // -----------------------------------------------------------------------
1118 bool wxPropertyGridManager::IsPropertySelected( wxPGPropArg id
) const
1120 wxPG_PROP_ARG_CALL_PROLOG_RETVAL(false)
1121 for ( unsigned int i
=0; i
<GetPageCount(); i
++ )
1123 if ( GetPageState(i
)->DoIsPropertySelected(p
) )
1129 // -----------------------------------------------------------------------
1131 wxPGProperty
* wxPropertyGridManager::GetPageRoot( int index
) const
1133 wxASSERT( index
>= 0 );
1134 wxASSERT( index
< (int)m_arrPages
.size() );
1136 return m_arrPages
[index
]->GetStatePtr()->m_properties
;
1139 // -----------------------------------------------------------------------
1141 bool wxPropertyGridManager::RemovePage( int page
)
1143 wxCHECK_MSG( (page
>= 0) && (page
< (int)GetPageCount()),
1145 wxT("invalid page index") );
1147 wxPropertyGridPage
* pd
= m_arrPages
[page
];
1149 if ( m_arrPages
.size() == 1 )
1151 // Last page: do not remove page entry
1152 m_pPropGrid
->Clear();
1154 m_iFlags
&= ~wxPG_MAN_FL_PAGE_INSERTED
;
1155 pd
->m_label
.clear();
1158 // Change selection if current is page
1159 else if ( page
== m_selPage
)
1161 if ( !m_pPropGrid
->ClearSelection() )
1164 // Substitute page to select
1165 int substitute
= page
- 1;
1166 if ( substitute
< 0 )
1167 substitute
= page
+ 1;
1169 SelectPage(substitute
);
1172 // Remove toolbar icon
1174 if ( HasFlag(wxPG_TOOLBAR
) )
1176 wxASSERT( m_pToolbar
);
1178 int toolPos
= GetExtraStyle() & wxPG_EX_MODE_BUTTONS
? 3 : 0;
1181 // Delete separator as well, for consistency
1182 if ( (GetExtraStyle() & wxPG_EX_MODE_BUTTONS
) &&
1183 GetPageCount() == 1 )
1184 m_pToolbar
->DeleteToolByPos(2);
1186 m_pToolbar
->DeleteToolByPos(toolPos
);
1190 if ( m_arrPages
.size() > 1 )
1192 m_arrPages
.erase(m_arrPages
.begin() + page
);
1196 // Adjust indexes that were above removed
1197 if ( m_selPage
> page
)
1203 // -----------------------------------------------------------------------
1205 bool wxPropertyGridManager::ProcessEvent( wxEvent
& event
)
1207 int evtType
= event
.GetEventType();
1209 // NB: For some reason, under wxPython, Connect in Init doesn't work properly,
1210 // so we'll need to call OnPropertyGridSelect manually. Multiple call's
1211 // don't really matter.
1212 if ( evtType
== wxEVT_PG_SELECTED
)
1213 OnPropertyGridSelect((wxPropertyGridEvent
&)event
);
1215 // Property grid events get special attention
1216 if ( evtType
>= wxPG_BASE_EVT_TYPE
&&
1217 evtType
< (wxPG_MAX_EVT_TYPE
) &&
1220 wxPropertyGridPage
* page
= GetPage(m_selPage
);
1221 wxPropertyGridEvent
* pgEvent
= wxDynamicCast(&event
, wxPropertyGridEvent
);
1223 // Add property grid events to appropriate custom pages
1224 // but stop propagating to parent if page says it is
1225 // handling everything.
1226 if ( pgEvent
&& !page
->m_isDefault
)
1228 /*if ( pgEvent->IsPending() )
1229 page->AddPendingEvent(event);
1231 page
->ProcessEvent(event
);
1233 if ( page
->IsHandlingAllEvents() )
1234 event
.StopPropagation();
1238 return wxPanel::ProcessEvent(event
);
1241 // -----------------------------------------------------------------------
1243 void wxPropertyGridManager::RepaintDescBoxDecorations( wxDC
& dc
,
1249 wxColour bgcol
= GetBackgroundColour();
1252 int rectHeight
= m_splitterHeight
;
1253 dc
.DrawRectangle(0, newSplitterY
, newWidth
, rectHeight
);
1254 dc
.SetPen( wxSystemSettings::GetColour(wxSYS_COLOUR_3DDKSHADOW
) );
1255 int splitterBottom
= newSplitterY
+ m_splitterHeight
- 1;
1256 int boxHeight
= newHeight
- splitterBottom
;
1257 if ( boxHeight
> 1 )
1258 dc
.DrawRectangle(0, splitterBottom
, newWidth
, boxHeight
);
1260 dc
.DrawLine(0, splitterBottom
, newWidth
, splitterBottom
);
1263 // -----------------------------------------------------------------------
1265 void wxPropertyGridManager::UpdateDescriptionBox( int new_splittery
, int new_width
, int new_height
)
1267 int use_hei
= new_height
;
1270 // Fix help control positions.
1271 int cap_hei
= m_pPropGrid
->m_fontHeight
;
1272 int cap_y
= new_splittery
+m_splitterHeight
+5;
1273 int cnt_y
= cap_y
+cap_hei
+3;
1274 int sub_cap_hei
= cap_y
+cap_hei
-use_hei
;
1275 int cnt_hei
= use_hei
-cnt_y
;
1276 if ( sub_cap_hei
> 0 )
1278 cap_hei
-= sub_cap_hei
;
1283 m_pTxtHelpCaption
->Show( false );
1284 m_pTxtHelpContent
->Show( false );
1288 m_pTxtHelpCaption
->SetSize(3,cap_y
,new_width
-6,cap_hei
);
1289 m_pTxtHelpCaption
->Wrap(-1);
1290 m_pTxtHelpCaption
->Show( true );
1293 m_pTxtHelpContent
->Show( false );
1297 m_pTxtHelpContent
->SetSize(3,cnt_y
,new_width
-6,cnt_hei
);
1298 m_pTxtHelpContent
->Show( true );
1302 wxRect
r(0, new_splittery
, new_width
, new_height
-new_splittery
);
1305 m_splitterY
= new_splittery
;
1307 m_iFlags
&= ~(wxPG_FL_DESC_REFRESH_REQUIRED
);
1310 // -----------------------------------------------------------------------
1312 void wxPropertyGridManager::RecalculatePositions( int width
, int height
)
1315 int propgridBottomY
= height
;
1317 // Toolbar at the top.
1321 m_pToolbar
->SetSize(0, 0, width
, -1);
1322 propgridY
+= m_pToolbar
->GetSize().y
;
1324 if (GetExtraStyle() & wxPG_EX_TOOLBAR_SEPARATOR
)
1329 // Header comes after the tool bar
1330 #if wxUSE_HEADERCTRL
1333 m_pHeaderCtrl
->SetSize(0, propgridY
, width
, -1);
1334 propgridY
+= m_pHeaderCtrl
->GetSize().y
;
1339 if ( m_pTxtHelpCaption
)
1341 int new_splittery
= m_splitterY
;
1344 if ( ( m_splitterY
>= 0 || m_nextDescBoxSize
) && m_height
> 32 )
1346 if ( m_nextDescBoxSize
>= 0 )
1348 new_splittery
= m_height
- m_nextDescBoxSize
- m_splitterHeight
;
1349 m_nextDescBoxSize
= -1;
1351 new_splittery
+= (height
-m_height
);
1355 new_splittery
= height
- wxPGMAN_DEFAULT_NEGATIVE_SPLITTER_Y
;
1356 if ( new_splittery
< 32 )
1360 // Check if beyond minimum.
1361 int nspy_min
= propgridY
+ m_pPropGrid
->m_lineHeight
;
1362 if ( new_splittery
< nspy_min
)
1363 new_splittery
= nspy_min
;
1365 propgridBottomY
= new_splittery
;
1367 UpdateDescriptionBox( new_splittery
, width
, height
);
1370 if ( m_iFlags
& wxPG_FL_INITIALIZED
)
1372 int pgh
= propgridBottomY
- propgridY
;
1375 m_pPropGrid
->SetSize( 0, propgridY
, width
, pgh
);
1377 m_extraHeight
= height
- pgh
;
1384 // -----------------------------------------------------------------------
1386 void wxPropertyGridManager::SetDescBoxHeight( int ht
, bool refresh
)
1388 if ( m_windowStyle
& wxPG_DESCRIPTION
)
1390 if ( ht
!= GetDescBoxHeight() )
1392 m_nextDescBoxSize
= ht
;
1394 RecalculatePositions(m_width
, m_height
);
1399 // -----------------------------------------------------------------------
1401 int wxPropertyGridManager::GetDescBoxHeight() const
1403 return GetClientSize().y
- m_splitterY
- m_splitterHeight
;
1406 // -----------------------------------------------------------------------
1408 void wxPropertyGridManager::OnPaint( wxPaintEvent
& WXUNUSED(event
) )
1412 // Update everything inside the box
1413 wxRect r
= GetUpdateRegion().GetBox();
1415 if (GetExtraStyle() & wxPG_EX_TOOLBAR_SEPARATOR
)
1417 if (m_pToolbar
&& m_pPropGrid
)
1419 wxPen
marginPen(m_pPropGrid
->GetMarginColour());
1420 dc
.SetPen(marginPen
);
1422 int y
= m_pPropGrid
->GetPosition().y
-1;
1423 dc
.DrawLine(0, y
, GetClientSize().x
, y
);
1427 // Repaint splitter and any other description box decorations
1428 if ( (r
.y
+ r
.height
) >= m_splitterY
&& m_splitterY
!= -1)
1429 RepaintDescBoxDecorations( dc
, m_splitterY
, m_width
, m_height
);
1432 // -----------------------------------------------------------------------
1434 void wxPropertyGridManager::Refresh(bool eraseBackground
, const wxRect
* rect
)
1436 m_pPropGrid
->Refresh(eraseBackground
);
1437 wxWindow::Refresh(eraseBackground
,rect
);
1440 // -----------------------------------------------------------------------
1442 void wxPropertyGridManager::RefreshProperty( wxPGProperty
* p
)
1444 wxPropertyGrid
* grid
= p
->GetGrid();
1446 if ( GetPage(m_selPage
)->GetStatePtr() == p
->GetParent()->GetParentState() )
1447 grid
->RefreshProperty(p
);
1450 // -----------------------------------------------------------------------
1452 void wxPropertyGridManager::RecreateControls()
1455 bool was_shown
= IsShown();
1460 if ( m_windowStyle
& wxPG_TOOLBAR
)
1465 long toolBarFlags
= ((GetExtraStyle()&wxPG_EX_NO_FLAT_TOOLBAR
)?0:wxTB_FLAT
);
1466 if (GetExtraStyle() & wxPG_EX_NO_TOOLBAR_DIVIDER
)
1467 toolBarFlags
|= wxTB_NODIVIDER
;
1469 m_pToolbar
= new wxToolBar(this, wxID_ANY
,
1473 m_pToolbar
->SetToolBitmapSize(wxSize(16, 15));
1475 #if defined(__WXMSW__)
1476 // Eliminate toolbar flicker on XP
1477 // NOTE: Not enabled since it corrupts drawing somewhat.
1480 #ifndef WS_EX_COMPOSITED
1481 #define WS_EX_COMPOSITED 0x02000000L
1484 HWND hWnd = (HWND)m_pToolbar->GetHWND();
1486 ::SetWindowLong( hWnd, GWL_EXSTYLE,
1487 ::GetWindowLong(hWnd, GWL_EXSTYLE) | WS_EX_COMPOSITED );
1492 m_pToolbar
->SetCursor ( *wxSTANDARD_CURSOR
);
1494 if ( (GetExtraStyle()&wxPG_EX_MODE_BUTTONS
) )
1496 wxString
desc1(_("Categorized Mode"));
1497 wxString
desc2(_("Alphabetic Mode"));
1499 wxToolBarToolBase
* tool
;
1501 tool
= m_pToolbar
->AddTool(wxID_ANY
,
1503 wxBitmap(gs_xpm_catmode
),
1506 m_categorizedModeToolId
= tool
->GetId();
1508 tool
= m_pToolbar
->AddTool(wxID_ANY
,
1510 wxBitmap(gs_xpm_noncatmode
),
1513 m_alphabeticModeToolId
= tool
->GetId();
1515 m_pToolbar
->Realize();
1517 Connect(m_categorizedModeToolId
,
1519 wxCommandEventHandler(
1520 wxPropertyGridManager::OnToolbarClick
));
1521 Connect(m_alphabeticModeToolId
,
1523 wxCommandEventHandler(
1524 wxPropertyGridManager::OnToolbarClick
));
1528 m_categorizedModeToolId
= -1;
1529 m_alphabeticModeToolId
= -1;
1534 if ( (GetExtraStyle() & wxPG_EX_MODE_BUTTONS
) )
1536 // Toggle correct mode button.
1537 // TODO: This doesn't work in wxMSW (when changing,
1538 // both items will get toggled).
1539 int toggle_but_on_ind
;
1540 int toggle_but_off_ind
;
1541 if ( m_pPropGrid
->m_pState
->IsInNonCatMode() )
1543 toggle_but_on_ind
= m_alphabeticModeToolId
;
1544 toggle_but_off_ind
= m_categorizedModeToolId
;
1548 toggle_but_on_ind
= m_categorizedModeToolId
;
1549 toggle_but_off_ind
= m_alphabeticModeToolId
;
1552 m_pToolbar
->ToggleTool(toggle_but_on_ind
, true);
1553 m_pToolbar
->ToggleTool(toggle_but_off_ind
, false);
1561 m_pToolbar
->Destroy();
1566 #if wxUSE_HEADERCTRL
1571 if ( !m_pHeaderCtrl
)
1573 hc
= new wxPGHeaderCtrl(this);
1574 hc
->Create(this, wxID_ANY
);
1579 m_pHeaderCtrl
->Show();
1582 m_pHeaderCtrl
->OnPageChanged(GetCurrentPage());
1586 if ( m_pHeaderCtrl
)
1587 m_pHeaderCtrl
->Hide();
1591 if ( m_windowStyle
& wxPG_DESCRIPTION
)
1594 m_pPropGrid
->m_iFlags
|= (wxPG_FL_NOSTATUSBARHELP
);
1596 if ( !m_pTxtHelpCaption
)
1598 m_pTxtHelpCaption
= new wxStaticText(this,
1603 wxALIGN_LEFT
|wxST_NO_AUTORESIZE
);
1604 m_pTxtHelpCaption
->SetFont( m_pPropGrid
->m_captionFont
);
1605 m_pTxtHelpCaption
->SetCursor( *wxSTANDARD_CURSOR
);
1607 if ( !m_pTxtHelpContent
)
1609 m_pTxtHelpContent
= new wxStaticText(this,
1614 wxALIGN_LEFT
|wxST_NO_AUTORESIZE
);
1615 m_pTxtHelpContent
->SetCursor( *wxSTANDARD_CURSOR
);
1618 SetDescribedProperty(GetSelection());
1623 m_pPropGrid
->m_iFlags
&= ~(wxPG_FL_NOSTATUSBARHELP
);
1625 if ( m_pTxtHelpCaption
)
1626 m_pTxtHelpCaption
->Destroy();
1628 m_pTxtHelpCaption
= NULL
;
1630 if ( m_pTxtHelpContent
)
1631 m_pTxtHelpContent
->Destroy();
1633 m_pTxtHelpContent
= NULL
;
1638 GetClientSize(&width
,&height
);
1640 RecalculatePositions(width
,height
);
1646 // -----------------------------------------------------------------------
1648 wxPGProperty
* wxPropertyGridManager::DoGetPropertyByName( const wxString
& name
) const
1651 for ( i
=0; i
<GetPageCount(); i
++ )
1653 wxPropertyGridPageState
* pState
= m_arrPages
[i
]->GetStatePtr();
1654 wxPGProperty
* p
= pState
->BaseGetPropertyByName(name
);
1663 // -----------------------------------------------------------------------
1665 bool wxPropertyGridManager::EnsureVisible( wxPGPropArg id
)
1667 wxPG_PROP_ARG_CALL_PROLOG_RETVAL(false)
1669 wxPropertyGridPageState
* parentState
= p
->GetParentState();
1671 // Select correct page.
1672 if ( m_pPropGrid
->m_pState
!= parentState
)
1673 DoSelectPage( GetPageByState(parentState
) );
1675 return m_pPropGrid
->EnsureVisible(id
);
1678 // -----------------------------------------------------------------------
1680 void wxPropertyGridManager::OnToolbarClick( wxCommandEvent
&event
)
1682 int id
= event
.GetId();
1684 if ( id
== m_categorizedModeToolId
)
1686 // Categorized mode.
1687 if ( m_pPropGrid
->m_windowStyle
& wxPG_HIDE_CATEGORIES
)
1689 if ( !m_pPropGrid
->HasInternalFlag(wxPG_FL_CATMODE_AUTO_SORT
) )
1690 m_pPropGrid
->m_windowStyle
&= ~wxPG_AUTO_SORT
;
1691 m_pPropGrid
->EnableCategories( true );
1694 else if ( id
== m_alphabeticModeToolId
)
1697 if ( !(m_pPropGrid
->m_windowStyle
& wxPG_HIDE_CATEGORIES
) )
1699 if ( m_pPropGrid
->HasFlag(wxPG_AUTO_SORT
) )
1700 m_pPropGrid
->SetInternalFlag(wxPG_FL_CATMODE_AUTO_SORT
);
1702 m_pPropGrid
->ClearInternalFlag(wxPG_FL_CATMODE_AUTO_SORT
);
1704 m_pPropGrid
->m_windowStyle
|= wxPG_AUTO_SORT
;
1705 m_pPropGrid
->EnableCategories( false );
1714 wxPropertyGridPage
* pdc
;
1716 // Find page with given id.
1717 for ( i
=0; i
<GetPageCount(); i
++ )
1719 pdc
= m_arrPages
[i
];
1720 if ( pdc
->m_toolId
== id
)
1727 wxASSERT( index
>= 0 );
1729 if ( DoSelectPage( index
) )
1731 // Event dispatching must be last.
1732 m_pPropGrid
->SendEvent( wxEVT_PG_PAGE_CHANGED
, NULL
);
1736 // TODO: Depress the old button on toolbar.
1741 // -----------------------------------------------------------------------
1743 bool wxPropertyGridManager::SetEditableStateItem( const wxString
& name
, wxVariant value
)
1745 if ( name
== wxS("descboxheight") )
1747 SetDescBoxHeight(value
.GetLong(), true);
1753 // -----------------------------------------------------------------------
1755 wxVariant
wxPropertyGridManager::GetEditableStateItem( const wxString
& name
) const
1757 if ( name
== wxS("descboxheight") )
1759 return (long) GetDescBoxHeight();
1761 return wxNullVariant
;
1764 // -----------------------------------------------------------------------
1766 void wxPropertyGridManager::SetDescription( const wxString
& label
, const wxString
& content
)
1768 if ( m_pTxtHelpCaption
)
1770 wxSize osz1
= m_pTxtHelpCaption
->GetSize();
1771 wxSize osz2
= m_pTxtHelpContent
->GetSize();
1773 m_pTxtHelpCaption
->SetLabel(label
);
1774 m_pTxtHelpContent
->SetLabel(content
);
1776 m_pTxtHelpCaption
->SetSize(-1,osz1
.y
);
1777 m_pTxtHelpContent
->SetSize(-1,osz2
.y
);
1779 UpdateDescriptionBox( m_splitterY
, m_width
, m_height
);
1783 // -----------------------------------------------------------------------
1785 void wxPropertyGridManager::SetDescribedProperty( wxPGProperty
* p
)
1787 if ( m_pTxtHelpCaption
)
1791 SetDescription( p
->GetLabel(), p
->GetHelpString() );
1795 SetDescription( wxEmptyString
, wxEmptyString
);
1800 // -----------------------------------------------------------------------
1802 void wxPropertyGridManager::SetSplitterLeft( bool subProps
, bool allPages
)
1806 m_pPropGrid
->SetSplitterLeft(subProps
);
1810 wxClientDC
dc(this);
1811 dc
.SetFont(m_pPropGrid
->GetFont());
1816 for ( i
=0; i
<GetPageCount(); i
++ )
1818 int maxW
= m_pState
->GetColumnFitWidth(dc
, m_arrPages
[i
]->m_properties
, 0, subProps
);
1819 maxW
+= m_pPropGrid
->m_marginWidth
;
1820 if ( maxW
> highest
)
1822 m_pState
->m_dontCenterSplitter
= true;
1826 SetSplitterPosition( highest
);
1829 #if wxUSE_HEADERCTRL
1831 m_pHeaderCtrl
->OnColumWidthsChanged();
1835 void wxPropertyGridManager::SetPageSplitterLeft(int page
, bool subProps
)
1837 wxASSERT_MSG( (page
< (int) GetPageCount()),
1838 wxT("SetPageSplitterLeft() has no effect until pages have been added") );
1840 if (page
< (int) GetPageCount())
1842 wxClientDC
dc(this);
1843 dc
.SetFont(m_pPropGrid
->GetFont());
1845 int maxW
= m_pState
->GetColumnFitWidth(dc
, m_arrPages
[page
]->m_properties
, 0, subProps
);
1846 maxW
+= m_pPropGrid
->m_marginWidth
;
1847 SetPageSplitterPosition( page
, maxW
);
1849 #if wxUSE_HEADERCTRL
1851 m_pHeaderCtrl
->OnColumWidthsChanged();
1856 // -----------------------------------------------------------------------
1858 void wxPropertyGridManager::OnPropertyGridSelect( wxPropertyGridEvent
& event
)
1861 wxASSERT_MSG( GetId() == m_pPropGrid
->GetId(),
1862 wxT("wxPropertyGridManager id must be set with wxPropertyGridManager::SetId (not wxWindow::SetId).") );
1864 SetDescribedProperty(event
.GetProperty());
1868 // -----------------------------------------------------------------------
1871 wxPropertyGridManager::OnPGColDrag( wxPropertyGridEvent
& WXUNUSED(event
) )
1873 #if wxUSE_HEADERCTRL
1874 if ( !m_showHeader
)
1877 m_pHeaderCtrl
->OnColumWidthsChanged();
1881 // -----------------------------------------------------------------------
1883 void wxPropertyGridManager::OnResize( wxSizeEvent
& WXUNUSED(event
) )
1887 GetClientSize(&width
, &height
);
1889 if ( m_width
== -12345 )
1892 RecalculatePositions(width
, height
);
1894 if ( m_pPropGrid
&& m_pPropGrid
->m_parent
)
1896 int pgWidth
, pgHeight
;
1897 m_pPropGrid
->GetClientSize(&pgWidth
, &pgHeight
);
1899 // Regenerate splitter positions for non-current pages
1900 for ( unsigned int i
=0; i
<GetPageCount(); i
++ )
1902 wxPropertyGridPage
* page
= GetPage(i
);
1903 if ( page
!= m_pPropGrid
->GetState() )
1905 page
->OnClientWidthChange(pgWidth
,
1906 pgWidth
- page
->m_width
,
1912 #if wxUSE_HEADERCTRL
1914 m_pHeaderCtrl
->OnColumWidthsChanged();
1918 // -----------------------------------------------------------------------
1920 void wxPropertyGridManager::OnMouseEntry( wxMouseEvent
& WXUNUSED(event
) )
1922 // Correct cursor. This is required atleast for wxGTK, for which
1923 // setting button's cursor to *wxSTANDARD_CURSOR does not work.
1924 SetCursor( wxNullCursor
);
1928 // -----------------------------------------------------------------------
1930 void wxPropertyGridManager::OnMouseMove( wxMouseEvent
&event
)
1932 if ( !m_pTxtHelpCaption
)
1937 if ( m_dragStatus
> 0 )
1939 int sy
= y
- m_dragOffset
;
1941 // Calculate drag limits
1942 int bottom_limit
= m_height
- m_splitterHeight
+ 1;
1943 int top_limit
= m_pPropGrid
->m_lineHeight
;
1945 if ( m_pToolbar
) top_limit
+= m_pToolbar
->GetSize().y
;
1948 if ( sy
>= top_limit
&& sy
< bottom_limit
)
1951 int change
= sy
- m_splitterY
;
1956 m_pPropGrid
->SetSize( m_width
, m_splitterY
- m_pPropGrid
->GetPosition().y
);
1957 UpdateDescriptionBox( m_splitterY
, m_width
, m_height
);
1959 m_extraHeight
-= change
;
1960 InvalidateBestSize();
1968 if ( y
>= m_splitterY
&& y
< (m_splitterY
+m_splitterHeight
+2) )
1970 SetCursor ( m_cursorSizeNS
);
1977 SetCursor ( wxNullCursor
);
1984 // -----------------------------------------------------------------------
1986 void wxPropertyGridManager::OnMouseClick( wxMouseEvent
&event
)
1990 // Click on splitter.
1991 if ( y
>= m_splitterY
&& y
< (m_splitterY
+m_splitterHeight
+2) )
1993 if ( m_dragStatus
== 0 )
1996 // Begin draggin the splitter
2003 m_dragOffset
= y
- m_splitterY
;
2009 // -----------------------------------------------------------------------
2011 void wxPropertyGridManager::OnMouseUp( wxMouseEvent
&event
)
2013 // No event type check - basically calling this method should
2014 // just stop dragging.
2016 if ( m_dragStatus
>= 1 )
2019 // End Splitter Dragging
2024 // DO NOT ENABLE FOLLOWING LINE!
2025 // (it is only here as a reminder to not to do it)
2028 // This is necessary to return cursor
2031 // Set back the default cursor, if necessary
2032 if ( y
< m_splitterY
|| y
>= (m_splitterY
+m_splitterHeight
+2) )
2034 SetCursor ( wxNullCursor
);
2041 // -----------------------------------------------------------------------
2043 void wxPropertyGridManager::SetSplitterPosition( int pos
, int splitterColumn
)
2045 wxASSERT_MSG( GetPageCount(),
2046 wxT("SetSplitterPosition() has no effect until pages have been added") );
2049 for ( i
=0; i
<GetPageCount(); i
++ )
2051 wxPropertyGridPage
* page
= GetPage(i
);
2052 page
->DoSetSplitterPosition( pos
, splitterColumn
,
2053 wxPG_SPLITTER_REFRESH
);
2056 #if wxUSE_HEADERCTRL
2058 m_pHeaderCtrl
->OnColumWidthsChanged();
2062 // -----------------------------------------------------------------------
2064 void wxPropertyGridManager::SetPageSplitterPosition( int page
,
2068 GetPage(page
)->DoSetSplitterPosition( pos
, column
);
2070 #if wxUSE_HEADERCTRL
2072 m_pHeaderCtrl
->OnColumWidthsChanged();
2076 // -----------------------------------------------------------------------
2077 // wxPGVIterator_Manager
2078 // -----------------------------------------------------------------------
2080 // Default returned by wxPropertyGridInterface::CreateVIterator().
2081 class wxPGVIteratorBase_Manager
: public wxPGVIteratorBase
2084 wxPGVIteratorBase_Manager( wxPropertyGridManager
* manager
, int flags
)
2085 : m_manager(manager
), m_flags(flags
), m_curPage(0)
2087 m_it
.Init(manager
->GetPage(0), flags
);
2089 virtual ~wxPGVIteratorBase_Manager() { }
2098 if ( m_curPage
< m_manager
->GetPageCount() )
2099 m_it
.Init( m_manager
->GetPage(m_curPage
), m_flags
);
2103 wxPropertyGridManager
* m_manager
;
2105 unsigned int m_curPage
;
2108 wxPGVIterator
wxPropertyGridManager::GetVIterator( int flags
) const
2110 return wxPGVIterator( new wxPGVIteratorBase_Manager( (wxPropertyGridManager
*)this, flags
) );
2113 #endif // wxUSE_PROPGRID