《深入浅出MFC第2版(PDF格式)》第306章


圖六是 Tracewin 的 PreCreateWindow 內容,利用 GetClassInfo 把 MFC 的視窗類別做 
出份副本,然後改變其類別名稱以及程式圖示,再重新裕浴J堑模匦略'冊是必要 
CMfxTrace Write FindWindow 
的。這麼來, :: 呼叫的 就有明確的搜尋目標了。 
#0001 BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs) 
#0002 { 
#0003 static LPCSTR className = NULL; 
#0004 
#0005 if (!CFrameWnd::PreCreateWindow(cs)) 
#0006 return FALSE; 
#0007 
#0008 if (className==NULL) { 
#0009 // One…time class registration 
#0010 // The only purpose is to make the class name something 
#0011 // meaningful instead of 〃Afx:0x4d:27:32:hup1hup:hike!〃 
#0012 // 
#0013 WNDCLASS wndcls; 
#0014 ::GetClassInfo(AfxGetInstanceHandle(); cs。lpszClass; &wndcls); 
#0015 wndcls。lpszClassName = TRACEWND_CLASSNAME; 
#0016 wndcls。hIcon = AfxGetApp()…》LoadIcon(IDR_MAINFRAME); 
#0017 VERIFY(AfxRegisterClass(&wndcls)); 
#0018 className=TRACEWND_CLASSNAME; 
930 
…………………………………………………………Page 993……………………………………………………………
附錄D 以MFC 重建DBWIN
#0019 } 
#0020 cs。lpszClass = className; 
#0021 
#0022 // Load window position from profile 
#0023 CWinApp *pApp = AfxGetApp(); 
#0024 cs。x = pApp…》GetProfileInt(PROFILE; 〃x〃; CW_USEDEFAULT); 
#0025 cs。y = pApp…》GetProfileInt(PROFILE; 〃y〃; CW_USEDEFAULT); 
#0026 cs。cx = pApp…》GetProfileInt(PROFILE; 〃cx〃; CW_USEDEFAULT); 
#0027 cs。cy = pApp…》GetProfileInt(PROFILE; 〃cy〃; CW_USEDEFAULT); 
#0028 
#0029 return TRUE; 
#0030 } 
圖六 Tracewin 的 frame 視窗的 PreCreateWindow 函式內容 
Tracewin 取出字串並顯示 
WM TRACE MSG OnTraceMsg 
Tracewin _ _
如果 欲接收由除錯端傳來的自定訊息 ,並交由 
函式去處理,它就必須在其訊息映射表有所表示: 
BEGIN_MESSAGE_MAP(CMainFrame; CFrameWnd) 
//{{AFX_MSG_MAP(CMainFrame) 
ON_REGISTERED_MESSAGE(WM_TRACE_MSG; OnTraceMsg) 
。。。 
//}}AFX_MSG_MAP 
END_MESSAGE_MAP() 
並且設計 OnTraceMsg 函式如圖七。 
#0001 LRESULT CMainFrame::OnTraceMsg(WPARAM wParam; LPARAM) 
#0002 { 
#0003 if (!wParam || m_nOutputWhere==ID_OUTPUT_OFF) 
#0004 return 0; 
#0005 
#0006 char buf'256'; 
#0007 UINT len = GlobalGetAtomName((ATOM)wParam; buf; sizeof(buf)); 
#0008 
#0009 if (m_nOutputWhere==ID_OUTPUT_TO_WINDOW) { 
#0010 
#0011 // Convert n to nr for Windows edit control 
931 
…………………………………………………………Page 994……………………………………………………………
第五篇 附錄
#0012 。。。 
#0013 // Append string to contents of trace buffer 
#0014 。。。 
#0015 } else if (m_nOutputWhere==ID_OUTPUT_TO_FILE) { 
#0016 m_file。Write(buf; len); 
#0017 } 
#0018 return 0; 
#0019 } 
圖七 CMainFrame::OnTraceMsg 函式內容。 
WM_COPYDATA IPC 
改用 進行行程通訊( ) 
Paul DiLascia 的第篇文章發表後,收到許多讀者的來信,指出以 global atom 完成行 
WM COPYDATA 
_ Paul
程通訊並不是最高明的辦法,可以改用 。於是 從善如流寫了第 
篇文章。 
WM COPYDATA 
_ 是 Win32 的新訊息,可以提供個簡單又方便的方法,把字串送往另 
個程式。這正符合 Tracewin 之所需。這個訊息的兩個參數意義如: 
wParam = (WPARAM) (HWND) wnd; // handle of sending window 
lParam = (LPARAM) (PCOPYDATASTRUCT) pcds; // pointer to structure with data 
其 COPYDATASTRUCT 結構定義如: 
typedef struct tagCOPYDATASTRUCT { // cds 
DWORD dwData; // 隨便你指定任何你需要的額外資訊 
DWORD cbData; // 資料長度 
PVOID lpData; // 資料指標 
} COPYDATASTRUCT; 
dwData ID_COPYDATA_TRACEMSG Tracewin
在本例應用被指定為 ; 將檢查這個識別 
WM COPYDATA 
碼,如果不合格,就忽略該次的 _ 訊息。 
Tracewin 新版本的內容我就不再列出了,請直接載其原始碼看個究竟。 
932 
…………………………………………………………Page 995……………………………………………………………
附錄D 以MFC 重?
小说推荐
返回首页返回目录