Inventor.AddinTemplate
                             
                            
                                1.2.3
                            
                        
                    dotnet new install Inventor.AddinTemplate::1.2.3

Inventor Add-in Template
The goal of this template is to make creating an Inventor addin as easy as possible. All that is required is to create the buttons and write the code that will be executed when the buttons are clicked. The template will handle adding the buttons to the ribbon.
Features
- Simplifies the creation of Inventor addins
- Automatically adds buttons to the ribbon
- Supports light and dark themes
- Easy to extend and customize
Getting Started
1️⃣ Creating Buttons
3️⃣ Referencing the Inventor Interop
4️⃣ Installing and Using this Template
1️⃣ Creating Buttons
All buttons need to inherit the InventorButton class, which contains abstract
properties for all of the required information for creating a button. There are
also some optional properties and methods that can be used.
Adding button to the Ribbon
The InventorButton class handles adding the button to the ribbon and executing
the code when the button is clicked. All subclasses (i.e., user defined buttons)
in the project are automatically loaded into the Inventor UI. A button can be
prevented from being loaded by overriding the Enabled property to return
false.
Command Execution
The code that should run when the button is clicked should be placed in the
Execute() method.
Required Properties/Methods
| Name | Description | 
|---|---|
| Execute( NameValueMapcontext,Inventor.Applicationinventor) | This is the code that will execute when the button is clicked by the user. The Inventor.Applicationargument is the active instance of Inventor | 
| RibbonName | The internal name of the Ribbon the button will be added to. See Internal Naming | 
| RibbonTabName | The name of the Ribbon Tab the button will be added to. If an Internal name of an existing Ribbon Tab is used, the button will be added to that Tab. Otherwise, a new tab will be created. See Internal Naming | 
| RibbonPanelName | The name of the Ribbon Panel the button will be added to. If an Internal name of an existing Ribbon Panel is used, the button will be added to that Panel. Otherwise, a new panel will be created. See Internal Naming | 
| Label | The display name of the button. This value will be shown as the text for the button if ShowLabelis set to true | 
| Description | The description text for the button | 
| Tooltip | the tool tip text for the button | 
| LargeIconResourceName | The resource to be used as the Large Icon for the button. See Icon Resources | 
| DarkThemeLargeIconResourceName | The resource to be used as the Large Icon when Inventor's Dark Theme is used. See Icon Resources | 
| SmallIconResourceName | The resource to be used as the Small Icon for the button. See Icon Resources | 
| DarkThemeSmallIconResourceName | The resource to be used as the Small Icon when Inventor's Dark Theme is used. See Icon Resources | 
Internal Naming
The NuGet package Inventor.InternalNames is referenced in this template and contains all of the Internal Names for the Inventor Ribbon, RibbonTabs, and RibbonPanels.
Icon Resources
Button icons need to be .PNG files and be added to the project as embedded resources. Large icons should be 32px by 32px and small icons should be 16px by 16px.
Optional Properties/Methods
| Name | Default Value | Description | 
|---|---|---|
| UseLargeIcon | true | Whether the button will be displayed with a Large Icon | 
| ShowText | true | Whether the button's label will be displayed | 
| Enabled | true | Whether the button will be displayed | 
| SequenceNumber | 0 | Used to control the order that the buttons are added (if creating multiple buttons). Buttons are ordered lowest to highest from Left to Right / Top to Bottom | 
| ConfigureProgressiveToolTip( ProgressiveToolTiptoolTip) | Allows configuring a progressive tooltip. The LabelandTooltipproperties will be ignored if this is used. Refer to Autodesk's ProgressiveToolTip Documentation for the available properties forProgressiveToolTip | |
| OnHelp( NameValueMapcontext, outHandlingCodeEnumhandlingcode) | Only Available if using a Progressive Tool Tip. Allows overriding what happens when a user selects F1 while the progressive tool tip is being displayed. Refer to Autodesk's ButtonDefinition.OnHelp Event Documentation | 
Example
using System.Windows.Forms;
using Inventor;
using Inventor.InternalNames.Ribbon;
namespace Inventor.AddinTemplate.Buttons
{
    public class DefaultButton : InventorButton
    {
        protected override void Execute(NameValueMap context, Inventor.Application inventor)
        {
            MessageBox.Show($"Current document name: {inventor.ActiveDocument.DisplayName}");
        }
        protected override string RibbonName => InventorRibbons.Drawing;
        protected override string RibbonTabName => DrawingRibbonTabs.PlaceViews;
        protected override string RibbonPanelName => "Inventor.AddinTemplate";
        protected override string Label => "DefaultButton";
        protected override string Description => "Default Button Description";
        protected override string Tooltip => "Click the Default Button";
        protected override string LargeIconResourceName => "Inventor.AddinTemplate.Buttons.Assets.Default-Light.png";
        protected override string DarkThemeLargeIconResourceName => "Inventor.AddinTemplate.Buttons.Assets.Default-Dark.png";
        protected override string SmallIconResourceName => LargeIconResourceName;
        protected override string DarkThemeSmallIconResourceName => DarkThemeLargeIconResourceName;
    }
}
2️⃣ Deploying Your Addin
Deploying your addin is fairly simple. Just copy the build contents of your project and put them in the correct folder so that Inventor can find them.
The only catch is there are multiple locations that Inventor looks for addins to load. Deciding on which location to use will depend on the following factors:
- Should it load for all users of the computer or only a specific user?
- Should it load for all versions of Inventor or only a specific version?
Load for All Users and all Versions of Inventor
%AllUsersProfile%\Autodesk\ApplicationPlugins
Load for All Users and a Specific Version of Inventor
%AllUsersProfile%\Autodesk\Inventor 2024\Addins
Load for a Specific User and all Versions of Inventor
This is the recommended installation location by Autodesk
%AppData%\Autodesk\ApplicationPlugins
Load for a Specific User and a Specific Version of Inventor
%AppData%\Autodesk\Inventor 2024\Addins
3️⃣ Referencing the Inventor Interop
Inventor Addins must reference the Inventor Interop library
(Autodesk.Inventor.Interop.dll) in order to access Inventor's API. This
template includes a copy of the Inventor 2023 Interop in the lib folder. If
needed, you can change the reference to a different version. The
Autodesk.Inventor.Interop.dll can be found in the following location:
C:\Program Files\Autodesk\Inventor 20xx\Bin\Public Assemblies
xx should be set to the version of Inventor you want to reference.
Keeping the Interop Up to Date
This article on Mod the Machine explains how the different versions of the Interop work and how you can be sure that your app continues to work even with new versions of Inventor.
4️⃣ Installing and Using this Template
The easiest way to install this template is by using the dotnet CLI. Simply run the following command and the project will then show in Visual Studio and JetBrains Rider:
dotnet new install Inventor.AddinTemplate


- 
                                                    .NETFramework 4.7.2- Inventor.InternalNames (>= 0.5.0)
- System.Resources.Extensions (>= 9.0.9)
 
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 1.2.3 | 116 | 9/27/2025 | 
| 1.2.2 | 222 | 9/15/2025 | 
| 1.2.2-fix-target-frame0001 | 220 | 9/15/2025 | 
| 1.2.1 | 277 | 4/9/2025 | 
| 1.2.0 | 198 | 4/9/2025 | 
| 1.1.1 | 229 | 3/12/2025 | 
| 1.1.0 | 237 | 3/11/2025 | 
| 1.1.0-fix-template-inp0003 | 188 | 3/11/2025 | 
| 1.1.0-fix-template-inp0002 | 250 | 3/11/2025 | 
| 1.1.0-alpha0019 | 194 | 3/11/2025 | 
| 1.0.7 | 235 | 11/23/2024 | 
| 1.0.6 | 156 | 11/3/2024 | 
| 1.0.6-beta0002 | 128 | 11/3/2024 | 
| 1.0.6-beta0001 | 128 | 11/3/2024 | 
| 1.0.5 | 2,816 | 2/23/2024 | 
| 1.0.3 | 831 | 2/15/2024 | 
| 1.0.2 | 663 | 2/14/2024 | 
| 1.0.1 | 785 | 2/10/2024 | 
| 1.0.0 | 614 | 2/9/2024 | 
| 0.1.14 | 719 | 2/8/2024 | 
| 0.1.13 | 782 | 2/8/2024 | 
| 0.1.12 | 747 | 2/8/2024 | 
| 0.1.11 | 817 | 2/8/2024 | 
| 0.1.10 | 796 | 2/8/2024 | 
| 0.1.9 | 726 | 2/8/2024 | 
| 0.1.8 | 819 | 2/8/2024 | 
| 0.1.7 | 800 | 2/8/2024 |