SetWindowLong 用法总结
2016-03-25 16:34
344 查看
转载地址:http://blog.csdn.net/firehood_/article/details/6167085
SetWindowLong 函数原型为:LONG SetWindowLong(HWND hwnd,int nIndex,Long dwNewLong);详见MSDN。
下面简单总结一下SetWindowLong函数几种常用的地方:
1.设置窗口风格
如:SetWindowLong(hWnd, GWL_STYLE, WS_POPUP|WS_BORDER); //有边框的弹出窗口
SetWindowLong(hWnd, GWL_EXSTYLE, WS_EX_TOOLWINDOW); //设置窗口扩展样式为WS_EX_TOOLWINDOW,可以让窗体不在任务栏中显示。
2.消息处理函数的转移
对于WINDOWS控件,比如编辑框,按钮,这些控件消息处理函数是由系统定义好了的。
但如果我们需要对控件消息进行特殊处理时,可以指定一个消息处理函数,替换原来的消息处理函数。
自己的处理完成后,再调用控件的缺省消息处理。
以IE WebBrowser控件为例,我们需要让IE支持滑屏翻页操作,就需要让WebBrowser控件对WM_MOUSEMOVE消息做出响应,但WebBrowser控件默认处理函数是不处理WM_MOUSEMOVE消息的。所以这里我们重新定义一个WebBrowser窗口的过程处理函数来替换原有的过程处理函数。代码如下:
[cpp]
view plain
copy
print?
// 定义WebBrowser窗口的过程处理函数
static LRESULT CALLBACK WebbrowserProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
// 保存WebBrowser原来的过程处理函数
WNDPROC m_pPreProcWebbrowser;
LRESULT CALLBACK CMainWnd::WebbrowserProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
// 获取对象指针
CMainWnd *pMainWnd = (CMainWnd *)GetWindowLong(hWnd,GWL_USERDATA);
if(pMainWnd->_hWndBrowser == hWnd)
{
switch(msg)
{
case WM_MOUSEMOVE:
//TODO:place code here
break;
}
return CallWindowProc(pMainWnd->m_pPreProcWebbrowser,hWnd,msg,wParam,lParam);
}
}
这种方法也是前面讲的《WINCE IE浏览器定制--支持触摸屏滑动操作》另一种处理方式。
3.保存与窗口相关联的长值
上面代码中因为窗口处理函数WebbrowserProc必须是静态的,而静态函数是无法访问类的成员变量和函数的。因此这里又用SetWindowLong函数在创建完WebBrowser窗体完之后保存当前对象指针然后,然后在窗口处理函数中调用GetWindowLong获取对象指针,这样就可以通过该对象指针来访问类的成员变量和函数了。这里又体现了SetWindowLong的另一种用法。
SetWindowLong 函数原型为:LONG SetWindowLong(HWND hwnd,int nIndex,Long dwNewLong);详见MSDN。
下面简单总结一下SetWindowLong函数几种常用的地方:
1.设置窗口风格
如:SetWindowLong(hWnd, GWL_STYLE, WS_POPUP|WS_BORDER); //有边框的弹出窗口
SetWindowLong(hWnd, GWL_EXSTYLE, WS_EX_TOOLWINDOW); //设置窗口扩展样式为WS_EX_TOOLWINDOW,可以让窗体不在任务栏中显示。
2.消息处理函数的转移
对于WINDOWS控件,比如编辑框,按钮,这些控件消息处理函数是由系统定义好了的。
但如果我们需要对控件消息进行特殊处理时,可以指定一个消息处理函数,替换原来的消息处理函数。
自己的处理完成后,再调用控件的缺省消息处理。
以IE WebBrowser控件为例,我们需要让IE支持滑屏翻页操作,就需要让WebBrowser控件对WM_MOUSEMOVE消息做出响应,但WebBrowser控件默认处理函数是不处理WM_MOUSEMOVE消息的。所以这里我们重新定义一个WebBrowser窗口的过程处理函数来替换原有的过程处理函数。代码如下:
[cpp]
view plain
copy
print?
// 定义WebBrowser窗口的过程处理函数
static LRESULT CALLBACK WebbrowserProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
// 保存WebBrowser原来的过程处理函数
WNDPROC m_pPreProcWebbrowser;
LRESULT CALLBACK CMainWnd::WebbrowserProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
// 获取对象指针
CMainWnd *pMainWnd = (CMainWnd *)GetWindowLong(hWnd,GWL_USERDATA);
if(pMainWnd->_hWndBrowser == hWnd)
{
switch(msg)
{
case WM_MOUSEMOVE:
//TODO:place code here
break;
}
return CallWindowProc(pMainWnd->m_pPreProcWebbrowser,hWnd,msg,wParam,lParam);
}
}
[cpp] view plain copy print? // 创建WebBrowser窗体 if (!(_hWndBrowser = CreateBrowser())) return FALSE; // 保存当前对象指针 SetWindowLong(_hWndBrowser, GWL_USERDATA, (LONG)this); // 设置新的消息处理函数 m_pPreProcWebbrowser=(WNDPROC)SetWindowLong(_hWndBrowser,GWL_WNDPROC,(LONG)WebbrowserProc); // 创建WebBrowser窗体 if (!(_hWndBrowser = CreateBrowser())) return FALSE; // 保存当前对象指针 SetWindowLong(_hWndBrowser, GWL_USERDATA, (LONG)this); // 设置新的消息处理函数 m_pPreProcWebbrowser=(WNDPROC)SetWindowLong(_hWndBrowser,GWL_WNDPROC,(LONG)WebbrowserProc);
这种方法也是前面讲的《WINCE IE浏览器定制--支持触摸屏滑动操作》另一种处理方式。
3.保存与窗口相关联的长值
上面代码中因为窗口处理函数WebbrowserProc必须是静态的,而静态函数是无法访问类的成员变量和函数的。因此这里又用SetWindowLong函数在创建完WebBrowser窗体完之后保存当前对象指针然后,然后在窗口处理函数中调用GetWindowLong获取对象指针,这样就可以通过该对象指针来访问类的成员变量和函数了。这里又体现了SetWindowLong的另一种用法。
相关文章推荐
- 利用webstrom的宏,保存文件自动格式化代码
- 四大组件之ContentProvider
- react-native开源组件react-native-wechat学习
- 《内核设计与实现》第十八章读书笔记
- bzoj2467 生成树 Matrix-tree定理
- MapReduce-Counter使用-快速实现大文件行数的统计
- Nginx+tomcat 实现负载均衡和动静分离
- MIPS cache指令
- hjr-四旋翼飞行器串级PID飞控算法
- C#——Random类猜数字
- Linux系统iNode耗尽硬盘无法写入文件怎么办?
- GetMemory的几个笔试题 面试碰到两次
- Obj-C语言开发iOS项目使用反射减少代码工作 (转载他人)
- BouncyCastle not registered
- 最长公共子子串 java
- [转]SpringMVC日期类型转换问题三大处理方法归纳
- JAVA基础--继承和权限控制
- mysql各种引擎的比较
- 函数模板
- 语音识别工具箱之HTK安装与使用