A grid control is similar to a normal list control, except that each sub-item is editable. Sub-items can contain text values (for editing), dropdown lists, filename browsers or pretty much any type imaginable.
Just as my other property controls (the PropertyList and PropertyTree controls),
it's using the same selection of in-place editors, ranging from dropdown lists to filename browsers.
They are all implemented as standard windows, which link to the parent control through a generic 
interface and some shared window messages.
Because of this design, you may extend the control with your own property types.
The control is a subclassed ListView control. 
The nice thing about this grid control is that it uses the same navigation as a normal spreadsheet grid, and that it has many familiar keyboard-shortcuts (F2 key and space works as expected). It doesn't do sofisticated row/column selection or copy/paste functionality, but for a fast type-in grid control it's very nice.
How to use it
Place aListView control on a dialog.
Add a member variable to your dialog class...
CPropertyGridCtrl m_GridOnInitDialog() event handler, add the following line:
LRESULT OnInitDialog(UINT /*uMsg*/, WPARAM /*wParam*/, LPA...
{
  ...
  m_Grid.SubclassWindow(GetDlgItem(IDC_LIST1));
  ...
}BEGIN_MSG_MAP(CMainDlg)
  ...
  REFLECT_NOTIFICATIONS()
END_MSG_MAP()Here are some of the control methods available:
InsertItem
SetSubItem
GetItemText
GetItemValue
SetItemValue
GetItemEnabled
GetItemEnabled
GetItemData
SetItemDataCListViewCtrl methods still work as well.
Just like the ListView control, you need to add column headers first.
  m_Grid.InsertColumn(0, "Name", LVCFMT_LEFT, 200, 0);Adding a new property requires using a "creation helper" method...
  m_Grid.InsertItem(0, PropCreateSimple("", "Raymond"), 0);
  m_Grid.SetSubItem(0, 1, PropCreateSimple("", false));
  m_Grid.SetSubItem(0, 2, PropCreateCheckButton("", true));You may also associate some item-data to each property using the
SetItemData() method, 
so it can later be identified.
The PropertyList control sample explains how to use some of the other editors.
Several notifications are sent back to the owner window. 
They contain information about the changing property using 
WM_NOTIFY notification structure: NMPROPERTYITEM.
The list of notifications currently include:
PIN_SELCHANGED
PIN_ITEMCHANGING
PIN_ITEMCHANGED
PIN_BROWSE
PIN_CLICKListView notifications are also
available. Use the GetSelectedIndex() and GetSelectedColumn()
methods to located the selected property.
Source Code Dependencies
Microsoft Visual C++ 6.0Microsoft WTL 3.1 Library
See Also
My Property List controlMy Property Tree control
My ChoiceBar control for adding your own pop-ups
Download Files
|  | Source Code and sample (58 Kb) | 


