一、CSplitterWnd的創(chuàng)建函數(shù)主要有下面三個:
//功能描述:該函數(shù)用來創(chuàng)建動態(tài)切分窗口。
//參數(shù)含義:pParentWnd 切分窗口的父框架窗口。
//nMaxRows,nMaxCols是創(chuàng)建的最大的列數(shù)和行數(shù)。
//sizeMin是窗格的現(xiàn)實大小。
//pContext 大多數(shù)情況下傳給父窗口。
//nID是子窗口的ID號.
BOOL Create(CWnd* pParentWnd,int nMaxRows,int nMaxCols,SIZE sizeMin,
CCreateContext* pContext,DWORD dwStyle,UINT nID);
//功能描述:用來創(chuàng)建靜態(tài)切分窗口。 參數(shù)含義同上。
BOOL CreateStatic(CWnd* pParentWnd,int nRows,int nCols,DWORD dwStyle,UINT nID);
//功能描述:為靜態(tài)切分的窗口的網(wǎng)格填充視圖
//在將視圖于切分窗口聯(lián)系在一起的時候必 須先將切分窗口創(chuàng)建好。
BOOL CreateView (int row,int col,CruntimeClass* pViewClass,
SIZE sizeinit,CcreateContext* pContext);
二、創(chuàng)建動態(tài)拆分窗口
創(chuàng)建動態(tài)拆分窗口用Create()方法,對于所有的窗格,都必須共享同一個視圖,所受的限制也比較多,因此我們不將動態(tài)創(chuàng)建作為重點。
三、創(chuàng)建靜態(tài)拆分窗口
與動態(tài)創(chuàng)建相比,靜態(tài)創(chuàng)建的代碼要簡單許多,而且可以最多創(chuàng)建16x16的窗格。不同的窗格我們可以使用CreateView()填充不同的視圖。
在這里我們將創(chuàng)建CuteFtp的窗口分割。CuteFtp的分割情況如下:
CCuteFTPView
CView2 CView3
CView4
創(chuàng)建步驟:
▲ 在創(chuàng)建之前我們必須先用AppWizard生成單文檔CuteFTP,生成的視類為 CCuteFTPView.同時在增加三個視類或者從視類繼承而來的派生類CView2,CView3 CView4.
▲ 增加成員:
在CMainFrm.h中我們將增加下面的代碼:
CSplitterWnd wndSplitter1;
CSplitterWnd wndSplitter2;
▲ 重載CMainFrame::OnCreateClient()函數(shù):

BOOL CMainFrame::OnCreateClient( LPCREATESTRUCT /**//*lpcs*/, CCreateContext* pContext)


{
//創(chuàng)建一個靜態(tài)分欄窗口,分為三行一列
if(m_wndSplitter1.CreateStatic(this,3,1)==NULL)
return FALSE;

//將CCuteFTPView連接到0行0列窗格上
m_wndSplitter1.CreateView(0,0,RUNTIME_CLASS(CCuteFTPView),CSize(100,100), pContext);

//將CView4連接到0行2列
m_wndSplitter1.CreateView(2,0,RUNTIME_CLASS(CView4),CSize(100,100),pContext);

//將第1行0列再分開1行2列
if(m_wndSplitter2.CreateStatic(&m_wndSplitter,1,2,WS_CHILD|WS_VISIBLE,
m_wndSplitter.IdFromRowCol(1, 0))==NULL)
return FALSE;

//將CView2類連接到第二個分欄對象的0行0列
m_wndSplitter2.CreateView(0,0,RUNTIME_CLASS(CView2),CSize(400,300),pContext);
//將CView3類連接到第二個分欄對象的0行1列
m_wndSplitter2.CreateView(0,1,RUNTIME_CLASS(CView3),CSize(400,300),pContext);

return TRUE;
}
四、實現(xiàn)各個分割區(qū)域的通信
■有文檔相連的視圖之間的通信
由AppWizard生成的CCuteFTPView是與文檔相連的,同時我們也讓CView2與文檔相連,因此我們需要修改CCuteFTPApp的InitInstance()函數(shù),我們將增加下面的部分。
AddDocTemplate (new CMultiDocTemplate(IDR_VIEW2TYPE,
RUNTIME_CLASS(CMainDoc),
RUNTIME_CLASS(CMDIChildWnd),
RUNTIME_CLASS(CView2)));
我們現(xiàn)在來實現(xiàn)CCuteFTPView與CView2之間的通信。由于跟文檔類相連的視圖類 是不能安全的與除文檔類之外的其余的視圖類通信的。因此我們只能讓他們都與文檔 類通信。在文檔中我們設(shè)置相應(yīng)的指針以用來獲的各個視圖。
首先在CCuteFTPDoc.h文件中定義視圖類的指針變量
CCuteFTPView* m_pCuteFTPView;
CView2* m_pView2;
然后,我們重載CCuteFTPDoc::OnOpenDocument()函數(shù)
POSITION pos;
CView* pView;
while(pos!=NULL)


{
pView=GetNextView(pos);
if(pView->IsKindOf(RUNTIME_CLASS(CCuteFTPView))==NULL)
m_pCuteFTPView=(CCuteFTPView*)pView;
else(pView->IsKindOf(RUNTIME_CLASS(CCuteFTPView))==NULL)
m_pView2=(CView2*)pView;
}
這樣我們在文檔類中就獲的了跟它相連的所有的視圖的指針。
如果需要在 CCuteFTPView中調(diào)用CView2中的一個方法DoIt()則代碼如下:
CCuteFTPDoc* pDoc=GetDocument();
CView2* pView2=pDoc->m_pView2;
pView2.DoIt();
■無文檔視圖與文檔關(guān)聯(lián)視圖之間的通信
CView3和CView4都是不與文檔相關(guān)聯(lián)的。我們現(xiàn)在實現(xiàn)CView3與CView2的通信,正如前面所說,CView2只能安全的與CCuteFTPDoc通信,因此,CView3如果需要跟CView2通信,也必須借助于文檔類。因此程序的關(guān)鍵是如何在CView3中獲得文檔的指針。視圖類中沒有這樣的類成員可以用來直接訪問文檔類。但是我們知道在主窗口類MainFrame中我們可以獲得程序的任意窗口類的指針。因此我們只要獲得了程序主窗口的指針,就可以解決問題了。下面代碼實現(xiàn)在CView3中訪問CView2中的DoIt()方法。
CMainFrame* MainFrame=(CMainFrame*)this->GetParent()->GetParent();

CCuteFTPDoc* pDoc=(CCuteFTPDoc*)MainFrame->GetActiveDocument();
if(pDoc!=NULL) pDoc->DoIt();
CCuteFTPDoc中的相應(yīng)的處理函數(shù)DoIt()代碼如下:
CView2* pView2;
POSITION pos;
CView* pView;
while(pos!=NULL)


{
pView=GetNextView(pos);
if(pView->IsKindOf(RUNTIME_CLASS(CView2))==NULL)
pView2=(CView2*)pView;
}
pView2->DoIt();
■無文檔關(guān)聯(lián)視圖之間的通信
CView3和CView4都是不跟文檔相連的,如何實現(xiàn)他們之間的通信呢。 正如我們在上面所說的那樣,由于在主框架中我們可以訪問任意的視圖,因此我們的主要任務(wù)還是在程序中獲得主框架的指針。下面代碼實現(xiàn)在CView3中訪問CView4中的方法DoIt()。
CMainFrame* MainFrame=(CMainFrame*)this->GetParent()->GetParent();

CView4* View4=(CView4*)MainFrame->m_wndSplitter1.GetPane(2,0);
View4->DoIt();
到現(xiàn)在我們已經(jīng)實現(xiàn)了CuteFTP的主窗口的框架并且能夠?qū)崿F(xiàn)他們之間相互通信的框架。
















二、創(chuàng)建動態(tài)拆分窗口
創(chuàng)建動態(tài)拆分窗口用Create()方法,對于所有的窗格,都必須共享同一個視圖,所受的限制也比較多,因此我們不將動態(tài)創(chuàng)建作為重點。
三、創(chuàng)建靜態(tài)拆分窗口
與動態(tài)創(chuàng)建相比,靜態(tài)創(chuàng)建的代碼要簡單許多,而且可以最多創(chuàng)建16x16的窗格。不同的窗格我們可以使用CreateView()填充不同的視圖。
在這里我們將創(chuàng)建CuteFtp的窗口分割。CuteFtp的分割情況如下:
CCuteFTPView
CView2 CView3
CView4
創(chuàng)建步驟:
▲ 在創(chuàng)建之前我們必須先用AppWizard生成單文檔CuteFTP,生成的視類為 CCuteFTPView.同時在增加三個視類或者從視類繼承而來的派生類CView2,CView3 CView4.
▲ 增加成員:
在CMainFrm.h中我們將增加下面的代碼:






























四、實現(xiàn)各個分割區(qū)域的通信
■有文檔相連的視圖之間的通信
由AppWizard生成的CCuteFTPView是與文檔相連的,同時我們也讓CView2與文檔相連,因此我們需要修改CCuteFTPApp的InitInstance()函數(shù),我們將增加下面的部分。





首先在CCuteFTPDoc.h文件中定義視圖類的指針變量


然后,我們重載CCuteFTPDoc::OnOpenDocument()函數(shù)












如果需要在 CCuteFTPView中調(diào)用CView2中的一個方法DoIt()則代碼如下:



■無文檔視圖與文檔關(guān)聯(lián)視圖之間的通信
CView3和CView4都是不與文檔相關(guān)聯(lián)的。我們現(xiàn)在實現(xiàn)CView3與CView2的通信,正如前面所說,CView2只能安全的與CCuteFTPDoc通信,因此,CView3如果需要跟CView2通信,也必須借助于文檔類。因此程序的關(guān)鍵是如何在CView3中獲得文檔的指針。視圖類中沒有這樣的類成員可以用來直接訪問文檔類。但是我們知道在主窗口類MainFrame中我們可以獲得程序的任意窗口類的指針。因此我們只要獲得了程序主窗口的指針,就可以解決問題了。下面代碼實現(xiàn)在CView3中訪問CView2中的DoIt()方法。




CCuteFTPDoc中的相應(yīng)的處理函數(shù)DoIt()代碼如下:












■無文檔關(guān)聯(lián)視圖之間的通信
CView3和CView4都是不跟文檔相連的,如何實現(xiàn)他們之間的通信呢。 正如我們在上面所說的那樣,由于在主框架中我們可以訪問任意的視圖,因此我們的主要任務(wù)還是在程序中獲得主框架的指針。下面代碼實現(xiàn)在CView3中訪問CView4中的方法DoIt()。




到現(xiàn)在我們已經(jīng)實現(xiàn)了CuteFTP的主窗口的框架并且能夠?qū)崿F(xiàn)他們之間相互通信的框架。