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.
Hinweis |
|---|
| 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.
Hinweis |
|---|
| 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
Aufgaben
Gewusst wie: Ändern des Erscheinungsbilds eines FenstersGewusst wie: Erstellen von Add-Ins
Exemplarische Vorgehensweise: Erstellen eines Assistenten
Konzepte
Automatisieren von wiederkehrenden Aktionen mit MakrosDiagramm "Automationsobjektmodell"
Weitere Ressourcen
Erstellen und Steuern von UmgebungsfensternErstellen von Add-Ins und Assistenten
Referenz zur Automatisierung und Erweiterbarkeit
Hinweis