• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Sleeping

            Note Book

            2008年10月7日 #

            DialogBox的若干問題

            今天繼續折騰那個List Box控件,發現一個問題,當對話框出來之后,被主窗體給刷屏了,不能得到子窗體的句柄。后經仔細調試,發現一些端倪。首先在調用 DialogBox函數時 ,所生成的Dialog(我這里的Dialog面板里有一個Edit控件 兩個按鈕控件 和一個List Box控件)依次產生的消息隊列如下所示:
            WM_SETFONT    0x0030                 設置字體
            WM_INITDIALOG 0x0110                 初始化Dialog
            WM_WINDOWPOSCHANGING            0x0046                窗體大小 位置等轉變的消息
            WM_NCACTIVATE   0x0086          改變一個非工作區域 sent to a window when its nonclient area needs to be changed to indicate an active or inactive state.
            WM_ACTIVATE     0x0006   讓你窗體無效 并激活子窗體
            WM_COMMAND   0x0111 (HIWORD(WPARAM))->LBN_SETFOCUS(4) ->LBN_KILLFOCUS(5) 消息命令 ListBox
            WM_USER     0x0400    用戶自定義消息
            WM_NCACTIVATE  0x0086
            WM_SHOWWINDOW   0x0018   顯示窗體
            WM_WINDOWPOSCHANGING 0x0046
            WM_NCPAINT 0x0085    The WM_NCPAINT message is sent to a window when its frame must be painted.
            WM_ERASEBKGND 0x0014   清楚窗口背景
            WM_WINDOWPOSCHANGED 0x0047  
            WM_GETICON 0x007F  3次   The WM_GETICON message is sent to a window to retrieve a handle to the large or small icon associated with a window
            WM_NCCALCSIZE 0x0083   計算機窗體大小尺寸
            WM_MOVE 0x0003     移動
            WM_SIZE 0x0005     改變大小
            WM_PAINT 0x000F    繪制窗體
            WM_CTLCOLORBTN 0x0135   繪制按鈕的顏色
            WM_CTLCOLORLISTBOX 0x0134  繪制Listbox的顏色
            WM_CTLCOLOREDIT 0x0133   繪制Edit的顏色
            WM_POWERBROADCAST 0x0218   broadcast to an application to notify it of power-management events
            while(1) 一直循環以下的兩個消息
            WM_NCACTIVATE  0x0086
            WM_WINDOWPOSCHANGING            0x0046

            代碼如下:
            BOOL CALLBACK  ListBoxTest(HWND hWnd,UINT message , WPARAM wParam, LPARAM lParam) 

            int wmId = LOWORD(wParam ); 
            int wmEvent = HIWORD(wParam) ; 
            int i ; 
            HDC hDc ; 
            PAINTSTRUCT ps ; 
            HWND hListBox ; 
            switch(message) 

              
            case WM_INITDIALOG: 
               hListBox 
            = GetDlgItem(hWnd,IDC_LIST_TEST) ; 
               
            for(i = 0; MyData[i].Name[0!= 0 ; i++

                SendMessage(hListBox,LB_ADDSTRING,
            0,(LPARAM)MyData[i].Name) ; 
                SendMessage(hListBox,LB_SETITEMDATA,  i ,(LPARAM)i) ; 
               }
             
               SetFocus(hListBox); 
               
            return (TRUE) ; 
              
            case WM_PAINT: 
               hDc 
            = BeginPaint(hWnd,&ps) ; 
               
            //MSGPRINT(_T("Print")) ; 
               EndPaint(hWnd,&ps); 
               
            break ; 
              
            case LB_ADDFILE: 
               
            break ; 
              
            case WM_COMMAND: 
               
            switch(wmId) 
            {
             
               
            case IDC_LIST_TEST: 
                
            switch(wmEvent) 
               {
             
                
            case LBN_SELCHANGE: 
                 
            //MSGPRINT(_T("LBN_SELCHANGE")); 
                 break ; 
                
            case LBN_DBLCLK: 
                 
            //MSGPRINT(_T("LBN_DBLCLK")); 
                 break ; 
                
            case LBN_SETFOCUS: 
                 
            //MSGPRINT(_T("LBN_SETFOCUS")) ; 
                 break ; 
                
            case LBN_KILLFOCUS: 
                 
            //MSGPRINT(_T("LBN_KILLFOCUS")) ; 
                 break ; 
                }
             
                
            return FALSE ; 
                
            break ; 
               
            case IDOK: 
                MSGPRINT(_T(
            "IDOK")); 
                EndDialog(hWnd,
            0) ; 
                
            return TRUE; 
                
            break ; 
               
            case IDCANCEL: 
                MSGPRINT(_T(
            "IDCANCEL")); 
                EndDialog(hWnd,
            0) ; 
                
            return TRUE ; 
                
            break ; 
               }
             
            }
             
            return FALSE;
            }

            如果最后返回TRUE那么窗體的著色會很有問題,Dialog的顏色和背景顏色完全一樣,導致不能看到一個窗體的存在,所以這里必須返回FALSE,
            MSDN作出的解釋如下:Typically, the dialog box procedure should return TRUE if it processed the message, and FALSE if it did not. If the dialog box procedure returns FALSE, the dialog manager performs the default dialog operation in response to the message.
            意即,如果這個窗體想處理哪個消息就返回TRUE,如果不想處理這個消息就返回FALSE,所以在最后應該返回False,即默認不處理那些消息而只算WM_INITDIALOG 和其它一些IDOK IDCANCEL的消息。
            If the dialog box procedure processes a message that requires a specific return value, the dialog box procedure should set the desired return value by calling SetWindowLong(hwndDlg, DWL_MSGRESULT, lResult) immediately before returning TRUE. Note that you must call SetWindowLong immediately before returning TRUE; doing so earlier may result in the DWL_MSGRESULT value being overwritten by a nested dialog box message.

            這個嘛   靠 英文 爛!勉勉強強
            如果窗體在處理一個消息時需要顯示地返回一個值,那這個窗體應該在返回TRUE前調用SetWindoLong(hWndDlg,DWL_MSGRESULT,lpResult)函數更改想要返回的值.切記一定要馬上調用該函數在返回TRUE之前,盡可能早地通過DWL_MSGRESULT去改寫真正的Result,by a nested dialog box message.  他媽的這句怎么翻譯?


            現在都開始懷疑弄這些消息有什么用,用MFC肯定是一個更好的選擇。在List Box里增加和刪除內容都是太煩了,都是通過SendMessage來完成的。不知道能堅持學到什么時候。

            posted @ 2008-10-07 21:42 祥子_隨波逐流 閱讀(2064) | 評論 (0)編輯 收藏

            2008年10月5日 #

            關于FormatMessage的錯誤

            #ifdef UNICODE 
            typedef WCHAR
            * TYPESTR ; 
            typedef WCHAR TYPECHAR ; 
            #else //UNICODE 
            typedef 
            char* TYPESTR ; 
            typedef 
            char TYPECHAR ; 
            #endif 
            #define ERRINFO _T("調試錯誤信息") 

            VOID PrintError(DWORD dwErrNo,TYPESTR szFileName,DWORD LineNo) 

            TCHAR
            * szErrBuff ; // TCHAR 
            TYPESTR szBuff =(TCHAR*) LocalAlloc(LPTR,sizeof(TYPECHAR)*512) ; 
            if(szBuff == NULL) 

              MessageBox(NULL,_T(
            "內存分配失敗"),ERRINFO,MB_OK) ; 
              
            return ; 
            }
             
            // 這個地方報 讀取位置 0x00000000 時發生訪問沖突 或者 The variable 'szErrBuff' is being used without being defined. 
                //原因是 包含| FORMAT_MESSAGE_FROM_STRING
            FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, 
                                        // | FORMAT_MESSAGE_FROM_STRING, 
                NULL, 
                dwErrNo, 
                MAKELANGID(LANG_NEUTRAL,SUBLANG_DEFAULT), 
                (LPTSTR) 
            &szErrBuff, 
                
            sizeof(szErrBuff), 
                NULL) ; 

            #ifdef UNICODE 
            wsprintf(szBuff,L
            "%s 第%d行;錯誤信息:%s",szFileName,LineNo,szErrBuff) ; 
            #else 
            sprintf(szBuff,
            "文件名%s 第%d行;錯誤信息:%s",szFileName,LineNo,szErrBuff) ; 
            #endif 
            MessageBox(NULL,szBuff,ERRINFO,MB_OK) ; 
            LocalFree((HLOCAL)szErrBuff) ; 
            LocalFree( szBuff); 
            return ; 
            }
             

            VOID TestForPrintError()
            {
                SECURITY_ATTRIBUTES sp;
                sp.nLength 
            = sizeof(sp) ;
                sp.bInheritHandle 
            = FALSE ;
                sp.lpSecurityDescriptor 
            = NULL ;
            #ifdef UNICODE 
                TYPESTR szFileName 
            = _T("d:\\he.txt") ;
            #else
                TYPESTR szFileName 
            = "d:\\he.txt" ;
            #endif
                
            //如何判斷文件是否已經存在了?
                HANDLE hFile = CreateFile(szFileName,
                    GENERIC_READ 
            |GENERIC_WRITE | GENERIC_EXECUTE ,
                    NULL, 
            //FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE,
                    NULL, //&sp,
                    CREATE_ALWAYS, //| OPEN_EXISTING, //如果有這個會報 在沒有原文件的時候會報系統找不到指定的文件
                    FILE_ATTRIBUTE_NORMAL,
                    NULL) ;
                
            if(hFile ==  INVALID_HANDLE_VALUE)
             
            {
                    DWORD dwErrNo 
            = GetLastError() ;
                    PRINTERROINFO(GetLastError() ,__FILE__,__LINE__) ;
                }

                DWORD lenth ;
                    //這個函數好像比較少用了 不支持Unicode
                
            if(!WriteFile(hFile,"hello",4,&lenth,NULL))
                    PRINTERROINFO(GetLastError() ,__FILE__,__LINE__) ;
                CloseHandle(hFile) ;
                
            return ;
            }

            posted @ 2008-10-05 18:30 祥子_隨波逐流 閱讀(639) | 評論 (0)編輯 收藏

            僅列出標題  
            久久99精品久久久久久齐齐 | 一本色道久久综合亚洲精品| 9久久9久久精品| 国产午夜福利精品久久2021| 91久久九九无码成人网站| 色天使久久综合网天天| 欧美大香线蕉线伊人久久| 久久这里只有精品久久| 亚洲人成无码网站久久99热国产 | 思思久久99热只有频精品66| 久久综合丁香激情久久| 久久久久99精品成人片三人毛片| 色综合久久久久综合99| 精品久久人妻av中文字幕| 国产69精品久久久久9999| 午夜精品久久久久久中宇| 久久精品国产99久久香蕉| 精品久久久久久亚洲精品| 日韩久久无码免费毛片软件| 久久亚洲AV成人无码电影| 日产精品久久久久久久| 99久久国产亚洲高清观看2024| 久久久久久久精品妇女99| 久久久久99精品成人片 | 久久五月精品中文字幕| 久久美女网站免费| 久久久女人与动物群交毛片| 久久精品免费全国观看国产| 精品综合久久久久久97超人| 久久婷婷五月综合色奶水99啪 | 久久精品国产清高在天天线| 欧美精品一本久久男人的天堂| 久久综合伊人77777麻豆| 粉嫩小泬无遮挡久久久久久| 久久人妻少妇嫩草AV无码专区| 久久天天躁狠狠躁夜夜不卡| 国产—久久香蕉国产线看观看| 91久久精品91久久性色| 久久久久人妻一区二区三区vr | 亚洲午夜无码久久久久| 亚洲国产成人精品女人久久久|