// [!output CHILD_FRAME_IMPL] : Implementierung der Klasse [!output CHILD_FRAME_CLASS] // #include "stdafx.h" #include "[!output APP_HEADER]" #include "[!output CHILD_FRAME_HEADER]" [!if PROJECT_STYLE_EXPLORER] #include "[!output TREE_VIEW_HEADER]" #include "[!output VIEW_HEADER]" [!endif] #ifdef _DEBUG #define new DEBUG_NEW #endif // [!output CHILD_FRAME_CLASS] IMPLEMENT_DYNCREATE([!output CHILD_FRAME_CLASS], [!output CHILD_FRAME_BASE_CLASS]) BEGIN_MESSAGE_MAP([!output CHILD_FRAME_CLASS], [!output CHILD_FRAME_BASE_CLASS]) [!if !DOCVIEW] ON_COMMAND(ID_FILE_CLOSE, &[!output CHILD_FRAME_CLASS]::OnFileClose) ON_WM_SETFOCUS() ON_WM_CREATE() [!endif] [!if PROJECT_STYLE_EXPLORER] [!if LIST_VIEW] ON_UPDATE_COMMAND_UI_RANGE(AFX_ID_VIEW_MINIMUM, AFX_ID_VIEW_MAXIMUM, &[!output CHILD_FRAME_CLASS]::OnUpdateViewStyles) ON_COMMAND_RANGE(AFX_ID_VIEW_MINIMUM, AFX_ID_VIEW_MAXIMUM, &[!output CHILD_FRAME_CLASS]::OnViewStyle) [!endif] [!endif] END_MESSAGE_MAP() // [!output CHILD_FRAME_CLASS]-Erstellung/Zerstörung [!output CHILD_FRAME_CLASS]::[!output CHILD_FRAME_CLASS]() { [!if ACCESSIBILITY] EnableActiveAccessibility(); [!endif] // TODO: Hier Code für die Memberinitialisierung einfügen } [!output CHILD_FRAME_CLASS]::~[!output CHILD_FRAME_CLASS]() { } [!if APP_TYPE_MDI && SPLITTER] BOOL [!output CHILD_FRAME_CLASS]::OnCreateClient(LPCREATESTRUCT /*lpcs*/, CCreateContext* pContext) { [!if PROJECT_STYLE_EXPLORER] // Splitterfenster erstellen if (!m_wndSplitter.CreateStatic(this, 1, 2)) return FALSE; if (!m_wndSplitter.CreateView(0, 0, RUNTIME_CLASS([!output TREE_VIEW_CLASS]), CSize(100, 100), pContext) || !m_wndSplitter.CreateView(0, 1, RUNTIME_CLASS([!output VIEW_CLASS]), CSize(100, 100), pContext)) { m_wndSplitter.DestroyWindow(); return FALSE; } return TRUE; [!else] [!if HTML_VIEW || HTML_EDITVIEW] return m_wndSplitter.Create(this, 2, 2, // TODO: Spalten- und Zeilenzahl festlegen CSize(10, 10), // TODO: Minimale Größe des Bearbeitungsbereichs festlegen pContext, WS_CHILD | WS_VISIBLE | SPLS_DYNAMIC_SPLIT); [!else] return m_wndSplitter.Create(this, 2, 2, // TODO: Spalten- und Zeilenzahl festlegen CSize(10, 10), // TODO: Minimale Größe des Bearbeitungsbereichs festlegen pContext); [!endif] [!endif] } [!else] [!if PROJECT_STYLE_EXPLORER] BOOL [!output CHILD_FRAME_CLASS]::OnCreateClient(LPCREATESTRUCT /*lpcs*/, CCreateContext* pContext) { // Splitterfenster erstellen if (!m_wndSplitter.CreateStatic(this, 1, 2)) return FALSE; if (!m_wndSplitter.CreateView(0, 0, RUNTIME_CLASS([!output TREE_VIEW_CLASS]), CSize(100, 100), pContext) || !m_wndSplitter.CreateView(0, 1, RUNTIME_CLASS([!output VIEW_CLASS]), CSize(100, 100), pContext)) { m_wndSplitter.DestroyWindow(); return FALSE; } return TRUE; } [!endif] [!endif] BOOL [!output CHILD_FRAME_CLASS]::PreCreateWindow(CREATESTRUCT& cs) { // TODO: Ändern Sie die Fensterklasse oder die Stile hier, indem Sie CREATESTRUCT ändern if( ![!output CHILD_FRAME_BASE_CLASS]::PreCreateWindow(cs) ) return FALSE; [!if !CHILD_FRAME_DEFAULT_STYLES] cs.style = WS_CHILD | WS_VISIBLE | WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | FWS_ADDTOTITLE[!output CHILD_FRAME_STYLE_FLAGS]; [!endif] [!if !DOCVIEW] cs.dwExStyle &= ~WS_EX_CLIENTEDGE; cs.lpszClass = AfxRegisterWndClass(0); [!endif] return TRUE; } // [!output CHILD_FRAME_CLASS]-Diagnose #ifdef _DEBUG void [!output CHILD_FRAME_CLASS]::AssertValid() const { [!output CHILD_FRAME_BASE_CLASS]::AssertValid(); } #endif //_DEBUG // [!output CHILD_FRAME_CLASS]-Meldungshandler [!if PROJECT_STYLE_EXPLORER] [!if LIST_VIEW] [!output VIEW_CLASS]* [!output CHILD_FRAME_CLASS]::GetRightPane() { CWnd* pWnd = m_wndSplitter.GetPane(0, 1); [!output VIEW_CLASS]* pView = DYNAMIC_DOWNCAST([!output VIEW_CLASS], pWnd); return pView; } void [!output CHILD_FRAME_CLASS]::OnUpdateViewStyles(CCmdUI* pCmdUI) { if (!pCmdUI) return; // TODO: Passen Sie diesen Code an, damit die Auswahl im Menü 'Ansicht' behandelt werden kann. [!output VIEW_CLASS]* pView = GetRightPane(); // Wenn der rechte Bereich nicht erstellt wurde und keine Ansicht ist, werden diese Befehle deaktiviert if (pView == NULL) pCmdUI->Enable(FALSE); else { DWORD dwStyle = pView->GetStyle() & LVS_TYPEMASK; // Ist der Befehl ID_VIEW_LINEUP, dann aktivieren Sie den Befehl nur, wenn // wir im Modus LVS_ICON oder LVS_SMALLICON sind if (pCmdUI->m_nID == ID_VIEW_LINEUP) { if (dwStyle == LVS_ICON || dwStyle == LVS_SMALLICON) pCmdUI->Enable(); else pCmdUI->Enable(FALSE); } else { // andernfalls verwenden Sie Punkte, um das Format der Ansicht widerzuspiegeln pCmdUI->Enable(); BOOL bChecked = FALSE; switch (pCmdUI->m_nID) { case ID_VIEW_DETAILS: bChecked = (dwStyle == LVS_REPORT); break; case ID_VIEW_SMALLICON: bChecked = (dwStyle == LVS_SMALLICON); break; case ID_VIEW_LARGEICON: bChecked = (dwStyle == LVS_ICON); break; case ID_VIEW_LIST: bChecked = (dwStyle == LVS_LIST); break; default: bChecked = FALSE; break; } pCmdUI->SetRadio(bChecked ? 1 : 0); } } } void [!output CHILD_FRAME_CLASS]::OnViewStyle(UINT nCommandID) { // TODO: Passen Sie diesen Code an, damit die Auswahl im Menü 'Ansicht' behandelt werden kann. [!output VIEW_CLASS]* pView = GetRightPane(); // Wenn der rechte Bereich erstellt wurde und eine [!output VIEW_CLASS] ist, werden die Menübefehle verarbeitet... if (pView != NULL) { int nStyle = -1; switch (nCommandID) { case ID_VIEW_LINEUP: { // Das Listen-Steuerelement soll sich am Raster ausrichten CListCtrl& refListCtrl = pView->GetListCtrl(); refListCtrl.Arrange(LVA_SNAPTOGRID); } break; // Weitere Befehle ändern das Format im Listen-Steuerelement case ID_VIEW_DETAILS: nStyle = LVS_REPORT; break; case ID_VIEW_SMALLICON: nStyle = LVS_SMALLICON; break; case ID_VIEW_LARGEICON: nStyle = LVS_ICON; break; case ID_VIEW_LIST: nStyle = LVS_LIST; break; } // Format ändern; das Fenster baut sich automatisch neu auf if (nStyle != -1) pView->ModifyStyle(LVS_TYPEMASK, nStyle); } } [!endif] [!endif] [!if !DOCVIEW] void [!output CHILD_FRAME_CLASS]::OnFileClose() { // Senden Sie ein WM_CLOSE, um diesen Rahmen zu schließen, was mit der Auswahl // von "Schließen" im Systemmenü gleichzusetzen ist. SendMessage(WM_CLOSE); } int [!output CHILD_FRAME_CLASS]::OnCreate(LPCREATESTRUCT lpCreateStruct) { if (CMDIChildWnd::OnCreate(lpCreateStruct) == -1) return -1; // Ansicht erstellen, um den Clientbereich des Rahmens zu belegen if (!m_wndView.Create(NULL, NULL, AFX_WS_DEFAULT_VIEW, CRect(0, 0, 0, 0), this, AFX_IDW_PANE_FIRST, NULL)) { TRACE0("Fehler beim Erstellen des Ansichtsfensters.\n"); return -1; } return 0; } void [!output CHILD_FRAME_CLASS]::OnSetFocus(CWnd* pOldWnd) { CMDIChildWnd::OnSetFocus(pOldWnd); m_wndView.SetFocus(); } BOOL [!output CHILD_FRAME_CLASS]::OnCmdMsg(UINT nID, int nCode, void* pExtra, AFX_CMDHANDLERINFO* pHandlerInfo) { // Ansichtsfenster erhält ersten Eindruck vom Befehl if (m_wndView.OnCmdMsg(nID, nCode, pExtra, pHandlerInfo)) return TRUE; // andernfalls die Standardbehandlung durchführen return CMDIChildWnd::OnCmdMsg(nID, nCode, pExtra, pHandlerInfo); } [!endif]