Walkthrough: Calling Code from VBA in a Visual Basic Project
Applies to |
---|
The information in this topic applies only to the specified Visual Studio Tools for Office projects and versions of Microsoft Office. Project type
Microsoft Office version
For more information, see Features Available by Application and Project Type. |
This walkthrough demonstrates how to call a method in a document-level customization for Microsoft Office Word 2007 from Visual Basic for Applications (VBA) code in the document. The procedure involves three basic steps: add a method to the ThisDocument host item class, expose the method to VBA code, and then call the method from VBA code in the document.
Although this walkthrough uses Word specifically, the concepts demonstrated by the walkthrough also apply to document-level projects for Microsoft Office Excel 2007.
This walkthrough illustrates the following tasks:
Creating a document that contains VBA code.
Trusting the location of the document by using the Trust Center in Word.
Adding a method to the ThisDocument host item class.
Exposing the method to VBA code.
Calling the method from VBA code.
Note
Your computer might show different names or locations for some of the Visual Studio user interface elements in the following instructions. The Visual Studio edition that you have and the settings that you use determine these elements. For more information, see Visual Studio Settings.
For a related video demonstration, see How Do I: Call VSTO Code from VBA?.
Prerequisites
You need the following components to complete this walkthrough:
Visual Studio Tools for Office (an optional component of Visual Studio 2008 Professional and Visual Studio Team System).
Microsoft Office Word 2007.
Visual Studio Tools for Office is installed by default with the listed versions of Visual Studio. To check whether it is installed, see Installing Visual Studio Tools for Office.
Creating a Document That Contains VBA Code
The first step is to create a macro-enabled document that contains a simple VBA macro. The document must contain a VBA project before you create a Visual Studio project that is based on that document. Otherwise, Visual Studio Tools for Office cannot modify the VBA project to enable VBA code to call into the Visual Studio Tools for Office assembly.
If you already have a document that contains VBA code that you want to use, you can skip this step.
To create a document that contains VBA code
Start Word 2007.
Save the active document as a Word Macro-Enabled Document (*.docm) with the name DocumentWithVBA. Save it in a convenient location, such as the desktop.
On the Ribbon, click the Developer tab.
Note
If the Developer tab is not visible, you must first show it. For more information, see How to: Show the Developer Tab on the Ribbon.
In the Code group, click Visual Basic.
The Visual Basic Editor opens.
In the Project window, double-click ThisDocument.
The code file for the ThisDocument object opens.
Add the following VBA code to the code file. This code defines a simple function that does nothing. The only purpose of this function is to ensure that a VBA project exists in the document. This is required for later steps in this walkthrough.
Sub EmptySub() End Sub
Save the document and exit Word.
Creating the Project
Now you can create a document-level project for Word 2007 that uses the macro-enabled document you created earlier.
To create a new project
Start Visual Studio.
On the File menu, point to New, and then click Project. If your IDE is set to use Visual Basic development settings, on the File menu, click New Project.
In the Project Types pane, expand Visual Basic, and then expand Office.
Select the 2007 folder.
In the Templates pane, select the Word document project.
In the Name box, type CallingCodeFromVBA.
Click OK.
The Visual Studio Tools for Office Project Wizard opens.
Select Copy an existing document, and, in the Full path of the existing document box, specify the location of the DocumentWithVBA document that you created earlier. If you are using your own macro-enabled document, specify the location of this document instead.
Click Finish.
Visual Studio opens the DocumentWithVBA document in the designer and adds the CallingCodeFromVBA project to Solution Explorer.
Trusting the Location of the Document
Before you can expose code in your solution to VBA code in the document, you must trust VBA in the document to run. There are several ways to do this. For this walkthrough, trust the location of the document in the Trust Center in Word.
To trust the location of the document
Start Word.
Click the Microsoft Office Button.
Click the Word Options button.
In the categories pane, click Trust Center.
In the details pane, click Trust Center Settings.
In the categories pane, click Trusted Locations.
In the details pane, click Add new location.
In the Microsoft Office Trusted Location dialog box, browse to the folder that contains the CallingCodeFromVBA project.
Select Subfolders of this location are also trusted.
In the Microsoft Office Trusted Location dialog box, click OK.
In the Trust Center dialog box, click OK.
In the Word Options dialog box, click OK.
Exit Word.
Adding a Method to the ThisDocument Class
Now that the VBA project is set up, add a method to the ThisDocument host item class that you can call from VBA code.
To add a method to the ThisDocument class
In Solution Explorer, right-click ThisDocument.vb, and then click View Code.
The ThisDocument.vb file opens in the Code Editor.
Add the following method to the ThisDocument class. This method creates a table with two rows and two columns at the beginning of the document. The parameters specify the text that is displayed in the first row. Later in this walkthrough, you will call this method from VBA code in the document.
Public Sub CreateTable(ByVal firstColumnHeader As String, _ ByVal secondColumnHeader As String) Me.Paragraphs(1).Range.InsertParagraphBefore() Dim table1 As Word.Table = Me.Tables.Add(Me.Paragraphs(1).Range, 2, 2) With table1 .Style = "Table Professional" .Cell(1, 1).Range.Text = firstColumnHeader .Cell(1, 2).Range.Text = secondColumnHeader End With End Sub
Build the project.
Exposing the Method to VBA Code
To expose the CreateTable method to VBA code in the document, set the EnableVbaCallers property for the ThisDocument host item to True.
To expose the method to VBA code
In Solution Explorer, double-click ThisDocument.vb.
The DocumentWithVBA file opens in the designer.
In the Properties window, select the EnableVbaCallers property, and change the value to True.
Click OK in the message that is displayed.
Build the project.
Calling the Method from VBA Code
You can now call the CreateTable method from VBA code in the document.
Note
In this walkthrough, you will add VBA code to the document while debugging the project. The VBA code you add to this document will be overwritten the next time that you build the project, because Visual Studio replaces the document in the build output folder with a copy of the document from the main project folder. If you want to save the VBA code, you can copy it into the document in the project folder. For more information, see Calling Code in Document-Level Customizations from VBA.
To call the method from VBA code
Press F5 to run your project.
On the Developer tab, in the Code group, click Visual Basic.
The Visual Basic Editor opens.
On the Insert menu, click Module.
Add the following code to the new module.
This code calls the CreateTable method in the Visual Studio Tools for Office assembly. The macro accesses this method by using the CallVSTOAssembly property of the ThisDocument object. This property was automatically generated when you set the EnableVbaCallers property earlier in this walkthrough.
Sub CreateTable() Call ThisDocument.CallVSTOAssembly.CreateTable("Employee Name", "Start Date") End Sub
Press F5.
Verify that a new table was added to the document.
Exit Word without saving your changes.
Next Steps
You can learn more about calling code in Visual Studio Tools for Office solutions from VBA in these topics:
Call code in a Visual C# customization from VBA. This process is different from the Visual Basic process. For more information, see Walkthrough: Calling Code from VBA in a Visual C# Project.
Call code in an application-level add-in from VBA. For more information, see Walkthrough: Calling Code in an Application-Level Add-in from VBA.
See Also
Tasks
How to: Expose Code to VBA in a Visual Basic Project
How to: Expose Code to VBA in a Visual C# Project
Walkthrough: Calling Code from VBA in a Visual C# Project