Visual Studio provides project templates you can use to create VSTO Add-ins for Microsoft Office PowerPoint. You can use VSTO Add-ins to automate PowerPoint, extend PowerPoint features, or customize the PowerPoint user interface (UI).
For more information about VSTO Add-ins, see Get started programming VSTO Add-ins and Architecture of VSTO Add-ins. If you are new to programming with Microsoft Office, see Get started (Office development in Visual Studio).
Applies to: The information in this topic applies to VSTO Add-in projects for PowerPoint. For more information, see Features available by Office application and project type.
Automate PowerPoint by using the PowerPoint object model
The PowerPoint object model exposes many types that you can use to automate PowerPoint. These types enable you to write code to accomplish common tasks:
Programmatically create and format presentations.
Add or remove slides from presentations.
Add or change shapes on a slide.
To access the PowerPoint object model from a VSTO Add-in, use the
Applicationfield of the
ThisAddInclass in your project. The
Applicationfield returns a Application object that represents the current instance of PowerPoint. For more information, see Program VSTO Add-Ins.
When you call into the PowerPoint object model, you use types that are provided in the primary interop assembly for PowerPoint. The primary interop assembly acts as a bridge between the managed code in the VSTO Add-in and the COM object model in PowerPoint. All types in the PowerPoint primary interop assembly are defined in the Microsoft.Office.Interop.PowerPoint namespace. For more information about primary interop assemblies, see Office solutions development overview (VSTO) and Office primary interop assemblies.
Use the PowerPoint object model documentation
For complete information about the PowerPoint object model, you can refer to the PowerPoint primary interop assembly (PIA) reference and the VBA object model reference.
Primary interop assembly reference
The PowerPoint PIA reference documentation describes the types in the primary interop assembly for PowerPoint. This documentation is available from the following location: PowerPoint 2010 primary interop assembly reference.
For more information about the design of the PowerPoint PIA, such as the differences between classes and interfaces in the PIA and how events in the PIA are implemented, see Overview of classes and interfaces in the Office primary interop assemblies.
VBA object model reference
The VBA object model reference documents the PowerPoint object model as it is exposed to Visual Basic for Applications (VBA) code. For more information, see PowerPoint 2010 object model reference.
All of the objects and members in the VBA object model reference correspond to types and members in the PowerPoint primary interop assembly (PIA). For example, the Presentation object in the VBA object model reference corresponds to the Presentation type in the PowerPoint PIA. Although the VBA object model reference provides code examples for most properties, methods, and events, you must translate the VBA code in this reference to Visual Basic or Visual C# if you want to use them in a PowerPoint VSTO Add-in project that you create by using Visual Studio.
Customize the user interface of PowerPoint
You can modify the UI of PowerPoint in the following ways.
|Task||For more information|
|Create a custom task pane.||Custom task panes|
|Add custom tabs to the Ribbon.||Ribbon overview|
|Add custom groups to a built-in tab on the Ribbon.||How to: Customize a built-in tab|
For more information about customizing the UI of PowerPoint and other Microsoft Office applications, see Office UI customization.
- Walkthrough: Create your first VSTO Add-in for PowerPoint
- Get started programming VSTO Add-ins
- Office solutions development overview (VSTO)
- Architecture of VSTO Add-ins
- How to: Create Office projects in Visual Studio
- Program VSTO Add-ins
- Write code in Office solutions
- Office primary interop assemblies
- Office UI customization
- PowerPoint 2010 in Office development