Пример текста макроса уровня приложения на C#

В данном примере класс Revit.DB.Geometry.XYZ служит для задания положения (в координатах X, Y, Z) текстового примечания, которое при выполнении макрокоманд добавляется в текстовом поле на активном виде активного документа.

В IDE для метода используйте следующую программу:

public
void MyFirstMacroAppCS(){
Autodesk.Revit.DB.XYZ
baseVec = Application.Create.NewXYZ(1.0, 0.0, 0.0);Autodesk.Revit.DB.XYZ
upVec = Application.Create.NewXYZ(0.0, 0.0, 1.0); Autodesk.Revit.DB.XYZ
origin = Application.Create.NewXYZ(0.0, 0.0, 0.0);
Autodesk.Revit.DB.TextAlignFlags align
= Autodesk.Revit.DB.TextAlignFlags.TEF_ALIGN_LEFT | Autodesk.Revit.DB.TextAlignFlags.TEF_ALIGN_TOP;
string
strText = "My First Macro, App level, C#!"; double
lineWidth = 4.0 / 12.0;
Autodesk.Revit.DB.View
pView = ActiveUIDocument.Document.ActiveView;Autodesk.Revit.DB.Transaction
t = new Autodesk.Revit.DB.Transaction(ActiveUIDocument.Document, "NewTextNote");t.Start();ActiveUIDocument.Document.Create.NewTextNote(pView,
origin, baseVec, upVec, lineWidth, align, strText);
t.Commit();
}

Следует учитывать, что данная макрокоманда уровня приложения предназначена для изменения документа, поэтому для ее правильной работы необходимо начать транзакцию (t.Start();) и завершить ее (t.Commit();).

Текстовое поле, размещенное макросом

Совет: Не забудьте скомпоновать проект в Revit macro IDE перед его запуском из Диспетчера макросов.