目录:

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

2.手工生成代码如下

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


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

  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.手工生成代码如下:

  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.当消息队列中没有消息需要处理,我们可以利用这段时间处理我们自己的任务:

  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. 如何给windows窗体程序打包成一个安装包

    http://blog.csdn.net/xyy410874116/article/details/6341787 给windows窗体程序打包成一个安装包:具体操作在:http://hi.baidu ...

  2. Windows 窗体设计器生成的代码

    namespace 窗体的浮动及隐藏{    partial class Form1    {        /// <summary>        /// 必需的设计器变量.      ...

  3. 捕捉WPF应用程序中XAML代码解析异常

    原文:捕捉WPF应用程序中XAML代码解析异常 由于WPF应用程序中XAML代码在很多时候是运行时加载处理的.比如DynamicResource,但是在编译或者运行的过程中,编写的XAML代码很可能有 ...

  4. .net中关于Windows窗体程序和Web网站程序调用自己的服务

    在.NET Framework 4.0创建服务是中没有像3.5那样的选择新建-网站-ASP.NET Web服务模块,但在4.0中可以选择 新建-网站-ASP.NET空网站-选中项目右键添加新项- 选择 ...

  5. VS中空项目、win32项目、控制台程序的区别(转)

    空项目,大多数想单纯创建c++工程的新同学,打开vs后很可能不知道选择创建什么工程,这时候请相信我,空项目是你最好的选择.因为空工程不包含任何的源代码文件,接下来你只需要在相应的源代码文件夹和头文件文 ...

  6. VS2010 Win32项目的源码位置设置

    在VS2010中,我们可以创建一个Win32项目用来编辑C或CPP代码,项目建好后我们向项目文件夹添加代码文件,并调试能正常运行. 有时候我们会发现项目目录下没有源文件,这种情况下,可以通过设置“输出 ...

  7. NSIS安装与向导生成代码

    NSIS 的脚本语言和通常的编程语言有类似的结构和语法,但它是为安装程序这类应用所设计的.NSIS (Nullsoft Scriptable Install System) 是一个专业开源的制作 wi ...

  8. MFC应用程序向导生成的文件

    比方说我们用Visio Studio创建了一个MFC应用程序,名称为Mysdi.在创建这个项目的时候,默认的会生成许多类和文件,就关于这些文件的内容和要点展开以下论述. 框架窗口类头文件 向导为项目M ...

  9. C# windows窗体程序打包安装及卸载

    一.新建安装部署项目

随机推荐

  1. drawable 另外一种形式dimens.xml

    常见的Drawable,放置默认drawable一系列目录,有时候会发现drawable找不到的情况,其实还可以放另外一个目录下 values------->>dimens.xml < ...

  2. MVC+JSON 无限滚动翻页

    public partial class News { public int ID{ get; set; } public int Title{ get; set; } } ) { Response. ...

  3. 限制ITEM读取其它物料的物料描述

    应用 Oracle   Purchasing 层 Level Function 函数名 Funcgtion Name CUXPOXPOEPO 表单名 Form Name POXPOEPO 说明 Des ...

  4. Ubuntu下,在Eclipse中使用JNI调用ffmpeg

    Android的应用层开发大部分还是采用JAVA,如果想使用ffmpeg库,就必须利用JNI,使得Java可以调用C/C++的库. JNI其实就是定义的一个转接接口,可以让Java的代码调用C/C++ ...

  5. Unix/Linux环境C编程入门教程(8) FreeBSD CCPP开发环境搭建

    1. FreeBSD是一种自由类Unix操作系统,是由经过BSD.386BSD和4.4BSD发展而来的类Unix的一个重要分支.FreeBSD拥有超过200名活跃开发者和上千名贡献者.FreeBSD被 ...

  6. NOI2014 Day1

    NOI2014 Day1 起床困难综合症 题目描述:给出\(n\)个操作,每个操作包含一种运算\((XOR.OR.AND)\)和一个数,已知一开始的数字为\([0, m]\),问经过\(n\)次操作后 ...

  7. Google Maps API V2

    1. 在AndroidManifest.xml的application节点中,添加Google play service的版本号: <meta-data android:name="c ...

  8. Android Afinal框架学习(二) FinalActivity 一个IOC框架

    框架地址:https://github.com/yangfuhai/afinal 相应的源代码: net.tsz.afinal.annotation.view.* FinalActivity Fina ...

  9. SurfaceView 和 View 区别

    android.view.View 和 android.view.SurfaceView SurfaceView 是从 View 基类中派生出来的显示类,直接子类有 GLSurfaceView和Vid ...

  10. HDU 1879 继续畅通工程 (Prim(普里姆算法)+Kruskal(克鲁斯卡尔))

    继续畅通工程 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...