My First Plug-in Training
[This page has been updated to work with Revit 2025. If you are interested in previous versions, i.e., Revit 2023&2024, you can download the pdf version of the training materials from here ]
Lesson 1: The Basic Plug-in
Steps to Create Your First Plug-in
- Launch the Visual Studio development environment:
Open Visual Studio using the Windows Start menu, selecting All Programs, and then Microsoft Visual Studio.
Supported .NET version for Revit version is as follows:
- Revit 2025 - .NET 8.0 (Long Term Support)
Note: previous versions of Revit 2023 and 2024 uses .NET 4.8. If you are interested in the training materials using previous versions of Revit, you can download the pdf version of the materials from here ],
You can find the developer guide for the versions here:
Revit 2025: https://help.autodesk.com/view/RVT/2025/ENU/?guid=Revit_API_Revit_API_Developers_Guide_html
- Create a class library project:
- Open Visual Studio.
- Navigate to the "Get started" section. Click on "Create a new project".
data:image/s3,"s3://crabby-images/d0d55/d0d5530c5f9e8278399414a31fd428070770d793" alt=""
c. Select "C#" from languages.
d. Choose "All platforms”.
e. Select "Library" as the project type.
data:image/s3,"s3://crabby-images/85f33/85f33b84a1b592b9718549db5f8a566b95a3f372" alt=""
f. Now, choose "Class Library – A project for creating a class library that targets .NET or .NET Standard" from the available options. Click on the "Next" button.
g. Enter "Lab1PlaceGroup" as the Project Name.
data:image/s3,"s3://crabby-images/7424c/7424cd3a8e6e3c7a8c54111e5dd9b71e313ba7a5" alt=""
h. Type "C:\test" in the Location box.
i. Click on the "Next" button.
j. In the "Framework" section, choose ".NET 8.0 (Long Term Support)". Finally, click on the "Create" button to create the project.
data:image/s3,"s3://crabby-images/7087d/7087d756e6f9e331f7acadcf95463a5c9b048a9b" alt=""
- Add references:
In the "View" menu, you'll see "Solution Explorer". Click on it. This action should open the Solution Explorer window.
Within the Solution Explorer, right-click "Dependencies" and select "Add Project Reference...".
data:image/s3,"s3://crabby-images/81d7a/81d7a5617542061a2176512577165de2d7341899" alt=""
- Click the Browse tab and in the Add Reference dialog and browse to the Revit product installation sub-folder. (The sub-folder path depends on where you have installed Revit 20xx. The default path is C:\Program Files\Autodesk\Revit 20xx\*).
data:image/s3,"s3://crabby-images/3c3ce/3c3ceab87d5ddc51d5d57e4719378c5ce1fb28d2" alt=""
You will add two reference files from this folder. Select RevitAPI.dll, hold the Ctrl key and select RevitAPIUI.dll, and then click OK. Now the two interface DLL files are referenced in your project. All the Revit APIs are exposed by these interface files and your project can use all of those available APIs from them.
- Set the referenced files' Copy Local property value
In the Solution Explorer window you saw in step 4, right click RevitAPI under Assemblies node and choose properties. In the Properties window, click Copy Local property, and then click the drop-down list, select No. Repeat the same steps to change RevitAPIUI's Copy Local property value to No.
data:image/s3,"s3://crabby-images/87069/87069956fb1c56b6f155a3e928da119a28c3d98d" alt=""
data:image/s3,"s3://crabby-images/b64f4/b64f43746b158b1bcbcc01f1a67f2046813d6e73" alt=""
- Add the code:
Double click Class1.cs in the Solution Explorer window to show the code-editing window. Delete everything in this window and then type the following C# code. To get the full experience of developing with Visual Studio – including the use of features such as IntelliSense – we recommend you type the code from this guide rather than copying and pasting it. That said, if constrained for time you can also copy and paste into the Visual Studio code window: although this reduces the experience you gain from working with the code directly.
using Autodesk.Revit.DB;
using Autodesk.Revit.Attributes;
using Autodesk.Revit.UI;
using Autodesk.Revit.UI.Selection;
namespace Lab1PlaceGroup
{
[Transaction(TransactionMode.Manual)]
public class Class1 : IExternalCommand
{
public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
{
//Get application and document objects
UIApplication uiapp = commandData.Application;
Document doc = uiapp.ActiveUIDocument.Document;
//Define a reference Object to accept the pick result
Reference pickedref;
//Pick a group
Selection sel = uiapp.ActiveUIDocument.Selection;
pickedref = sel.PickObject(ObjectType.Element, "Please select a group");
Element elem = doc.GetElement(pickedref);
Group? group = elem as Group;
//Pick point
XYZ point = sel.PickPoint("Please pick a point to place group");
//Place the group
Transaction trans = new Transaction(doc);
trans.Start("Lab");
doc.Create.PlaceGroup(point, group?.GroupType);
trans.Commit();
return Result.Succeeded;
}
}
}
Don't worry about the details of the code for now, you'll come back to this shortly in the next couple of lessons.
- Save the file:
On the File menu, click Save All.
- Build the project:
The code you have written is in human readable form. To make the code readable by a computer, you will need to translate it or “build” it.
Inside Visual Studio, in the Build menu, click Build Solution to compile and build your plug-in. Build Success message shows in status bar of the Visual Studio window if the code is successfully built.
data:image/s3,"s3://crabby-images/9676b/9676b4ea2e942eac620e3e83cf2adf9a865b5586" alt=""
- Supress Warnings
After building the solution, you will encounter numerous warnings displayed in the output window located at the bottom of the Visual Studio interface.
data:image/s3,"s3://crabby-images/b13be/b13bec14e33e1c20f0bdaadaa1eab003bff1a940" alt=""
In this tutorial code, they are benign.
To suppress these warnings, follow these steps:
- Navigate to the Solution Explorer.
- Right-click on "Lab1PlaceGroup" and select "Properties."
data:image/s3,"s3://crabby-images/16184/161843cdd27cdbf2a1a454118454ded9cf060db7" alt=""
- In the properties window, under the "Build" tab, navigate to "General."
- Change the "Platform target" to "x64."
data:image/s3,"s3://crabby-images/0b520/0b52064bba63b4b350dc1a5603539347c1c46703" alt=""
Next:
- Still in the "Build" tab, navigate to "Errors and Warnings."
- Add ";MSB3277" to the existing list to suppress warnings effectively.
data:image/s3,"s3://crabby-images/bc2fb/bc2fbc8c9646484a1d18c424ec6e0fec91e85204" alt=""
Once these settings are configured:
- Proceed to build the solution as instructed in step 8.
data:image/s3,"s3://crabby-images/db476/db4763d08d34e2e9164d6068421f8fc720c3c232" alt=""
Upon completion of the build process, you will observe that the warnings are successfully suppressed, and the status bar of the Visual Studio window will display the message "Build succeeded."
That’s it! You have just written your first plug-in for Autodesk Revit.
Before you actually work with the plug-in in Revit, you will need to do one more step, which is to write an AddIn manifest.
Writing an AddIn Manifest
An AddIn manifest is a file located in a specific location checked by Revit when the application starts. The manifest includes information used by Revit to load and run the plug-in.
- Add the manifest code:
Start Notepad.exe from the Windows Start menu. Copy and paste the following plug-in load settings to the Notepad editor.
Note: In the add-in file, you will see a <AddInId>GUID </AddInId> tag.It is a GUID that represents the id of this particular application. AddInId must be unique for a given session of Revit. Autodesk recommends you generate a unique GUID for each registered application or command.
<?xml version="1.0" encoding="utf-8"?>
<RevitAddIns>
<AddIn Type="Command">
<Name>Lab1PlaceGroup</Name>
<FullClassName>Lab1PlaceGroup.Class1</FullClassName>
<Text>Lab1PlaceGroup</Text>
<Description>Places the Group at Particular Point</Description>
<VisibilityMode>AlwaysVisible</VisibilityMode>
<Assembly>C:\test\Lab1PlaceGroup\Lab1PlaceGroup\bin\Debug\net8.0\Lab1PlaceGroup.dll</Assembly>
<AddInId>502fe383-2648-4e98-adf8-5e6047f9dc34</AddInId>
<VendorId>ADSK</VendorId>
<VendorDescription>Autodesk, Inc, www.autodesk.com</VendorDescription>
</AddIn>
</RevitAddIns>
Depending on the environment you are working on, you may need to change the path here to match your Lab1PlaceGroup.dll location on your computer:
C:\test\Lab1PlaceGroup\Lab1PlaceGroup\bin\Debug\net8.0\Lab1PlaceGroup.dll
- Save the file:
On Notepad’s File menu, click Enter MyFirstPlugin.addin in the File name box. Change Save as type to the All Files option (the file name is up to you; however, the file extension must be “.addin”). Browse to the following subfolder, and then click the Save button.
Under Windows 10 - C:\ProgramData\Autodesk\Revit\Addins\20xx\ (The ProgramData folder is hidden by default)
For example, here is the setting in Save As dialog in Windows 10 for Revit 2025.
data:image/s3,"s3://crabby-images/eabc2/eabc2190af5fc0fc1fd612a074f64b070ddb0f97" alt=""
- Load your plug-in into Revit and allow the plug-in to communicate with Revit:
Start Revit. Open the sample model HOTEL.rvt.
Inside Revit on the Add-Ins ribbon tab, click the External Tools drop-down list, then click Lab1PlaceGroup. This will start your plug-in.
data:image/s3,"s3://crabby-images/51738/51738b7d2bef6ebb2d0d97c3775459823c73b4a5" alt=""
- Work with the plug-in:
Move the cursor over Room1 in the Revit building model. When the cursor is hovering over the furniture group, its bounding box should be highlighted as per the below picture, with a tooltip showing Model Groups : Model Group : Group 1. Click to select this furniture group. (Note: when highlighted the room looks very similar to the group. Please carefully select the group according to the message in the tooltip. If the room is selected, you will not see the expected result after the following step.)
data:image/s3,"s3://crabby-images/6ce7f/6ce7f6b96ed4ad11129ef5bbac04793288fc1398" alt=""
NOTE: Make sure the TOOLTIP message is ModelGroups, then click to pick.
- Pick a point in another room, for example in Room 2. You should see the group copied to this location. The center of the new group is the point you selected.
data:image/s3,"s3://crabby-images/ab476/ab476a34735aa071f549c9b347e739cda27be1b8" alt=""
Congratulations! You have just written your first plug-in for Autodesk Revit. You will be reviewing the code in detail in Lesson 3.
Before you move on to the next lessons, let us go back to some of the things we skipped over earlier, starting with basics concept about programming, and the benefits it can bring to your day-to-day work.
Additional Topics
Introduction to Programming
The C# code you have just executed to copy a group is only 30 lines long. Here you see a small amount of code working in a similar way to the internal Revit command, Create Similar. Software programming allows you to capture the logic of a particular functionality once and then reap the benefits over and over again, every time you want to perform this functionality.
What is Programming?
A simple answer to this question is: Computer programming is the process of creating a sequence of instructions to tell the computer to do something. You can look at your program as a sequence of instructions. During the course of the upcoming lessons, you will look at the various lines and blocks of code and look at them all in the context of being instructions for a computer.
If you were to explain what computers are to a young child, you might say: a computer is a tool which follows instructions you provide. Programming is one way of giving instructions to the computer. Internally, a computer sees these instructions encoded as a series of numbers (also called machine code). The human-readable instructions you saw at the beginning of this lesson is called source code and the computer converts these instructions to machine code which it can then read and execute. A sequence of such instructions (or code), written to perform a specific task, is called a program and a collection of such programs and related data is called a software. Autodesk Revit is one such software product.
Source code can be written in different languages, just as humans use different languages to communicate between ourselves. The language you will be using in this guide is called C# (pronounced “C-Sharp”).
What is an API?
API is the acronym for Application Programming Interface: the way a software programmer can communicate with a software product. For instance, the Revit API is the way programmers can work with Revit, and it establishes what functionality a software programmer can use within Revit. Such as the Revit API allows you to write instructions for Revit to execute one after the other.
data:image/s3,"s3://crabby-images/214d5/214d5e08bc24331a4da3547ed66a4e3129b99159" alt=""
What is a Plug-in?
A software plug-in is a type of program module (or file) that adds functionality to a software product, usually in the form of a command automating a task or some customization of the product’s behavior. When you talk about a plug-in for Revit – and you will also hear the term Add-In used for this product – we mean a module containing code that makes use of the Revit API. Revit loads such plug-ins and uses them to adjust its behavior under certain conditions, such as when a particular command is executed by the user of the plug-in.