VS2010 win32項目windows窗體程序 向導生成代碼解析


目錄:

1.Win32項目的windows窗體程序的向導生成了如下代碼

2.手工生成代碼如下

3.當消息隊列中沒有消息需要處理,我們可以利用這段時間處理我們自己的任務


1.Win32項目的windows窗體程序的向導生成了如下代碼:

[cpp]   view plain copy
  1. // Timer.cpp : 定義應用程序的入口點。  
  2. //  
  3.   
  4. #include "stdafx.h"  
  5. #include "Timer.h"  
  6.   
  7. #define MAX_LOADSTRING 100  
  8.   
  9. // 全局變量:  
  10. HINSTANCE hInst;                                // 當前實例  
  11. TCHAR szTitle[MAX_LOADSTRING];                  // 標題欄文本  
  12. TCHAR szWindowClass[MAX_LOADSTRING];            // 主窗口類名  
  13.   
  14. // 此代碼模塊中包含的函數的前向聲明:  
  15. ATOM                MyRegisterClass(HINSTANCE hInstance);  
  16. BOOL                InitInstance(HINSTANCEint);  
  17. LRESULT CALLBACK    WndProc(HWNDUINTWPARAMLPARAM);  
  18. INT_PTR CALLBACK    About(HWNDUINTWPARAMLPARAM);  
  19.   
  20. int APIENTRY _tWinMain(HINSTANCE hInstance,  
  21.                      HINSTANCE hPrevInstance,  
  22.                      LPTSTR    lpCmdLine,  
  23.                      int       nCmdShow)  
  24. {  
  25.     UNREFERENCED_PARAMETER(hPrevInstance);  
  26.     UNREFERENCED_PARAMETER(lpCmdLine);  
  27.   
  28.     // TODO: 在此放置代碼。  
  29.     MSG msg;  
  30.     HACCEL hAccelTable;  
  31.   
  32.     // 初始化全局字符串  
  33.     LoadString(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING);   ///加載標題欄字符串  
  34.     LoadString(hInstance, IDC_TIMER, szWindowClass, MAX_LOADSTRING);  ///加載“關於對話框”  
  35.     MyRegisterClass(hInstance);  
  36.   
  37.     // 執行應用程序初始化:  
  38.     if (!InitInstance (hInstance, nCmdShow))  
  39.     {  
  40.         return FALSE;  
  41.     }  
  42.     /*函數原型:int TranslateAccelerator(HWND hWnd,HACCEL hAccTable,LPMSG IpMsg); 
  43.            函數功能:翻譯加速鍵表。該函數處理菜單命令中的加速鍵。該函數將一個WM_KEYDOWN或WM_SYSKEYDOWN消息翻譯 
  44.     成一個WM_COMMAND或WM_SYSCOMMAND消息(如果在給定的加速鍵表中有該鍵的入口),然后將WM_COMMAND或 
  45.     WM_SYSCOMMAND消息直接送到相應的窗口處理過程。 
  46.            TranslateAccelerator直到窗口過程處理完消息后才返回。 
  47.     參數: 
  48.     hWnd:窗口句柄,該窗口的消息將被翻譯。 
  49.     hAccTable:加速鍵表句柄。加速鍵表必須由LoadAccelerators函數調用裝入或由CreateAccd_eratorTable函數調用創建。 
  50.     LpMsg:MSG結構指針,MSG結構中包含了從使用GetMessage或PeekMessage函數調用線程消息隊列中得到的消息內容。 
  51.     返回值:若函數調用成功,則返回非零值;若函數調用失敗,則返回值為零。若要獲得更多的錯誤信息,可調用GetLastError函數。 
  52.     */  
  53.   
  54.     hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_TIMER));  
  55.   
  56.     // 主消息循環:  
  57.     while (GetMessage(&msg, NULL, 0, 0))  
  58.     {  
  59.         if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg))  
  60.         {  
  61.             TranslateMessage(&msg);  
  62.             DispatchMessage(&msg);  
  63.         }  
  64.     }  
  65.   
  66.     return (int) msg.wParam;  
  67. }  
  68.   
  69.   
  70.   
  71. //  
  72. //  函數: MyRegisterClass()  
  73. //  
  74. //  目的: 注冊窗口類。  
  75. //  
  76. //  注釋:  
  77. //  
  78. //    僅當希望  
  79. //    此代碼與添加到 Windows 95 中的“RegisterClassEx”  
  80. //    函數之前的 Win32 系統兼容時,才需要此函數及其用法。調用此函數十分重要,  
  81. //    這樣應用程序就可以獲得關聯的  
  82. //    “格式正確的”小圖標。  
  83. //  
  84. ATOM MyRegisterClass(HINSTANCE hInstance)  
  85. {  
  86.     WNDCLASSEX wcex;  
  87.   
  88.     wcex.cbSize = sizeof(WNDCLASSEX);   ///注冊類對象的大小  
  89.   
  90.     wcex.style          = CS_HREDRAW | CS_VREDRAW;   ///注冊類的風格  
  91.     wcex.lpfnWndProc    = WndProc;   ///消息處理函數  
  92.     wcex.cbClsExtra     = 0;  
  93.     wcex.cbWndExtra     = 0;  
  94.     wcex.hInstance      = hInstance;  ///應用程序實例句柄,系統提供的  
  95.     wcex.hIcon          = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_TIMER));   ///圖標  
  96.     wcex.hCursor        = LoadCursor(NULL, IDC_ARROW);   ///光標  
  97.     wcex.hbrBackground  = (HBRUSH)(COLOR_WINDOW+1);   ///背景畫刷設定  
  98.     wcex.lpszMenuName   = /*MAKEINTRESOURCE(IDC_TIMER)*/NULL;      ///菜單  
  99.     wcex.lpszClassName  = szWindowClass;    //注冊類  
  100.     wcex.hIconSm        = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL));  ///小圖標  
  101.   
  102.     return RegisterClassEx(&wcex);  
  103. }  
  104.   
  105. //  
  106. //   函數: InitInstance(HINSTANCE, int)  
  107. //  
  108. //   目的: 保存實例句柄並創建主窗口  
  109. //  
  110. //   注釋:  
  111. //  
  112. //        在此函數中,我們在全局變量中保存實例句柄並  
  113. //        創建和顯示主程序窗口。  
  114. //  
  115. BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)  
  116. {  
  117.    HWND hWnd;  
  118.   
  119.    hInst = hInstance; // 將實例句柄存儲在全局變量中  
  120.   
  121.    hWnd = CreateWindow(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW,  
  122.       CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, NULL, NULL, hInstance, NULL);  
  123.   
  124.    if (!hWnd)  
  125.    {  
  126.       return FALSE;  
  127.    }  
  128.   
  129.    ///MoveWindow(hWnd,100,100,640,320,true);  
  130.    ShowWindow(hWnd, nCmdShow);  
  131.    UpdateWindow(hWnd);  
  132.   
  133.    return TRUE;  
  134. }  
  135.   
  136. //  
  137. //  函數: WndProc(HWND, UINT, WPARAM, LPARAM)  
  138. //  
  139. //  目的: 處理主窗口的消息。  
  140. //  
  141. //  WM_COMMAND  - 處理應用程序菜單  
  142. //  WM_PAINT    - 繪制主窗口  
  143. //  WM_DESTROY  - 發送退出消息並返回  
  144. //  
  145. //  
  146. LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)  
  147. {  
  148.     int wmId, wmEvent;  
  149.     PAINTSTRUCT ps;  
  150.     HDC hdc;  
  151.   
  152.     switch (message)  
  153.     {  
  154.     case WM_COMMAND:  
  155.         wmId    = LOWORD(wParam);  
  156.         wmEvent = HIWORD(wParam);  
  157.         // 分析菜單選擇:  
  158.         switch (wmId)  
  159.         {  
  160.         case IDM_ABOUT:  
  161.             DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);  
  162.             break;  
  163.         case IDM_EXIT:  
  164.             DestroyWindow(hWnd);  
  165.             break;  
  166.         default:  
  167.             return DefWindowProc(hWnd, message, wParam, lParam);  
  168.         }  
  169.         break;  
  170.     case WM_PAINT:  
  171.         hdc = BeginPaint(hWnd, &ps);  
  172.         // TODO: 在此添加任意繪圖代碼...  
  173.         EndPaint(hWnd, &ps);  
  174.         break;  
  175.     case WM_DESTROY:  
  176.         PostQuitMessage(0);  
  177.         break;  
  178.     default:  
  179.         return DefWindowProc(hWnd, message, wParam, lParam);  
  180.     }  
  181.     return 0;  
  182. }  
  183.   
  184. // “關於”框的消息處理程序。  
  185. INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)  
  186. {  
  187.     UNREFERENCED_PARAMETER(lParam);  
  188.     switch (message)  
  189.     {  
  190.     case WM_INITDIALOG:  
  191.         return (INT_PTR)TRUE;  
  192.   
  193.     case WM_COMMAND:  
  194.         if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)  
  195.         {  
  196.             EndDialog(hDlg, LOWORD(wParam));  
  197.             return (INT_PTR)TRUE;  
  198.         }  
  199.         break;  
  200.     }  
  201.     return (INT_PTR)FALSE;  
  202. }  

2.手工生成代碼如下:

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


3.當消息隊列中沒有消息需要處理,我們可以利用這段時間處理我們自己的任務:

[cpp]   view plain copy
  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. }  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM