int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CFrameWnd::OnCreate(lpCreateStruct) == -1)
return -1;
if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP
| CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
!m_wndToolBar.LoadToolBar(IDR_MAINFRAME))
{
TRACE0("Failed to create toolbar\n");
return -1; // fail to create
}
if (!m_wndStatusBar.Create(this) ||
!m_wndStatusBar.SetIndicators(indicators,
sizeof(indicators)/sizeof(UINT)))
{
TRACE0("Failed to create status bar\n");
return -1; // fail to create
}
if (!m_newToolBar.CreateEx(this,TBSTYLE_FLAT,WS_CHILD|WS_VISIBLE|CBRS_RIGHT
|CBRS_GRIPPER|CBRS_TOOLTIPS|CBRS_FLYBY|CBRS_SIZE_DYNAMIC)
||!m_newToolBar.LoadToolBar(IDR_TOOLBAR1))
{
TRACE0("Failed to create toolbar\n");
return -1; // fail to create
}
// TODO: Delete these three lines if you don't want the toolbar to
// be dockable
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
m_newToolBar.EnableDocking(CBRS_ALIGN_ANY);
EnableDocking(CBRS_ALIGN_ANY);
DockControlBar(&m_wndToolBar);
DockControlBar(&m_newToolBar);
CTime time = CTime::GetCurrentTime();
CString strTime = time.Format("%H:%M:%S");
CClientDC dc(this);
CSize sz = dc.GetTextExtent(strTime);
int index = m_wndStatusBar.CommandToIndex(IDS_TIMER);
m_wndStatusBar.SetPaneInfo(index,IDS_TIMER,SBPS_NORMAL,sz.cx);
m_wndStatusBar.SetPaneText(index,strTime);
SetTimer(1,1000,NULL);
return 0;
}
void CMainFrame::OnTimer(UINT nIDEvent)
{
// TODO: Add your message handler code here and/or call default
CTime time = CTime::GetCurrentTime();
CString strTime = time.Format("%H:%M:%S");
CClientDC dc(this);
CSize sz = dc.GetTextExtent(strTime);
int index = m_wndStatusBar.CommandToIndex(IDS_TIMER);
m_wndStatusBar.SetPaneInfo(index,IDS_TIMER,SBPS_NORMAL,sz.cx);
m_wndStatusBar.SetPaneText(index,strTime);
CFrameWnd::OnTimer(nIDEvent);
}
CFrameWnd::EnableDocking
void EnableDocking(DWORD dwDockStyle);
参数: dwDockStyle 指定框架窗口的哪一边可作为控件条的停靠点,可为以下之中的一个或几个:
· CBRS_ALIGN_TOP 允许停靠到用户区的顶部。
· CBRS_ALIGN_BOTTOM 允许停靠到用户区底部。
· CBRS_ALIGN_LEFT 允许停靠到用户区左边。
· CBRS_ALIGN_RIGHT 允许停靠到用户区右边。
· CBRS_ALIGN ANY 允许停靠到用户区任意一边。
说明:
调用此成员函数使框架窗口中的可停靠控件条可用。缺省时,控件条会以下面顺序停靠于框架窗口中:顶部、底部、左部、右部。
CControlBar类成员
CControlBar::EnableDocking
void EnableDocking( DWORD dwStyle );
参数: dwStyle 指定是否允许控件条处于停靠状态和它在父窗口中停靠的位置。停靠位置参数如下: · CBRS_ALIGN_TOP 允许停靠在客户区的上方。
· CBRS_ALIGN_BOTTOM 允许停靠在客户区的下方。
· CBRS_ALIGN_LEFT 允许停靠在客户区的左边。
· CBRS_ALIGN_RIGHT 允许停靠在客户区的右边。
· CBRS_ALIGN_ANY 允许停靠在客户区的任意一边
· CBRS_FLOAT_MULTI 允许在一个小的框架窗口中浮动有多个控件条。
为0时(即没有指明标志)不允许停靠控件条。
说明:
本函数设置是否允许控件条处于停靠状态。可以给控件条指定停靠位置。