CMFCPropertyGridCtrl
2013-09-09 13:49
531 查看
用vs2010建立一个基于对话框的MFC工程,拖一个CMFCPropertyGridCtrl进去,大小调整好。(注:首先采用的是静态创建的办法,大部分需要的属性在对话框编辑界面就可以编辑。)然后为该控件更改ID为IDC_MFCPROPERTYGRID_TEST,并且使用ClassWizard为控件添加一个变量m_propertyGrid。
接下来更改控件的一些属性。
其实这不就是个CMFCPropertyGridCtrl控件么。Border神马的基础东西就不说了。
"Description Rows Count"指的是下面的描述部分有几行。
"Enable Description Area"表示是否启动下面的描述功能
"Enable Header"表示是否启动表头
"Mark Modified Properties"表示是否着重显示更改项
可以按照需求来进行设置。这里先使用默认的设置。先编译运行一下,比较简陋。
好,接下来该添加东西进去了。
在OnInitDialog中添加如下代码,我会一行一行解释。
第一行是建立一个新的项目,也是最普通的项目,CMFCPropertyGridProperty。与这种项目同级的还有CMFCPropertyGridColorProperty、CMFCPropertyGridFontProperty以及CMFCPropertyGridFileProperty,等会都可以试一下。调用构造函数时传入的三个参数分别是条目名称、默认选项及描述文字。运行一下就知分晓。
饿滴神啊,肿么这个样子。不过该有的全有,只需要设置一下就行。这里得提一笔,微软似乎非常喜欢把第一列的宽度设置为“只能容得下一个普通的5号小宋体的宽度”,不光是CMFCPropertyGrid,连CListCtrl也是如此,需要动点特殊的手段才能调整过来。在这段代码的前面加这么几句:
如此再运行,就会比较好看了。
好,接下来我们看一下右边的value部分还能换成神马东西。
如同vs2010里提供的“属性”栏一样,这CMFCPropertyGridCtrl应该也支持下拉菜单,好,就来添加下拉菜单看看。修改刚才的代码:
然后运行,就会如愿以偿地出现下拉框了。
接下来是另外三个同级的项目:
注:每一种类型的项目都有2个或3个重载函数,可以自己根据需求慢慢挖掘,在这里就不赘述了。
运行效果如下:
这么些不同种类的东西乱七八糟堆在一起,是不是有点不科学?那么就引入下一个概念:分组。回到第一张图,vs2010的“属性”栏分了三个组,分别是Apperance、Behavior和Misc,看起来就清晰多了,我们也可以。
好,来重新构建一下我们的代码:
编译运行效果如下:
至此,静态创建CMFCPropertyGridCtrl的方法就结束了。
还有一种方法是动态创建,与CStatic、CEdit等控件无二,在创建之后也可以利用自带的函数修改控件的属性,如:
更多属性留待各位发掘一下啦。
CMFCPropertyGridProperty* pProp1 = new CMFCPropertyGridProperty(strTitle, (_variant_t)bVal, strDesc);
pProp1->SetData(100);
int nPropId = pProp1->GetData();
//声明消息处理函数
afx_msg LRESULT OnPropertyChanged( WPARAM wParam,LPARAM lParam );
//注册消息, AFX_WM_PROPERTY_CHANGED:发送ctrl消息到父窗口
BEGIN_MESSAGE_MAP(CMyWnd, CWnd)
ON_WM_PAINT()
ON_WM_CREATE()
ON_REGISTERED_MESSAGE(AFX_WM_PROPERTY_CHANGED, OnPropertyChanged)
END_MESSAGE_MAP()
//消息处理, lParam是Property属性项, wParam是ctrl的id
LRESULT CMyWnd::OnPropertyChanged( WPARAM wParam,LPARAM lParam )
{
CMFCPropertyGridProperty* pProp = (CMFCPropertyGridProperty*) lParam;
//is the property ctrl
if ( (long)wParam == 2 )
{
}
pProp->SetValue((_variant_t)false);
pProp->Redraw();
int pID = pProp->GetData();
CString str = pProp->GetName();
if ( str == _T("abc") )
{
COleVariant var = pProp->GetValue();
if ( var.boolVal == VARIANT_TRUE )
{
// AfxMessageBox(L"failed!");
//pProp->SetValue(VARIANT_FALSE);
}
}
if (pID == 1)
{
}
if (pID > 1)
{
}
return 0;
}
【ZZ】COleVariant与常用基本数据类型之间的转换
COleVariant是数据库常用到的数据类型。它可以是字串,整型值,日期等。知道怎样将它转换为CString很有用处。
设有CString A; COleVariant B; 来看看怎样将COleVariant转换为CString:
switch(B.vt){
case VT_BSTR: A=V_BSTRT(&B); break;//COleVariant是一个字串
case VT_I2: A.Format(_T("%hd"),V_I2(&B));break;//是短整型
case VT_I4: A.Format(_T("%d"),V_I4(&B));break;//是长整型
case VT_R4: A.Format(_T("%e"),(double)V_R4(&B));break;//是浮点数
case VT_R8: A.Format(_T("%e"),V_R8(&B));break;//是浮点数
case VT_CY: A=COleCurrency(B).Format();break;//是货币值
case VT_DATE: A=COleDateTime(B).Format("%Y-%m-%d");break;//是日期
case VT_BOOL: A=V_BOOL(&B)?"True":"False";break;//是布尔值
}
//----------------------------------------------------------------------------------------------------------
我发现 A=V_BSTRT(&B); 只能传递一个字符,有问题。
用下面这个方法,两句话就直接可以解决。哈哈,有时网上的东西还是要思考下
B.ChangeType(VT_BSTR);
A=B.bstrVal;
接下来更改控件的一些属性。
其实这不就是个CMFCPropertyGridCtrl控件么。Border神马的基础东西就不说了。
"Description Rows Count"指的是下面的描述部分有几行。
"Enable Description Area"表示是否启动下面的描述功能
"Enable Header"表示是否启动表头
"Mark Modified Properties"表示是否着重显示更改项
可以按照需求来进行设置。这里先使用默认的设置。先编译运行一下,比较简陋。
好,接下来该添加东西进去了。
在OnInitDialog中添加如下代码,我会一行一行解释。
CMFCPropertyGridProperty * pProp1 = new CMFCPropertyGridProperty( _T("天朝适合生存吗?"), _T("51CTO不谈政治"), _T("这是描述部分")); m_propertyGrid.AddProperty(pProp1);
第一行是建立一个新的项目,也是最普通的项目,CMFCPropertyGridProperty。与这种项目同级的还有CMFCPropertyGridColorProperty、CMFCPropertyGridFontProperty以及CMFCPropertyGridFileProperty,等会都可以试一下。调用构造函数时传入的三个参数分别是条目名称、默认选项及描述文字。运行一下就知分晓。
饿滴神啊,肿么这个样子。不过该有的全有,只需要设置一下就行。这里得提一笔,微软似乎非常喜欢把第一列的宽度设置为“只能容得下一个普通的5号小宋体的宽度”,不光是CMFCPropertyGrid,连CListCtrl也是如此,需要动点特殊的手段才能调整过来。在这段代码的前面加这么几句:
HDITEM item; item.cxy=120; item.mask=HDI_WIDTH; m_propertyGrid.GetHeaderCtrl().SetItem(0, new HDITEM(item));
如此再运行,就会比较好看了。
好,接下来我们看一下右边的value部分还能换成神马东西。
如同vs2010里提供的“属性”栏一样,这CMFCPropertyGridCtrl应该也支持下拉菜单,好,就来添加下拉菜单看看。修改刚才的代码:
CMFCPropertyGridProperty* pProp2 = new CMFCPropertyGridProperty( _T("我是不是帅哥?"), _T("看选项"), _T("")); pProp2->AddOption(_T("是")); pProp2->AddOption(_T("肯定是")); pProp2->AddOption(_T("绝对是")); pProp2->AllowEdit(FALSE); //不允许对选项进行编辑 m_propertyGrid.AddProperty(pProp2);
然后运行,就会如愿以偿地出现下拉框了。
接下来是另外三个同级的项目:
CMFCPropertyGridColorProperty * pProp3 = new CMFCPropertyGridColorProperty( _T("颜色"), RGB(0, 111, 200)); m_propertyGrid.AddProperty(pProp3); CMFCPropertyGridFileProperty * pProp4 = new CMFCPropertyGridFileProperty( _T("打开文件"), TRUE, _T("D://test.txt")); m_propertyGrid.AddProperty(pProp4); LOGFONT font = {NULL}; CMFCPropertyGridFontProperty * pProp5 = new CMFCPropertyGridFontProperty( _T("选择字体"), font); m_propertyGrid.AddProperty(pProp5);
注:每一种类型的项目都有2个或3个重载函数,可以自己根据需求慢慢挖掘,在这里就不赘述了。
运行效果如下:
这么些不同种类的东西乱七八糟堆在一起,是不是有点不科学?那么就引入下一个概念:分组。回到第一张图,vs2010的“属性”栏分了三个组,分别是Apperance、Behavior和Misc,看起来就清晰多了,我们也可以。
好,来重新构建一下我们的代码:
CMFCPropertyGridProperty * group1 = new CMFCPropertyGridProperty(_T("分组1")); CMFCPropertyGridProperty * group2 = new CMFCPropertyGridProperty(_T("分组2")); group1->AddSubItem(pProp1); group1->AddSubItem(pProp2); group2->AddSubItem(pProp3); group2->AddSubItem(pProp4); group2->AddSubItem(pProp5); m_propertyGrid.AddProperty(group1); m_propertyGrid.AddProperty(group2);
编译运行效果如下:
至此,静态创建CMFCPropertyGridCtrl的方法就结束了。
还有一种方法是动态创建,与CStatic、CEdit等控件无二,在创建之后也可以利用自带的函数修改控件的属性,如:
CMFCPropertyGridCtrl * propertyGrid = new CMFCPropertyGridCtrl; propertyGrid->Create(WS_CHILD | WS_BORDER | WS_VISIBLE, CRect(400, 100, 600, 200), this, WM_USER + 100); propertyGrid->EnableHeaderCtrl(TRUE); //使用表头 propertyGrid->SetVSDotNetLook(); //使用样式 propertyGrid->MarkModifiedProperties(); //着重显示更改过的部分
更多属性留待各位发掘一下啦。
CMFCPropertyGridCtrl的属性改变事件代码
//用于区分Prop,使用SetData, GetData方法CMFCPropertyGridProperty* pProp1 = new CMFCPropertyGridProperty(strTitle, (_variant_t)bVal, strDesc);
pProp1->SetData(100);
int nPropId = pProp1->GetData();
//声明消息处理函数
afx_msg LRESULT OnPropertyChanged( WPARAM wParam,LPARAM lParam );
//注册消息, AFX_WM_PROPERTY_CHANGED:发送ctrl消息到父窗口
BEGIN_MESSAGE_MAP(CMyWnd, CWnd)
ON_WM_PAINT()
ON_WM_CREATE()
ON_REGISTERED_MESSAGE(AFX_WM_PROPERTY_CHANGED, OnPropertyChanged)
END_MESSAGE_MAP()
//消息处理, lParam是Property属性项, wParam是ctrl的id
LRESULT CMyWnd::OnPropertyChanged( WPARAM wParam,LPARAM lParam )
{
CMFCPropertyGridProperty* pProp = (CMFCPropertyGridProperty*) lParam;
//is the property ctrl
if ( (long)wParam == 2 )
{
}
pProp->SetValue((_variant_t)false);
pProp->Redraw();
int pID = pProp->GetData();
CString str = pProp->GetName();
if ( str == _T("abc") )
{
COleVariant var = pProp->GetValue();
if ( var.boolVal == VARIANT_TRUE )
{
// AfxMessageBox(L"failed!");
//pProp->SetValue(VARIANT_FALSE);
}
}
if (pID == 1)
{
}
if (pID > 1)
{
}
return 0;
}
【ZZ】COleVariant与常用基本数据类型之间的转换
COleVariant是数据库常用到的数据类型。它可以是字串,整型值,日期等。知道怎样将它转换为CString很有用处。
设有CString A; COleVariant B; 来看看怎样将COleVariant转换为CString:
switch(B.vt){
case VT_BSTR: A=V_BSTRT(&B); break;//COleVariant是一个字串
case VT_I2: A.Format(_T("%hd"),V_I2(&B));break;//是短整型
case VT_I4: A.Format(_T("%d"),V_I4(&B));break;//是长整型
case VT_R4: A.Format(_T("%e"),(double)V_R4(&B));break;//是浮点数
case VT_R8: A.Format(_T("%e"),V_R8(&B));break;//是浮点数
case VT_CY: A=COleCurrency(B).Format();break;//是货币值
case VT_DATE: A=COleDateTime(B).Format("%Y-%m-%d");break;//是日期
case VT_BOOL: A=V_BOOL(&B)?"True":"False";break;//是布尔值
}
//----------------------------------------------------------------------------------------------------------
我发现 A=V_BSTRT(&B); 只能传递一个字符,有问题。
用下面这个方法,两句话就直接可以解决。哈哈,有时网上的东西还是要思考下
B.ChangeType(VT_BSTR);
A=B.bstrVal;
相关文章推荐
- CMFCPropertyGridCtrl: How to Validate and Update Data?
- 【框架-MFC】CMFCPropertyGridCtrl(chenlu1):属性值改变事件的触发与处理
- CMFCPropertyGridCtrl 的简单教程
- Accelerators processing before CMFCPropertyGridCtrl
- C++ 关于 CMFCPropertyGridCtrl 的使用方法 之一 (原创)
- VS08SP1中CMFCPropertyGridCtrl的基本用法
- VS2012下实现CMFCPropertyGridCtrl 内添加日期时间控件
- MFC Feature Pack CMFCPropertyGridCtrl控件的应用
- CMFCPropertyGridCtrl 使用简记
- CMFCPropertyGridCtrl
- CMFCPropertyGridCtrl响应消息
- CMFCPropertyGridCtrl 使用简记
- C++ 关于 CMFCPropertyGridCtrl 的使用方法 之二 (原创)
- MFC Feature Pack CMFCPropertyGridCtrl 控件的例子
- CMFCPropertyGridCtrl 使用简记
- CMFCPropertyGridCtrl,CMFCPropertyGridProperty 响应消息
- C++ 关于 CMFCPropertyGridCtrl 的使用方法
- MFC Feature Pack CMFCPropertyGridCtrl控件的应用
- CMFCPropertyGridCtrl 的简单教程
- 使用CMFCPropertyGridCtrl及CMFCPropertyGridProperty控件的心得体会