|
如何拋出(throw)由CUserException派生的異常? 當(dāng)我試圖捕獲(catch)一個派生類異常時,我得到以下錯誤"error C2039:'classCMyException': is not a member of 'CMyException' 'classCMyException': undeclared identifier 'IsKindOf': cannot convert parameter 1 from 'int*' to 'const struct CRuntimeClass*" 異常類一定要從CUserException中派生出來嗎? 不,CUserException中的"User"僅僅指用戶產(chǎn)生的異常。而把它當(dāng)作你所能派生的唯一異常是種常見的誤解。 如何從HDC建立一個CDC類? 有時Windows API將會給你一個DC句柄,你可以通過它建立一個CDC類。例如:下拉式列表、組合框和按鈕。通過hDC你將接收到繪制消息。下面是將HDC轉(zhuǎn)換成你更熟悉的CDC的程序段。你也可以將該技巧用在其他任何MFC類和Windows句柄的轉(zhuǎn)換中。 void MyODList::DrawItem(LPDRAWITEMSTRUCT lpDrawItem) { CDC myDC; myDC.Attach(lpDrawItem-〉hDC); //在此插入其他需要的代碼。 //如果你不將句柄分離,它將被刪除,從而導(dǎo)致問題。 myDC.Detach(); }另一個方法是調(diào)用CDC類的FromHandle方法: CDC * pDC = CDC:FromHandle(lpDrawItem-〉hDC);目前還不清楚哪種方法更優(yōu)越―使用FromHandle()的錯誤也許會更少些,因為它不要求你分離(detach)句柄。 如何從磁盤上讀取256色位圖文件? 當(dāng)前,MFC并不支持直接讀取和顯示DIB文件和BMP文件。然而,有很多樣例應(yīng)用程序能夠說明如何完成該項任務(wù)。第一個例子是MFC樣例程序DIBLOOK。樣例MULTDOCS用DIBLOOK提供的相同源代碼來讀取并顯示DIB文件和BMP文件。其他兩個VC++中附帶的例子是SDK軟件包中的DIBVIEW程序和SHOWDIB程序。 如何改變一個視圖的大小? 通常,你可以調(diào)用函數(shù)MoveWindow()來改變窗口的大小。在用MFC庫開發(fā)的應(yīng)用程序中, 視圖是被框架窗口所圍繞的一個子窗口。為了改變一個視圖的大小,你可以通過調(diào)用函數(shù)GetParentFrame()來得到框架窗口的指針,然后調(diào)用函數(shù)MoveWindow()來改變父窗口的大小。當(dāng)父框架窗口改變大小時,視圖也會自動地改變大小來適應(yīng)父窗口。 如何改變一個CFormView的大小? 要想詳細了解的話,你可以看有關(guān)Visual C++基礎(chǔ)知識的文章Q98598 《Using CFormView in SDI and MDI Applications》。基本上,在從CFormView類派生出來的類中,你必須覆蓋函數(shù)OnInitialUpdate()。其他有關(guān)建立CFormView的細節(jié)問題,可以從該文章中獲得。 在類ClikethisView中聲明如下函數(shù): virtual void OnInitialUpdate(); 在ClikethisView的代碼中,函數(shù)如下: void ClikethisView::OnInitialUpdate() { //使窗口與主對話框同樣大小 CFormView::OnInitialUpdate(); GetParentFrame()-〉RecalcLayout(); ResizeParentToFit( /*FALSE*/ ); } 如何使用一個文檔模板的新視圖? 在用AppWizard創(chuàng)建的應(yīng)用程序中,你有兩種選擇:改變當(dāng)前視圖的派生關(guān)系或者建立一個新視圖并且在你的MDI程序中同時利用新視圖和原先的視圖。 如何改變視圖的背景色? 你可以通過處理WM_ERASEBKGND消息來改變CView、CFrameWnd或CWnd對象的背景色。請看如下的程序段: BOOL CSampleView::OnEraseBkgnd(CDC* pDC) { // 設(shè)置所要求背景色的刷子 CBrush backBrush(RGB(255, 128, 128)); // 保存舊刷子 CBrush* pOldBrush = pDC-〉SelectObject(&backBrush); CRect rect; pDC-〉GetClipBox(&rect); // 擦除所需的區(qū)域 pDC-〉PatBlt(rect.left, rect.top, rect.Width(), rect.Height(), PATCOPY); pDC-〉SelectObject(pOldBrush); return TRUE; } 而我則用如下方法解決這個問題: HBRUSH dlgtest::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) { switch (nCtlColor) { case CTLCOLOR_BTN: case CTLCOLOR_STATIC: { pDC-〉SetBkMode(TRANSPARENT); } case CTLCOLOR_DLG: { CBrush* back_brush; COLORREF color; color = (COLORREF) GetSysColor(COLOR_BTNFACE); back_brush = new CBrush(color); return (HBRUSH) (back_brush-〉m_hObject); } } return(CFormView::OnCtlColor(pDC, pWnd, nCtlColor)); }如何得到當(dāng)前視圖? 最佳方法是將視圖當(dāng)作一個參數(shù)來傳遞。如果不能這樣做,但你確信它是當(dāng)前激活文檔和當(dāng)前激活視圖的話,你也可以得到該視圖。具體細節(jié)見Visual C++文章Q108587《Get Current CDocument or CView from Anywhere》。 簡單說來,用: ((CFrameWnd*) AfxGetApp()-〉m_pMainWnd))-〉GetActiveDocument() 和: ((CFrameWnd*)(AfxGetApp()-〉m_pMainWnd))-〉GetActiveView()來得到文檔和視圖。一個好的方法是將它們封裝在你的CMyDoc和CMyView類的靜態(tài)函數(shù)中,并且核對它們是否屬于正確的RUNTIME_CLASS。然而,假如這個視圖不是當(dāng)前激活視圖或者你在運行OLE本地激活,這樣將不成功。 如何在一個文檔中建立多個視圖? CDocTemplate::CreateNewFrame()函數(shù)創(chuàng)建MFC MDI應(yīng)用程序中的文檔的附加視圖。為了調(diào)用該函數(shù),要指定一個指向CDocument對象(指將為之建立視圖的文檔)的指針和一個指向可從中復(fù)制屬性的框架窗口的指針。一般情形下,該函數(shù)的第二個參數(shù)為NULL。 如何在MDI程序中得到所有的視圖? 你必須用一些文檔中沒有記載的函數(shù): CDocument::GetFirstViewPosition(); // DOCCORE.CPP CDocument::GetNextView(); // DOCCORE.CPP CMultiDocTemplate::GetFirstDocPosition(); // DOCMULTI.CPP CMultiDocTemplate::GetNextDoc(); // DOCMULTI.CPP 你還需要與CWinApp的成員m_templateList打交道。 如何建立一個可用鼠標(biāo)拉動的CScrollView類 在CIS上從MSMFC庫下載AUTOSV.LZH。這個程序告訴你如何實現(xiàn)一個輔助消息循環(huán)來管理鼠標(biāo)的活動,并提供了鉤掛來對代碼進行定制。這是一個免費軟件。 一定要用視圖/文檔結(jié)構(gòu)嗎? MFC并不一定要求你使用文檔/視圖結(jié)構(gòu)。查看HELLO、 MDI和HELLOAPP例子―它們就沒有用那種結(jié)構(gòu)。大多數(shù)MFC特性都可以在非文檔/視圖應(yīng)用程序中得到運用。但是當(dāng)你不用文檔 / 視圖結(jié)構(gòu)時,你確實會失去一些特性,例如打印預(yù)覽和許多OLE特性。 如何得到當(dāng)前文檔? 請詳細參閱"如何得到當(dāng)前視圖?"章節(jié)。 文檔何時被析構(gòu)? 在SDI程序中,程序退出后文檔就被刪除。在MDI程序中,與該文檔相關(guān)的最后一個視圖關(guān)閉時文檔就被刪除。為了在SDI和MDI中同時用這個文檔,你應(yīng)該在虛函數(shù)DeleteContents()函數(shù)中刪除該文檔的數(shù)據(jù),而不是在析構(gòu)器中。 如何建立多文檔? 為了加入對附加文檔類型的支持,你可以在CWinApp派生類中創(chuàng)建和注冊附加CmultiDocTemplate對象。這種方法已經(jīng)在MULTDOCS樣例程序中得以說明。將一個附加文檔類型加入到MFC程序的一般步驟如下: 用AppWizard來創(chuàng)建一個新的文檔類和視圖類。 CMultiDocTemplate* pDocTemplate2 = new CMultiDocTemplate( IDR_DOC2TYPE, RUNTIME_CLASS(CDoc2), RUNTIME_CLASS(CMDIChildWnd),RUNTIME_CLASS(CView2)); AddDocTemplate(pDocTemplate2);最后,將定制的序列化和繪圖代碼加入到你的新文檔和視圖類中。 如何得到一個打開文檔的列表? 下面的程序段指明如何得到用CDocTemplate對象建立的所有文檔的指針列表。 void CMyApp::GetDocumentList(CObList * pDocList) { ASSERT(pDocList-〉IsEmpty()); POSITION pos = m_templateList.GetHeadPosition(); while (pos) { CDocTemplate* pTemplate = (CDocTemplate*)m_templateList.GetNext(pos); POSITION pos2 = pTemplate-〉GetFirstDocPosition(); while (pos2) { CDocument * pDocument; if ((pDocument=pTemplate-〉GetNextDoc(pos2)) != NULL) pDocList-〉A(chǔ)ddHead(pDocument); } } } 在參考手冊或在線幫助中,有兩個CdocTemplate類的公共成員函數(shù)沒有被說明。然而, 這些公共成員函數(shù)在CDocTemplate類中被定義,并且為在打開文檔的列表中前后搜索提供了簡單的支持。 這些函數(shù)如下: 注意,這僅對MFC3.2版本或更低版本有效,對MFC4.0版本請參考下面: void CMyApp::DoSomethingToAllDocs() { CObList pDocList; POSITION pos = GetFirstDocTemplatePosition(); while(pos) { CDocTemplate* pTemplate = GetNextDocTemplate(pos); POSITION pos2 = pTemplate-〉GetFirstDocPosition(); while(pos2) { CDocument* pDocument; if(pDocument = pTemplate-〉GetNextDoc(pos2)) pDocList.AddHead(pDocument); } } if(!pDocList.IsEmpty()){ pos = pDocList.GetHeadPosition(); while(pos) { //為每一個文檔調(diào)用CDocument函數(shù) ( (CDocument*)pDocList.GetNext(pos) ) -〉UpdateAllViews(NULL); } }如何使我的程序在啟動時不創(chuàng)建一個新文檔? 在程序的InitInstance中的ProcessShellCommand函數(shù)之前加入: cmdInfo.m_nShellCommand = CCommandLineInfo::FileNothing |
溫馨提示:喜歡本站的話,請收藏一下本站!