0 von 2 fanden dies hilfreich - Dieses Thema bewerten.

Gewusst wie: Steuern von Makros mithilfe von Add-Ins

Das Macros-Objekt im Automatisierungsmodell von Visual Studio dient zur programmgesteuerten Steuerung von Makros, die in der integrierten Entwicklungsumgebung (Integrated Development Environment – IDE) aufgezeichnet wurden. Sie können damit folgende Aufgaben durchführen:

  • Die Makroaufzeichnung anhalten und fortsetzen.

  • Dem Makro, das aufgezeichnet wird, Codezeilen hinzufügen.

  • Bestimmen, ob die Makroaufzeichnung momentan ein Makro aufzeichnet.

Sie können außerdem mithilfe der ExecuteCommand-Methode direkt einen Befehl an die IDE ausgeben, z. B. den Befehl zum Erstellen einer neuen Datei.

NoteHinweis

Die Macros-Objektmember sind nicht zur Verwendung innerhalb eines Makros bestimmt, sondern können nur innerhalb eines Add-Ins verwendet werden.

Im unten aufgeführten Visual Basic-Beispiel wird veranschaulicht, wie die verschiedenen Member des Automatisierungsmodells für Makros verwendet werden und wie auf sie verwiesen wird.

NoteHinweis

Je nach den aktiven Einstellungen oder der verwendeten Version können sich die angezeigten Dialogfelder und Menübefehle von den in der Hilfe beschriebenen unterscheiden. Bei der Entwicklung dieser Prozeduren war die Option Allgemeine Entwicklungseinstellungen aktiviert. Wählen Sie im Menü Extras die Option Einstellungen importieren und exportieren aus, um die Einstellungen zu ändern. Weitere Informationen finden Sie unter Visual Studio-Einstellungen.

Beispiel

Im folgenden Beispiel wird überprüft, ob gerade ein Makro aufgezeichnet wird. Wenn ja, wird dem Makro eine zusätzliche Codezeile hinzugefügt.

public void OnConnection(object application, ext_ConnectMode 
  connectMode, object addInInst, ref Array custom)
{
    _applicationObject = (DTE2)application;
    _addInInstance = (AddIn)addInInst;
    macroTest(_applicationObject);
}

public void macroTest(DTE2 dte)
{
    try
    {
        Macros objMac = dte.Macros;
        // Determine if a macro is recording. If it is, 
        // add a line of code to it and then let it resume 
        // recording.
        if (objMac.IsRecording == true)
        {
            objMac.EmitMacroCode("MsgBox(\"This was added by 
              code.\")");
        }
        else
        {
            System.Windows.Forms.MessageBox.Show("Macro is not 
              recording.");
        }
    }
    catch (Exception ex)
    {
        System.Windows.Forms.MessageBox.Show(ex.Message);
    }
}

Wenn Sie ein Makro aufzeichnen und eine Textdatei öffnen, sieht der Makrocode folgendermaßen aus:

Public Module RecordingModule
    Sub TemporaryMacro()
        DTE.ItemOperations.NewFile("General\Text File")
    End Sub
End Module

Wenn Sie den Beispielcode ausführen und dieselbe Ausgabe ausführen, wird dem Makrocode eine zusätzliche Zeile hinzugefügt:

Public Module RecordingModule
    Sub TemporaryMacro()
        DTE.ItemOperations.NewFile("General\Text File")
        MsgBox("This line was added by code.")
    End Sub
End Module

Siehe auch

Fanden Sie dies hilfreich?
(1500 verbleibende Zeichen)
© 2013 Microsoft. Alle Rechte vorbehalten.