SetProp()、GetProp()、RemoveProp() API接口

感觉这三个接口很少看到,所以就整理了下

1.功能介绍

网站来源:http://blog.csdn.net/ly131420/article/details/8865845

在windows界面设计中,我们和窗口的接触比较多,但是这三个api接口却很少用到,即:SetProp、GetProp、RemoveProp这三个API接口,实际上这三个API接口是和窗口句柄关联起来的,这个非常重要,因为他们可以给窗口设置添加、删除新属性,这就扩展了窗口的关联数据,使得我们可以把任何数据关联到窗口上,在设计一些界面架构上则可以用到这些接口,直接把窗口句柄和对象关联起来,把对窗口过程的处理转换成了对象事件的处理,对面向对象的变成更加的符合逻辑性,在Delphi的框架VCL框架上就是采用了这种方法,使得Delphi在界面开发上非常的高效,当然性能上要比MFC低,但是MFC牺牲了更加合理的事件处理方式,更多的都是在窗口过程中处理事件,使得MFC设计界面相对困难些了。

2.用法介绍

2.1 SetProp()

函数功能:该函数在指定窗口的属性表中增加一个新项,或者修改一个现有项。如果指定的字符串不在属性表中,那么就增加该新的项,新项中包含该字符串和句柄,否则就用指定的句柄替换该字符串的全前句柄。
函数原型:BOOL SetProp(HWND hWnd,LPCTSTR lpString,HANDLE hData)
参数:
hWnd:指向窗口的句柄,该窗口的属性表要接收一个新项。
lpString:指向以null结尾的字符串指针,或者包含一个标识字符串的原子。如果该参数是一个原子,那么它必须是以前使用GlobalAddAtom函数创建的。原子是16位的数据值,它必须是放置在lpstring参数低位字中,而高位字必须为O。
hData:指向要拷贝到属性表中的数据的句柄。该数据句柄可以标识任何对应用程序有用的值。
返回值:如果该数据句柄和字符串以加到属性表中,那么返回值为非零。如果该函数失败,那么返回为零。若想获得更多错误信息,请调用GetLastError函数。
备注:在清除窗口之前(也就是在处理WM_NCDESTROY消息之前),应用程序必须把它加到属性表的所项清除。应用程序必须使用RemoveProp函数来清除这些项。

2.2GetProp()

函数功能:该函数从给定窗口的属性列表中检索数据句柄。给定的字符串标识了要检索的句柄。该字符串和句柄必须在前一次调用SetProp函数时已经加到属性表中。
函数原型:HANDLE GetProp(HWND hWnd,LPCTSTR lpString);
参数:
hWnd:指向要搜索属性表的窗口。
LpString:指向以null结尾的字符串指针,或者包含一个标识字符串的原子。如果该参数是一个原子,那么它必须是使用GlobalAddAtom函数创建的。原子是16位的数据值,它必须是放置在lpstring参数的低位率中,而高位字必须为O。
返回值:如果属性表中包含了给定的字符串,那么返回值为相关的数据句柄。否则,返回值为NULL。

2.3 RemoveProp()

函数功能:该函数从指定的窗口的属性表中删除一项。指定的字符串标识了要删除的项。
函数原型:HANDLE RemoveProp(HWND hWnd,LPCTSTR lpString);
参数:
hWnd:指向要改变属性项的窗口的句柄。
lpString:指向以null结尾的字符串指针,或者包含一个标识字符串的原子。如果该参数是一个原子,那么它必须是使用AddAtom函数创建的。原子是16位的数据值,它必须是放置在lpString参数的低位字中,
而高位率必须为0。
返回值:返回值标识了指定的字符串。如果该串无法在指定的属性表中发现,那么返回值为NULL。
备注:应用程序必须释放与从属性表中清除的项相关的数据句柄。应用程序只能清除它加入的那些属性它不能清除其他应用程序或系统本身加入的属性。
RemoveProp函数返回与该字符串相关的数据句柄,这样应用程序就可以释放与该句柄相关的数据。

3.代码示例

网站来源:http://blog.csdn.net/primer_programer/article/details/2050750

可以使用GetProp和SetProp函数来查找已经启动的程序的窗口。
使用SetProp向窗口的属性表中添加字符串。可以在对话框的OnInitDialog函数的最后添加下面语句。
::SetProp( this->m_hWnd, "字符串", (HANDLE)1 );
使用GetProp在窗口的属性表中查找字符串。
::GetProp(hwnd, "字符串") 
BOOL CAutoRunApp::ensureOneInstance()
{
	m_hMutex = CreateMutex( NULL, FALSE, _T( "AutoRun" ) );
	if ( m_hMutex )
	{
		if ( GetLastError() == 183 /*ERROR_ALREADY_EXISTS*/ )
		{
			CloseHandle( m_hMutex );
			HWND hWndPrevious = ::GetWindow( ::GetDesktopWindow(), GW_CHILD );
			while(::IsWindow(hWndPrevious))
			{
				if (::GetProp(hWndPrevious, EXEPROP))
				{
					if (::IsIconic(hWndPrevious))
					{
						::ShowWindow(hWndPrevious, SW_RESTORE);
						::SetForegroundWindow(hWndPrevious);
					}
					else
					{
						::SetForegroundWindow(::GetLastActivePopup(hWndPrevious));
					}
					return FALSE;
				}
				hWndPrevious = ::GetWindow( hWndPrevious, GW_HWNDNEXT );
			}
			return FALSE;
		}
	}
	return TRUE;
}

4.其他介绍

网站来源:http://blog.csdn.net/fengbangyue/article/details/5222185
http://bigboyzhang.phpfs.com/?p=29
也可以查看我的文章中的 ”CListCtrl实现排序功能“里面也有用到SetProp和GetProp

SetProp()、GetProp()、RemoveProp() API接口

上一篇:Linux kali 3.14-kali1-amd64 编译安装 wine 1.7.33


下一篇:C# Winform里面用Console.WriteLine输出到哪了