SetWindowLong

SetWindowLong

函数功能      

该函数改变指定窗口的 属性函数也将指定的一个32位值设置在窗口的额外存储空间的指定偏移位置。

函数原型

       LONG SetWindowLong(HWND hWnd,int nlndex,LONG dwNewLong);
参数
    hWnd: 窗口句柄及间接给出的窗口所属的类。
 nlndex:指定将设定的大于等于0的偏移值。
          有效值范围从0到额外类的存储空间的字节数-4:例如若指定了12位或多于12位的额外类存储空间,则应设为第三个32位整数的索引位8。要设置其他任何值,
可以指定下面值之一:  
GWL_EXSTYLE:设定一个新的扩展 风格
GWL_STYLE:设定一个新的窗口风格。  
GWL_WNDPROC:为窗口过程设定一个新的 地址
GWL_ID:设置一个新的窗口标识符。
GWL_HINSTANCE:设置一个新的 应用程序事例句柄。
GWL_USERDATA:设置与 窗口有关的32位值。
每一个窗口均有一个由创建该窗口的应用程序使用的32位值。
当hWnd参数标识了一个 对话框时,也可使用下列值:
DWL_DLGPROC: 设置对话框过程的新地址。
DWL_MSGRESULT:设置在对话框过程中处理的消息的返回值。
DWL_USER:设置的应用程序私有的新的额外信息,例如一个句柄或指针。
dwNewLong:指定的替换值。
返回值:
如果函数成功,返回值是指定的32位整数的原来的值。
如果函数失败,返回值为0。若想获得更多错误信息,请调用GetLastError函数。
如果指定32位整数的原来的值为0,并且函数成功,则返回值为0,但是函数并不清除最后的错误信息,这就很难判断函数是否成功。这时,就应在调用SetWindowLong之前调用callingSetLastError(0)函数来清除最后的错误信息。这样,如果函数失败就会返回0,并且GetLastError。也返回一个非零值。   如果由hWnd参数指定的窗口与调用线程不属于同一进程,将导致SetWindowLong函数失败。
指定的窗口数据是在缓存中保存的,因此在调用SetWindowLong之后再调用SetWindowPos函数才能使SetWindowLong函数所作的改变生效。
如果使用带GWL_WNDPROC索引值的SetWindowLong函数替换窗口过程,则该窗口过程必须与WindowProccallback函数说明部分指定的指导行一致。
如果使用带DWL_MSGRESULT索引值的SetWindowLong函数来设置由一个对话框过程处理的消息的返回值,应在此后立即返回TRUE。否则,如果又调用了其他函数而使对话框过程接收到一个窗口消息,则嵌套的窗口消息可能改写使用DWL_MSGRESULT设定的返回值。
可以使用带GWL_WNDPROC索引值的SetWindowLong函数创建一个窗口类的子类,该窗口类是用于创建该窗口的关。一个应用程序可以一个系统美为于类,但是不能以一个其他进程产生的窗口类为子类,SetwindowLong函数通过改变与一个特殊的窗口类相联系的窗口过程来创建窗口子类,从而使系统调用新的窗口过程而不是以前定义的窗口过程。应用程序必须通过调用CallWindowProc函数向前窗口传递未被新窗口处理的消息,这样作允许应用程序创建一个窗口过程链。
通过使用函数RegisterClassEx将结构WNDCLASSEX中的cbWndExtra单元指定为一个非0值来保留新外窗口内存。
不能通过调用带GWL_HWNDPARENT索引值的SetWindowLong的函数来改变子窗口的父窗口,应使用SetParent函数。

你可能感兴趣的:(SetWindowLong)