How to turn on/off sorting for category and property names in the property grid?
CExtPropertyGridCtrl control is implemented as a container for one or more
CExtPropertyGridWnd tree grid controls, which are used for displaying property values and, optionally, property categories. You can configure each tree grid in such a way that its property values and/or property categories are either sorted or go in the order in which you inserted them into the grid.
First get the tree grids created in the property grid:
CExtPropertyGridCtrl * pPGC = . . .
CTypedPtrArray < CPtrArray, CExtPropertyGridWnd * > arrGrids;
pPGC->OnPgcQueryGrids( arrGrids );
Second specify the sort options for each tree grid:
bool bSortedCategories = . . .
bool bSortedValues = . . .
for( ; nGridIdx < arrGrids.GetSize(); nGridIdx ++ )
CExtPropertyGridWnd * pPGW = arrGrids[ nGridIdx ];
ASSERT_VALID( pPGW );
pPGW->m_bSortedCategories = bSortedCategories;
pPGW->m_bSortedValues = bSortedValues;
If the code above is invoked before assigning a property store to the property grid, the task is complete. If a property store is already assigned and its content is loaded into the tree grid controls, you should use the
CExtPropertyGridCtrl::PropertyStoreSynchronize() method for refresh the tree grids because their sort options have changed.
How to implement a property grid without the top combo box?
There are two ways doing this. The first is to call
CExtPropertyGridCtrl::GetChildByRTC() in order to get a pointer to the
CExtPropertyGridComboBoxBar window, hide it and finally call
CExtPropertyGridCtrl::RecalcLayout(). The second is to override the
OnPgcCreateBars() method in a
CExtPropertyGridCtrl-derived class so the new method is the same as the original one except for the
CExtPropertyGridComboBoxBar window that should not be created in it.
How can I know when the user expands or collapses a category in the property grid control?
The categorized grid (
CExtPropertyGridWndCategorized) in the property grid (
CExtPropertyGridCtrl) is derived from the
CExtTreeGridWnd class, which has a
CExtTreeGridWnd::ItemExpand() virtual method that is invoked when an item with sub items is expanded or collapsed:
virtual void ItemExpand(
INT nActionTVE = TVE_TOGGLE,
bool bRedraw = true
You can override the
CExtPropertyGridCtrl::OnPgcCreateGrids() virtual method in order to create a
CExtPropertyGridWndCategorized-derived property grid in which the
CExtTreeGridWnd::ItemExpand() virtual method is overridden (do to forget to call the
ItemExpand() method of the base class).
You may also need to make a conversion between handles to
HTREEITEM items of the tree grid and pointers to
CExtPropertyItem items of the property grid. You can use the
CExtPropertyGridWnd::PropertyItemFromTreeItem() methods for that.
What is the Prof-UIS property grid?
The Prof-UIS property grid is a set of C++ classes that allows you implement a modern, feature-rich Visual Studio .Net like property grid window for browsing and editing properties of objects of any complexity.
What is the combine operation with regard to the property grid?
The Prof-UIS property grid features displaying and editing properties of more than one object. Each object has its own tree of properties that is described by its property store (the
class). You can create a separate instance of
and combine properties of several objects in it so that you can subsequently display the combined property store in the property grid:
m_PropertyStoreCompoundSelection.Combine( m_wndStatic1.GetPropertyStore() );
m_PropertyStoreCompoundSelection.Combine( m_wndStatic2.GetPropertyStore() );
Is it possible to use the Prof-UIS property grid as a control in a MFC project that does not use other Prof-UIS controls?
Yes, you can use the Prof-UIS property grid as a standalone control.
If you have any questions, please visit our forum or contact our technical support team at email@example.com.