Exemplarische Vorgehensweise: Hinzufügen von Animationen zu einem MFC-Projekt
In dieser exemplarischen Vorgehensweise wird erläutert, wie einem Visual C++-Projekt vom Typ "Microsoft Foundation Class-Bibliothek" (MFC-Bibliothek) ein einfaches animiertes Objekt hinzugefügt wird.
Folgende Aufgaben werden erläutert:
Erstellen einer MFC-Anwendung
Hinzufügen eines Menüs und anschließendes Hinzufügen von Befehle zum Starten und Beenden einer Animation
Erstellen von Handlern für die Befehle zum Starten und Beenden
Hinzufügen eines animierten Objekts zum Projekt
Zentrieren des animierten Objekts im Fenster
Überprüfen der Ergebnisse
Hinweis
Auf Ihrem Computer werden möglicherweise andere Namen oder Speicherorte für die Benutzeroberflächenelemente von Visual Studio angezeigt als die in den folgenden Anweisungen aufgeführten. Diese Elemente sind von der jeweiligen Visual Studio-Version und den verwendeten Einstellungen abhängig. Weitere Informationen finden Sie unter Anpassen der Entwicklungseinstellungen in Visual Studio.
Vorbereitungsmaßnahmen
Um diese exemplarische Vorgehensweise abzuschließen, müssen Sie Visual Studio.
So erstellen Sie eine MFC-Anwendung
Zeigen Sie im Menü Datei auf Neu, und klicken Sie dann auf Projekt.
Erweitern Sie im Dialogfeld Neues Projekt im linken Bereich unter Installierte Vorlagen den Knoten Visual C++, und wählen Sie die Option MFC aus. Klicken Sie im mittleren Bereich auf MFC-Anwendung. Geben Sie im Feld Name den Namen MFCAnimationWalkthrough ein. Klicken Sie auf OK.
Vergewissern Sie sich im Dialogfeld MFC-Anwendungs-Assistent, dass Anwendungstyp auf Mehrere Dokumente und Projektstil auf Visual Studio festgelegt ist. Vergewissern Sie sich außerdem, dass die Unterstützung für die Dokument-/Ansichtarchitektur aktiviert ist. Klicken Sie auf Fertig stellen.
So fügen Sie ein Menü und Befehle zum Starten und Beenden einer Animation hinzu
Zeigen Sie im Menü Ansicht auf Weitere Fenster, und klicken Sie auf Ressourcenansicht.
Navigieren Sie in der Ressourcenansicht zum Ordner Menü, und öffnen Sie ihn. Doppelklicken Sie auf die IDR_MFCAnimationWalTYPE-Ressource, um sie zu öffnen.
Geben Sie auf der Menüleiste im Feld Hier eingeben, A &nimation ein, um einen Animationsmenüs zu erstellen.
unter Animation im Feld Hier eingeben, Starten &Vorwärts ein, um einen entsprechenden Befehl zu erstellen.
unter Vorwärts starten im Feld Hier eingeben, Starten &Rückwärts ein.
unter Rückwärts starten im Feld Hier eingeben, S &oben ein, um einen Befehl zum Beenden zu erstellen.
Speichern Sie "MFCAnimationWalkthrough.rc", und schließen Sie die Ressource.
Doppelklicken Sie im Projektmappen-Explorer auf "MainFrm.cpp", um das Element zu öffnen. Navigieren Sie in der CMainFrame::OnCreate-Methode zu dem Abschnitt, der mehrere Aufrufe von lstBasicCommands.AddTail enthält. Fügen Sie direkt nach diesem Abschnitt den folgenden Code hinzu:
lstBasicCommands.AddTail(ID_ANIMATION_STARTFORWARD); lstBasicCommands.AddTail(ID_ANIMATION_STARTBACKWARD); lstBasicCommands.AddTail(ID_ANIMATION_STOP);
Speichern und schließen Sie die Datei.
So erstellen Sie Handler für die Befehle zum Starten und Beenden
Klicken Sie im Menü Projekt auf Klassen-Assistent.
Wählen Sie im MFC-Klassen-Assistenten unter Klassenname die Option CMFCAnimationWalkthroughView aus.
Wählen Sie auf der Registerkarte Befehle im Feld Objekt-IDs die Option ID_ANIMATION_STARTFORWARD und im Feld Meldungen die Option COMMAND aus. Klicken Sie auf Handler hinzufügen.
Klicken Sie im Dialogfeld Memberfunktion hinzufügen auf OK.
Wählen Sie im Feld Objekt-IDs die Option ID_ANIMATION_STARTBACKWARD und im Feld Meldungen die Option COMMAND aus. Klicken Sie auf Handler hinzufügen.
Klicken Sie im Dialogfeld Memberfunktion hinzufügen auf OK.
Wählen Sie im Feld Objekt-IDs die Option ID_ANIMATION_STOP und im Feld Meldungen die Option COMMAND aus. Klicken Sie auf Handler hinzufügen und anschließend auf OK.
Klicken Sie im Dialogfeld Memberfunktion hinzufügen auf OK.
Klicken Sie im MFC-Klassen-Assistenten auf OK.
Speichern Sie das im Editor geöffnete Element "MFCAnimationWalkthroughView.cpp", aber lassen Sie den Editor geöffnet.
So fügen Sie dem Projekt ein animiertes Objekt hinzu
Doppelklicken Sie im Projektmappen-Explorer auf "MFCAnimationWalkthroughView.h", um das Element zu öffnen. Fügen Sie direkt vor der Definition der CMFCAnimationWalkthroughView-Klasse den folgenden Code hinzu, um einen benutzerdefinierten Animationscontroller zur Behandlung von Planungskonflikten mit dem Animationsobjekt zu erstellen:
class CCustomAnimationController : public CAnimationController { public: CCustomAnimationController() { } virtual BOOL OnHasPriorityTrim(CAnimationGroup* pGroupScheduled, CAnimationGroup* pGroupNew, UI_ANIMATION_PRIORITY_EFFECT priorityEffect) { return TRUE; } };
Fügen Sie am Ende der CMFCAnimationWalkthroughView-Klasse den folgenden Code hinzu:
CCustomAnimationController m_animationController; CAnimationColor m_animationColor; CAnimationRect m_animationRect;
Fügen Sie nach der Zeile DECLARE_MESSAGE_MAP() den folgenden Code hinzu:
void Animate(BOOL bDirection);
Speichern und schließen Sie die Datei.
Fügen Sie in "MFCAnimationWalkthroughView.cpp" am Dateianfang nach den #include-Anweisungen (aber noch vor den Klassenmethoden) den folgenden Code hinzu:
static int nAnimationGroup = 0; static int nInfoAreaHeight = 40;
Fügen Sie am Ende des Konstruktors für CMFCAnimationWalkthroughView den folgenden Code hinzu:
m_animationController.EnableAnimationTimerEventHandler(); m_animationController.EnablePriorityComparisonHandler(UI_ANIMATION_PHT_TRIM); m_animationColor = RGB(255, 255, 255); m_animationRect = CRect(0, 0, 0, 0); m_animationColor.SetID(-1, nAnimationGroup); m_animationRect.SetID(-1, nAnimationGroup); m_animationController.AddAnimationObject(&m_animationColor); m_animationController.AddAnimationObject(&m_animationRect);
Navigieren Sie zur CAnimationWalthroughView::PreCreateWindow-Methode, und ersetzen Sie sie durch den folgenden Code:
BOOL CMFCAnimationWalkthroughView::PreCreateWindow(CREATESTRUCT& cs) { // TODO: Modify the Window class or styles here by modifying // the CREATESTRUCT cs m_animationController.SetRelatedWnd(this); return CView::PreCreateWindow(cs); }
Navigieren Sie zur CAnimationWalkthroughView::OnDraw-Methode, und ersetzen Sie sie durch den folgenden Code:
void CMFCAnimationWalkthroughView::OnDraw(CDC* pDC) { CMFCAnimationWalkthroughDoc* pDoc = GetDocument(); ASSERT_VALID(pDoc); if (!pDoc) return; // TODO: add draw code for native data here CMemDC dcMem(*pDC, this); CDC& dc = dcMem.GetDC(); CRect rect; GetClientRect(rect); dc.FillSolidRect(rect, GetSysColor(COLOR_WINDOW)); CString strRGB; strRGB.Format(_T("Fill Color is: %d; %d; %d"), GetRValue(m_animationColor), GetGValue(m_animationColor), GetBValue(m_animationColor)); dc.DrawText(strRGB, rect, DT_CENTER); rect.top += nInfoAreaHeight; CBrush br; br.CreateSolidBrush(m_animationColor); CBrush* pBrushOld = dc.SelectObject(&br); dc.Rectangle((CRect)m_animationRect); dc.SelectObject(pBrushOld); }
Fügen Sie am Ende der Datei den folgenden Code hinzu:
void CMFCAnimationWalkthroughView::Animate(BOOL bDirection) { static UI_ANIMATION_SECONDS duration = 3; static DOUBLE dblSpeed = 35.; static BYTE nStartColor = 50; static BYTE nEndColor = 255; BYTE nRedColorFinal = bDirection ? nStartColor : nEndColor; BYTE nGreenColorFinal = bDirection ? nStartColor : nEndColor; BYTE nBlueColorFinal = bDirection ? nStartColor : nEndColor; CLinearTransition* pRedTransition = new CLinearTransition(duration, (DOUBLE)nRedColorFinal); CSmoothStopTransition* pGreenTransition = new CSmoothStopTransition(duration, (DOUBLE)nGreenColorFinal); CLinearTransitionFromSpeed* pBlueTransition = new CLinearTransitionFromSpeed(dblSpeed, (DOUBLE)nBlueColorFinal); m_animationColor.AddTransition(pRedTransition, pGreenTransition, pBlueTransition); CRect rectClient; GetClientRect(rectClient); rectClient.top += nInfoAreaHeight; int nLeftFinal = bDirection ? rectClient.left : rectClient.CenterPoint().x; int nTopFinal = bDirection ? rectClient.top : rectClient.CenterPoint().y; int nRightFinal = bDirection ? rectClient.right : rectClient.CenterPoint().x; int nBottomFinal = bDirection ? rectClient.bottom : rectClient.CenterPoint().y; CLinearTransition* pLeftTransition = new CLinearTransition(duration, nLeftFinal); CLinearTransition* pTopTransition = new CLinearTransition(duration, nTopFinal); CLinearTransition* pRightTransition = new CLinearTransition(duration, nRightFinal); CLinearTransition* pBottomTransition = new CLinearTransition(duration, nBottomFinal); m_animationRect.AddTransition(pLeftTransition, pTopTransition, pRightTransition, pBottomTransition); CBaseKeyFrame* pKeyframeStart = CAnimationController::GetKeyframeStoryboardStart(); CKeyFrame* pKeyFrameEnd = m_animationController.CreateKeyframe(nAnimationGroup, pBlueTransition); pLeftTransition->SetKeyframes(pKeyframeStart, pKeyFrameEnd); pTopTransition->SetKeyframes(pKeyframeStart, pKeyFrameEnd); pRightTransition->SetKeyframes(pKeyframeStart, pKeyFrameEnd); pBottomTransition->SetKeyframes(pKeyframeStart, pKeyFrameEnd); m_animationController.AnimateGroup(nAnimationGroup); }
Klicken Sie im Menü Projekt auf Klassen-Assistent.
Wählen Sie im MFC-Klassen-Assistenten unter Klassenname die Option CMFCAnimationWalkthroughView aus.
Wählen Sie auf der Registerkarte Meldungen im Feld Meldungen die Option WM_ERASEBKGND aus, klicken Sie auf Handler hinzufügen, und klicken Sie anschließend auf OK.
Ersetzen Sie in "MFCAnimationWalkthroughView.cpp" die Implementierung von OnEraseBkgnd durch den folgenden Code, um das Flimmern des animierten Objekts beim Neuzeichnen zu verringern:
BOOL CMFCAnimationWalkthroughView::OnEraseBkgnd(CDC* /*pDC*/) { return TRUE; }
Ersetzen Sie die Implementierungen von CMFCAnimationWalkthroughView::OnAnimationStartforward, CMFCAnimationWalkthroughView::OnAnimationStartbackward und CMFCAnimationWalkthroughView::OnAnimationStop durch den folgenden Code:
void CMFCAnimationWalkthroughView::OnAnimationStartforward() { Animate(TRUE); } void CMFCAnimationWalkthroughView::OnAnimationStartbackward() { Animate(FALSE); } void CMFCAnimationWalkthroughView::OnAnimationStop() { IUIAnimationManager* pManager = m_animationController.GetUIAnimationManager(); if (pManager != NULL) { pManager->AbandonAllStoryboards(); } }
Speichern und schließen Sie die Datei.
So zentrieren Sie das animierte Objekt im Fenster
Doppelklicken Sie im Projektmappen-Explorer auf "MFCAnimationWalkthroughView.h", um das Element zu öffnen. Fügen Sie am Ende der CMFCAnimationWalkthroughView-Klasse direkt nach der Definition von m_animationRect den folgenden Code hinzu:
BOOL m_bCurrentDirection;
Speichern und schließen Sie die Datei.
Klicken Sie im Menü Projekt auf Klassen-Assistent.
Wählen Sie im MFC-Klassen-Assistenten unter Klassenname die Option CMFCAnimationWalkthroughView aus.
Wählen Sie auf der Registerkarte Meldungen im Feld Meldungen die Option WM_SIZE aus, klicken Sie auf Handler hinzufügen, und klicken Sie anschließend auf OK.
Ersetzen Sie in "MFCAnimationWalkthroughView.cpp" den Code für CMFCAnimationWalkthroughView::OnSize durch den folgenden Code:
void CMFCAnimationWalkthroughView::OnSize(UINT nType, int cx, int cy) { CView::OnSize(nType, cx, cy); CRect rect; GetClientRect(rect); rect.top += nInfoAreaHeight; CRect rectAnim = m_animationRect; m_animationRect = CRect(CPoint(rect.CenterPoint().x - rectAnim.Width() / 2, rect.CenterPoint().y - rectAnim.Height() / 2), rectAnim.Size()); if (m_animationController.IsAnimationInProgress()) { Animate(m_bCurrentDirection); } }
Fügen Sie am Anfang des Konstruktors für CMFCAnimationWalkthroughView den folgenden Code hinzu:
m_bCurrentDirection = TRUE;
Fügen Sie am Anfang der CMFCAnimationWalkthroughView::Animate-Methode den folgenden Code hinzu:
m_bCurrentDirection = bDirection;
Speichern und schließen Sie die Datei.
So überprüfen Sie die Ergebnisse
- Erstellen Sie die Anwendung, und führen Sie sie aus. Klicken Sie im Menü Animation auf Vorwärts starten. Ein Rechteck wird angezeigt und füllt den mittleren Bereich aus. Wenn Sie auf Rückwärts starten klicken, wird die Animation umgekehrt. Durch Klicken auf Beenden wird die Animation beendet. Die Füllfarbe des Rechtecks ändert sich im Laufe der Animation, und die aktuelle Farbe wird am oberen Rand des Animationsfensters angezeigt.