• <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的若干問題

            今天繼續(xù)折騰那個List Box控件,發(fā)現(xiàn)一個問題,當對話框出來之后,被主窗體給刷屏了,不能得到子窗體的句柄。后經(jīng)仔細調試,發(fā)現(xiàn)一些端倪。首先在調用 DialogBox函數(shù)時 ,所生成的Dialog(我這里的Dialog面板里有一個Edit控件 兩個按鈕控件 和一個List Box控件)依次產(chǎn)生的消息隊列如下所示:
            WM_SETFONT    0x0030                 設置字體
            WM_INITDIALOG 0x0110                 初始化Dialog
            WM_WINDOWPOSCHANGING            0x0046                窗體大小 位置等轉變的消息
            WM_NCACTIVATE   0x0086          改變一個非工作區(qū)域 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) 一直循環(huán)以下的兩個消息
            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)函數(shù)更改想要返回的值.切記一定要馬上調用該函數(shù)在返回TRUE之前,盡可能早地通過DWL_MSGRESULT去改寫真正的Result,by a nested dialog box message.  他媽的這句怎么翻譯?


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

            posted @ 2008-10-07 21:42 祥子_隨波逐流 閱讀(2058) | 評論 (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 時發(fā)生訪問沖突 或者 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
                
            //如何判斷文件是否已經(jīng)存在了?
                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, //如果有這個會報 在沒有原文件的時候會報系統(tǒng)找不到指定的文件
                    FILE_ATTRIBUTE_NORMAL,
                    NULL) ;
                
            if(hFile ==  INVALID_HANDLE_VALUE)
             
            {
                    DWORD dwErrNo 
            = GetLastError() ;
                    PRINTERROINFO(GetLastError() ,__FILE__,__LINE__) ;
                }

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

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

            僅列出標題  
            亚洲欧美久久久久9999| 国产成人久久精品麻豆一区| 天堂久久天堂AV色综合| 日本人妻丰满熟妇久久久久久| 浪潮AV色综合久久天堂| 99热都是精品久久久久久| 久久久噜噜噜久久中文字幕色伊伊| 久久精品a亚洲国产v高清不卡| 久久毛片免费看一区二区三区| 久久国产免费观看精品3| 日本精品久久久久久久久免费| 久久久精品午夜免费不卡| 色综合久久中文字幕综合网| 久久99国产精品久久99| 国产精品一区二区久久精品涩爱| 久久91综合国产91久久精品| 亚洲精品国产字幕久久不卡 | 午夜精品久久久久9999高清| 国产亚洲欧美精品久久久| 亚洲精品久久久www| 久久精品亚洲精品国产欧美| 国产精品久久久久影视不卡| 思思久久好好热精品国产| 狠狠人妻久久久久久综合| 久久久久久综合一区中文字幕| 久久香综合精品久久伊人| 久久久国产精华液| 久久久久久综合网天天| 久久99热这里只有精品66| 亚洲精品国产综合久久一线| 久久亚洲电影| 日韩久久久久中文字幕人妻| 久久天天躁狠狠躁夜夜不卡| 久久人人爽人人澡人人高潮AV| 久久国产成人午夜aⅴ影院| 久久国产V一级毛多内射| 久久人人爽人爽人人爽av| 色8激情欧美成人久久综合电| 久久亚洲精品国产精品婷婷| 综合人妻久久一区二区精品| 久久精品国产亚洲av水果派|