目录:

1.Win32项目的windows窗体程序的向导生成了如下代码

2.手工生成代码如下

3.当消息队列中没有消息需要处理,我们可以利用这段时间处理我们自己的任务


1.Win32项目的windows窗体程序的向导生成了如下代码:

[cpp] view plaincopy
  1. // Timer.cpp : 定义应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #include "Timer.h"
  5. #define MAX_LOADSTRING 100
  6. // 全局变量:
  7. HINSTANCE hInst;                                // 当前实例
  8. TCHAR szTitle[MAX_LOADSTRING];                  // 标题栏文本
  9. TCHAR szWindowClass[MAX_LOADSTRING];            // 主窗口类名
  10. // 此代码模块中包含的函数的前向声明:
  11. ATOM                MyRegisterClass(HINSTANCE hInstance);
  12. BOOL                InitInstance(HINSTANCE, int);
  13. LRESULT CALLBACK    WndProc(HWND, UINT, WPARAM, LPARAM);
  14. INT_PTR CALLBACK    About(HWND, UINT, WPARAM, LPARAM);
  15. int APIENTRY _tWinMain(HINSTANCE hInstance,
  16. HINSTANCE hPrevInstance,
  17. LPTSTR    lpCmdLine,
  18. int       nCmdShow)
  19. {
  20. UNREFERENCED_PARAMETER(hPrevInstance);
  21. UNREFERENCED_PARAMETER(lpCmdLine);
  22. // TODO: 在此放置代码。
  23. MSG msg;
  24. HACCEL hAccelTable;
  25. // 初始化全局字符串
  26. LoadString(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING);   ///加载标题栏字符串
  27. LoadString(hInstance, IDC_TIMER, szWindowClass, MAX_LOADSTRING);  ///加载“关于对话框”
  28. MyRegisterClass(hInstance);
  29. // 执行应用程序初始化:
  30. if (!InitInstance (hInstance, nCmdShow))
  31. {
  32. return FALSE;
  33. }
  34. /*函数原型:int TranslateAccelerator(HWND hWnd,HACCEL hAccTable,LPMSG IpMsg);
  35. 函数功能:翻译加速键表。该函数处理菜单命令中的加速键。该函数将一个WM_KEYDOWN或WM_SYSKEYDOWN消息翻译
  36. 成一个WM_COMMAND或WM_SYSCOMMAND消息(如果在给定的加速键表中有该键的入口),然后将WM_COMMAND或
  37. WM_SYSCOMMAND消息直接送到相应的窗口处理过程。
  38. TranslateAccelerator直到窗口过程处理完消息后才返回。
  39. 参数:
  40. hWnd:窗口句柄,该窗口的消息将被翻译。
  41. hAccTable:加速键表句柄。加速键表必须由LoadAccelerators函数调用装入或由CreateAccd_eratorTable函数调用创建。
  42. LpMsg:MSG结构指针,MSG结构中包含了从使用GetMessage或PeekMessage函数调用线程消息队列中得到的消息内容。
  43. 返回值:若函数调用成功,则返回非零值;若函数调用失败,则返回值为零。若要获得更多的错误信息,可调用GetLastError函数。
  44. */
  45. hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_TIMER));
  46. // 主消息循环:
  47. while (GetMessage(&msg, NULL, 0, 0))
  48. {
  49. if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg))
  50. {
  51. TranslateMessage(&msg);
  52. DispatchMessage(&msg);
  53. }
  54. }
  55. return (int) msg.wParam;
  56. }
  57. //
  58. //  函数: MyRegisterClass()
  59. //
  60. //  目的: 注册窗口类。
  61. //
  62. //  注释:
  63. //
  64. //    仅当希望
  65. //    此代码与添加到 Windows 95 中的“RegisterClassEx”
  66. //    函数之前的 Win32 系统兼容时,才需要此函数及其用法。调用此函数十分重要,
  67. //    这样应用程序就可以获得关联的
  68. //    “格式正确的”小图标。
  69. //
  70. ATOM MyRegisterClass(HINSTANCE hInstance)
  71. {
  72. WNDCLASSEX wcex;
  73. wcex.cbSize = sizeof(WNDCLASSEX);   ///注册类对象的大小
  74. wcex.style          = CS_HREDRAW | CS_VREDRAW;   ///注册类的风格
  75. wcex.lpfnWndProc    = WndProc;   ///消息处理函数
  76. wcex.cbClsExtra     = 0;
  77. wcex.cbWndExtra     = 0;
  78. wcex.hInstance      = hInstance;  ///应用程序实例句柄,系统提供的
  79. wcex.hIcon          = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_TIMER));   ///图标
  80. wcex.hCursor        = LoadCursor(NULL, IDC_ARROW);   ///光标
  81. wcex.hbrBackground  = (HBRUSH)(COLOR_WINDOW+1);   ///背景画刷设定
  82. wcex.lpszMenuName   = /*MAKEINTRESOURCE(IDC_TIMER)*/NULL;      ///菜单
  83. wcex.lpszClassName  = szWindowClass;    //注册类
  84. wcex.hIconSm        = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL));  ///小图标
  85. return RegisterClassEx(&wcex);
  86. }
  87. //
  88. //   函数: InitInstance(HINSTANCE, int)
  89. //
  90. //   目的: 保存实例句柄并创建主窗口
  91. //
  92. //   注释:
  93. //
  94. //        在此函数中,我们在全局变量中保存实例句柄并
  95. //        创建和显示主程序窗口。
  96. //
  97. BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)
  98. {
  99. HWND hWnd;
  100. hInst = hInstance; // 将实例句柄存储在全局变量中
  101. hWnd = CreateWindow(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW,
  102. CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, NULL, NULL, hInstance, NULL);
  103. if (!hWnd)
  104. {
  105. return FALSE;
  106. }
  107. ///MoveWindow(hWnd,100,100,640,320,true);
  108. ShowWindow(hWnd, nCmdShow);
  109. UpdateWindow(hWnd);
  110. return TRUE;
  111. }
  112. //
  113. //  函数: WndProc(HWND, UINT, WPARAM, LPARAM)
  114. //
  115. //  目的: 处理主窗口的消息。
  116. //
  117. //  WM_COMMAND  - 处理应用程序菜单
  118. //  WM_PAINT    - 绘制主窗口
  119. //  WM_DESTROY  - 发送退出消息并返回
  120. //
  121. //
  122. LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
  123. {
  124. int wmId, wmEvent;
  125. PAINTSTRUCT ps;
  126. HDC hdc;
  127. switch (message)
  128. {
  129. case WM_COMMAND:
  130. wmId    = LOWORD(wParam);
  131. wmEvent = HIWORD(wParam);
  132. // 分析菜单选择:
  133. switch (wmId)
  134. {
  135. case IDM_ABOUT:
  136. DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);
  137. break;
  138. case IDM_EXIT:
  139. DestroyWindow(hWnd);
  140. break;
  141. default:
  142. return DefWindowProc(hWnd, message, wParam, lParam);
  143. }
  144. break;
  145. case WM_PAINT:
  146. hdc = BeginPaint(hWnd, &ps);
  147. // TODO: 在此添加任意绘图代码...
  148. EndPaint(hWnd, &ps);
  149. break;
  150. case WM_DESTROY:
  151. PostQuitMessage(0);
  152. break;
  153. default:
  154. return DefWindowProc(hWnd, message, wParam, lParam);
  155. }
  156. return 0;
  157. }
  158. // “关于”框的消息处理程序。
  159. INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
  160. {
  161. UNREFERENCED_PARAMETER(lParam);
  162. switch (message)
  163. {
  164. case WM_INITDIALOG:
  165. return (INT_PTR)TRUE;
  166. case WM_COMMAND:
  167. if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
  168. {
  169. EndDialog(hDlg, LOWORD(wParam));
  170. return (INT_PTR)TRUE;
  171. }
  172. break;
  173. }
  174. return (INT_PTR)FALSE;
  175. }


2.手工生成代码如下:

[cpp] view plaincopy
  1. #include <windows.h>
  2. void MyPaint(HDC hdc, LPARAM lParam )
  3. {
  4. //绘图代码
  5. }
  6. //我的消息过程处理函数
  7. LRESULT CALLBACK WndProc( HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
  8. {
  9. PAINTSTRUCT ps;
  10. HDC hdc;
  11. switch (message)
  12. {
  13. case WM_PAINT:
  14. hdc = BeginPaint(hWnd, &ps);
  15. EndPaint(hWnd,&ps);
  16. break;
  17. case WM_MOUSEMOVE:
  18. hdc = GetDC(hWnd);
  19. MyPaint(hdc,lParam);
  20. ReleaseDC(hWnd,hdc);
  21. break;
  22. case WM_DESTROY:
  23. PostQuitMessage(0);
  24. break;
  25. default:
  26. return DefWindowProc(hWnd, message,wParam,lParam);
  27. }
  28. return 0;
  29. }
  30. //初始化实例函数
  31. BOOL InistInstance( HINSTANCE hInstance, int nCmdShow)
  32. {
  33. HWND hWnd;
  34. hWnd = CreateWindow("canvas","绘图窗口",WS_OVERLAPPEDWINDOW, 350,110,CW_USEDEFAULT,50,NULL,NULL,hInstance,NULL);
  35. if ( !hWnd )
  36. {
  37. return FALSE;
  38. }
  39. MoveWindow( hWnd,350,110,450,250,true);
  40. ShowWindow( hWnd, nCmdShow);
  41. UpdateWindow( hWnd);
  42. return TRUE;
  43. }
  44. //我的窗口注册函数
  45. ATOM MyRegisterClass(HINSTANCE hInstance)
  46. {
  47. WNDCLASSEX wcex;
  48. wcex.cbSize = sizeof(WNDCLASSEX);
  49. wcex.style = CS_HREDRAW | CS_VREDRAW;
  50. wcex.lpfnWndProc = (WNDPROC)WndProc;
  51. wcex.cbClsExtra = 0;
  52. wcex.cbWndExtra = 0;
  53. wcex.hInstance = hInstance;
  54. wcex.hIcon = NULL;
  55. wcex.hCursor = LoadCursor(NULL,IDC_ARROW);
  56. wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1 );
  57. wcex.lpszMenuName = NULL;
  58. wcex.lpszClassName = "canvas";
  59. wcex.hIconSm = NULL;
  60. return RegisterClassEx(&wcex);
  61. }
  62. //程序入口函数
  63. int APIENTRY WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow )
  64. {
  65. MSG msg;
  66. MyRegisterClass(hInstance);
  67. if ( !InistInstance(hInstance,nCmdShow))
  68. {
  69. return FALSE;
  70. }
  71. while ( GetMessage( &msg, NULL, 0, 0) )
  72. {
  73. TranslateMessage(&msg);
  74. DispatchMessage(&msg);
  75. }
  76. return msg.wParam;
  77. }


3.当消息队列中没有消息需要处理,我们可以利用这段时间处理我们自己的任务:

[cpp] view plaincopy
  1. // 消息循环
  2. MSG msg;
  3. ZeroMemory(&msg, sizeof(msg));   //这句特别重要,因为需要将msg初始化后才不会引起编译异常、运行异常
  4. while (msg.message!=WM_QUIT)
  5. {
  6. if (PeekMessage(&msg, NULL, 0U, 0U, PM_REMOVE))
  7. {
  8. TranslateMessage(&msg);
  9. DispatchMessage(&msg);
  10. }
  11. else
  12. {
  13. Direct3DRender();       // 绘制3D场景
  14. }
  15. }

VS2010 win32项目windows窗体程序 向导生成代码解析相关推荐

  1. C#面向对象程序设计课程实验二: 实验名称:Windows 窗体程序

    C#面向对象程序设计课程实验二: 实验名称:Windows 窗体程序 实验内容:Windows 窗体程序 一.实验目的及要求 二.实验环境 三.实验内容与步骤 一.设计简单的计算器 3.1.实验内容 ...

  2. 设计一个Windows窗体程序,设置程序,其运行结果如下图所示。垂直滚动条控制字体大小。

    设计一个Windows窗体程序,设置程序,其运行结果如下图所示.一个标签控件的Text属性为"缩放"两个字,它的字体大小取决于垂直滚动条的值(Maximum=72,Minimum= ...

  3. C++ Windows 窗体程序入门 - 1.你的第亿个窗体程序

    〇.前言-------------------- + 学Windows窗体已经有一段时日了,奈何没有什么浅显易懂(&便宜!!)的书籍 , 就想来 , 算是记笔记吧 , 顺便还能给你们总结一些经 ...

  4. vs 窗体连接mysql_vs2008 c#开发windows窗体程序,怎么连接数据库?

    你的位置: 问答吧 -> .NET -> 问题详情 vs2008 c#开发windows窗体程序,怎么连接数据库? 我的oracle服务器为WebServer数据库为MIS,用户名为MIS ...

  5. 基于win32的windows画板程序

    功能设计如下: 1.Graphics菜单中可选择图形,支持Rectangle, Circle, Line,选择对应图形,则相应菜单项前面加上选中标志: 2.Options菜单中包含以下选项 a.Col ...

  6. [C#][Windows窗体程序]实现自动出题并判分

    文章目录 一.pandas是什么? 二.效果演示 三.代码 Form1.cs 四.补充 一.pandas是什么? 编写一个Windows程序,实现自动出题并判分的功能. 功能要求: 能使用Random ...

  7. 基于DirectUI搭建Windows窗体程序

    使用DirectUI需要directuiCom.dll,包含IDirectUI.h和DirectuiDef.h.在你的应用程序中初始化CLSID_DirectUI,并获取IDirectUI(IID_I ...

  8. 发消息给非windows窗体程序

    unit Unit1; interface uses   Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, For ...

  9. Source Insight是一个面向项目开发的程序编辑器和代码浏览器丨产品简介

    Source Insight是为大型.高要求的现实世界编程项目而设计的.事实上,今天,重要的技术公司正在使用Source Insight来开发一些最大.最成功的商业硬件和软件产品. 代码分析 Sour ...

最新文章

  1. 推荐一些算法方面的好书
  2. mysql的proxy机制_MySQL Proxy工作机制浅析
  3. 20210712未来智能实验室收录资料
  4. python提取excel数据-使用Python从Excel获取运营数据
  5. CSDNmarkdown编辑器直接写代码的小效果(一生愿)
  6. 蜘蛛纸牌java注释_自己摸索的纸牌游戏代码,感觉还有很多知识不懂,任重道远啊!...
  7. 过滤序列,惰性序列_Java 8的惰性序列实现
  8. 软件工程知识——软件配置管理
  9. 如何使用Dependabot保持环境最新
  10. tp5微信公众号获取用户openid_tp5+微信公众号获取用户基本信息
  11. 牛年春节海报怎么设计?psd分层模板,给你灵感!
  12. 19. Python 类的重写   类的私有变量和私有方法
  13. [专题练习] Part1 搜索
  14. 黑域最新版本android,黑域_黑域安卓版_黑域最新版_易玩网
  15. 计算机信息资源管理岗位,信息资源管理专业的可以报考公务员的哪些职位?
  16. 域名过期导致的问题-研究DNS相关知识
  17. ios 强制横屏大总结
  18. 神器vimium:比同级程序员成长更快,我主要靠它
  19. html把字母a显示为其asc码,HTML ASCII码
  20. 关于mac地址,请各位大侠帮忙解决

热门文章

  1. Yann LeCun:假如没有深度学习,Facebook就是尘埃
  2. 亚马逊AWS:用AI和机器学习让所有人受益
  3. 干货丨一文读懂深度学习(附学习资源,据说点赞2W+)
  4. 机器人行业专利构建与维护刻不容缓,专利研发需下苦功!
  5. 6G技术长啥样?5大趋势,13个核心技术2030年落地
  6. 【华为出品】智能体白皮书2020(附全文下载)
  7. 8大领域、6大机遇!读懂2020年AI医疗新风向
  8. 没有精准定位,万物还能实现互联吗?
  9. Nature解析中国AI现状,2030年能引领全球吗?
  10. 无线通信界的3大天王,谁能驾驭百亿台IoT设备?