data:image/s3,"s3://crabby-images/4d730/4d7302e6ddc2c67ef819de0ecee3aa07afd8eba5" alt="Sample image"
Introduction
In this article, we will learn how to create a simple Hello World browser add-in for Microsoft�s applications that supports add-in. A list of such applications is given here:
- Microsoft Word
- Microsoft VSMacros IDE
- Microsoft Visual Studio .NET
- Microsoft Visio
- Microsoft Publisher
- Microsoft Project
- Microsoft PowerPoint
- Microsoft Outlook
- Microsoft FrontPage
- Microsoft Excel
- Microsoft Access
In this article, we will take Microsoft Outlook as an example.
Prerequisites:
You must have the following �
- Microsoft Development Environment 2003 or higher
- Microsoft .NET Framework 2.0
- Office Primary Interop Assemblies (PIAs). For Office XP, click here to download.
Creating the Add-in
- Run the Microsoft Development Environment.
- Go to File> New Project>, a dialog will appear.
- Go to Other Projects> Extensibility Project, select Shared Add-in type project template.
Add-In Wizard
When the Add-in wizard starts, press Next...
data:image/s3,"s3://crabby-images/03b63/03b63e4889b1a123d02df3f25bb91ee5a0b95ed9" alt="Sample image"
Select programming language (example C#), press Next.
data:image/s3,"s3://crabby-images/5cb81/5cb81bd8a70a1438ec0c329994e48a3ae055c561" alt="Sample image"
Select applications in which you want to host your add-in, press Next.
data:image/s3,"s3://crabby-images/e2b64/e2b64fcc8d16d40d42026b50d59408263d1c72de" alt="Sample image"
Provide add-in name and description, press Next.
data:image/s3,"s3://crabby-images/b5bd8/b5bd8e6da6dd025e8c4993929930771ece3e5d80" alt="Sample image"
Choose add-in options, press Next.
data:image/s3,"s3://crabby-images/736ed/736ed66c4c55fd2ef7ca70c4aa43a438201de09a" alt="Sample image"
Press Finish.
data:image/s3,"s3://crabby-images/61611/61611e745411d3015ecb7bd83a913cfea9ec1cf6" alt="Sample image"
Setup Projects
Two projects will be added automatically.
- Add-in project.
- Setup project.
Creating the Browser Form
- Add a form for the Add-in project, named frmHelloWorld.cs.
- Add a
Label
, TextBox
, and a PictureBox
.
- Add a Microsoft web browser control to the form (you can get it by right clicking on the toolbox, selecting Add/Remove Items, and clicking on the �COM Components�: a lot of controls will be listed, select Microsoft Web Browser Control, and press OK.
- With the following code, create a function
go()
:
void go()
{
try
{
stbPanel1.Text="Trying to open "+tbURL+"..." ;
object obj=new object ();
browser.Navigate(tbURL.Text,ref obj,ref obj,ref obj,ref obj);
}
catch(Exception ex)
{
}
}
Call this function on the PictureBox
's Click
event.
Programming for Add-in Connection
Install PIAs and add a reference to the following DLL: Microsoft.Office.Interop.Outlook.DLL.
data:image/s3,"s3://crabby-images/18548/18548be0f9cf55f91a86fbe94be9adc393302bdf" alt="Sample image"
There will be a file connect.cs in the add-in project, open it. Declare the following items globally:
private Microsoft.Office.Interop.Outlook.Application applicationObject;
private object addInInstance;
private CommandBarButton btnLaunch;
In the function OnStartupComplete
, write the following code:
public void OnStartupComplete(ref System.Array custom)
{
CommandBars commandBars =
applicationObject.ActiveExplorer().CommandBars;
try
{
btnLaunch= (CommandBarButton)
commandBars["Standard"].Controls["HelloWorld"];
}
catch
{
btnLaunch = (CommandBarButton)
commandBars["Standard"].Controls.Add(1,
System.Reflection.Missing.Value,
System.Reflection.Missing.Value,
System.Reflection.Missing.Value,
System.Reflection.Missing.Value);
btnLaunch.Caption = "Hello World Browser!";
btnLaunch.Style = MsoButtonStyle.msoButtonCaption;
}
btnLaunch.Tag = "This is Hello World Browser!";
btnLaunch.OnAction = "!<EMAILSTATSADDIN.CONNECT>";
btnLaunch.Visible = true;
btnLaunch.Click += new
_CommandBarButtonEvents_ClickEventHandler(
btnLaunch_Click);
}
In the function OnBeginShutdown
, write the following code:
public void OnBeginShutdown(ref System.Array custom)
{
CommandBars commandBars = applicationObject.ActiveExplorer().CommandBars;
try
{
commandBars["Standard"].Controls["HelloWorld"].Delete(
System.Reflection.Missing.Value);
}
catch(System.Exception ex)
{
}
}
Write the following code in the btnLanuch
event handler:
private void btnLaunch_Click(CommandBarButton Ctrl,
ref bool CancelDefault)
{
try
{
frmHelloWorld objfrmHelloWorld=new frmHelloWorld ();
objfrmHelloWorld.Show();
}
catch(Exception ex)
{
}
}
Rebuild and Installation
Right click on the setup project, click Rebuild, and it will automatically rebuild the add-in and the setup project. Then, right click on the setup project and click Install.
Running
Run Microsoft Outlook, and you will see �Hello World Browser!� on the toolbar. Click on it and your add-in will start. As you can see here...
data:image/s3,"s3://crabby-images/4d730/4d7302e6ddc2c67ef819de0ecee3aa07afd8eba5" alt="Sample image"
Known Issues
After uninstallation, the �Hello World Browser!� button is not removed from the Outlook toolbar.