Outlook add-in 插件.Net开发经验

王朝c#·作者佚名  2006-01-08
宽屏版  字体: |||超大  

Outlook add-in 插件.Net开发经验

第一次写这玩意,记录些开发中的过程,.net开发设置要比在VB里复杂一些,要把office的对象用ms提供的工具包装一下,才能在.Net开发环境里使用。

开发环境设置:

我的开发环境:Windows2K professional + Office XP

Office每个版本的对象,不尽相同,一般新版本兼容旧版本,也有可能会废弃某些对象的接口。我看过Office XP,Office2000的outlook对象,Outlook XP比Outlook2000要多出一些对象和接口函数。

OfficeXP需要配置ms提供的设置文件,具体可看

(下载)。

我使用VB.Net开发,这样直接对Outlook对象编程比较方便(使用withevents),用C#的话,需要自定义事件参数,设置delegate。

对Outlook进行二次开发,可能用到CDO1.21对象,这个不是必需的,按个人需要。使用CDO1.21对象,可以使用一些较为核心的Outlook方法。这些方法,属性在Outlook对象里可能无法使用。

如果需要更直接的设置,获取Outlook对象,可以对MAPI32.dll提供的api接口,进行控制,可以最大限度的操纵Outlook。这些接口直接使用C++编程最方便,我没有具体的做过,只测试了一些,也就不多说了。

开发过程简介:

在vs.net里,其他项目à 扩展性项目 à 共享的外接程序。

选择语言:

选择外接程序的加载到的主程序,这里我只选择outlook:

程序会帮我们自动生成一个Addin项目,包含一个Connect.vb文件,打开看看。

Implements Extensibility.IDTExtensibility2 的接口。

象这样,我们就可以取得outlook的application对象,操纵Outlook。

Dim m_oAddin As olAddin

Public Sub OnConnection(ByVal application As Object, ByVal connectMode As Extensibility.ext_ConnectMode, ByVal addInInst As Object, ByRef custom As System.Array) Implements Extensibility.IDTExtensibility2.OnConnection

Dim oApp As myOutlook.Application

Dim oType As Type

Dim GetProgID As Object

Dim MyProgID As String

Dim oArgs As Object()

Try

m_oAddin = New olAddin

'Use InvokeMember to get ProgID of addInInst object

oType = addInInst.GetType

GetProgID = oType.InvokeMember("ProgID", _

BindingFlags.Public Or BindingFlags.GetField Or BindingFlags.GetProperty, _

Nothing, _

addInInst, _

oArgs)

MyProgID = CType(GetProgID, String)

oApp = CType(application, myOutlook.Application)

'Don't call InitHandler if Explorers.Count = 0 and Inspectors.Count = 0

If oApp.Explorers.Count = 0 And oApp.Inspectors.Count = 0 Then

Exit Sub

End If

' Initialize COMAddin object with this connect object to allow

' external clients to get access to exposed features

oApp.COMAddIns.Item(MyProgID.ToString).Object = Me

'Call InitHandler

m_oAddin.InitHandler(oApp, MyProgID)

Catch ex As SystemException

End Try

End Sub

当然也可以把所有的对outlook的操作,放在一个单独的类中处理:m_oAddin.InitHandler(oApp, MyProgID)

一些注意点:

具体要做些什么,我也不仔细说了,察看msdn就明白了。

我在开发过程中的一些注意,列一下:

在单独类oAddin中处理,加入

1. <GuidAttribute("CA940FE1-1193-411b-82DF-570A04491150"), ProgIdAttribute("AddinForBible.olAddin")>

Public Class OutAddIn

End Class

2. 清除outlook的对象:

Public Sub DisposeObject(ByVal obj As Object)

'Wraps ReleaseCOMObject to provide a 'safe' disposal helper method.

Dim count As Integer

Try

If obj Is Nothing Then

Exit Try

End If

If Not Marshal.IsComObject(obj) Then

Exit Try

End If

count = Marshal.ReleaseComObject(obj)

While count > 0

count = Marshal.ReleaseComObject(obj)

End While

Catch ex As SystemException

Finally

obj = Nothing

End Try

End Sub

3. CDO1.21对象在Office的安装包里可以安装,使用例子:

设置folder的default post message 属性为 自定义 form

这个属性找了很久,msdn里没有提及,留在这里吧,以后也不太会再作outlook开发了

g_olNamespace = m_olOutlookApp.Session

g_olNamespace.Logon(, , False, False)

g_objMAPISession = New MAPI.Session

g_objMAPISession.Logon(, , False, False)

Public Function SetFolderDftMsgPostClass(ByVal sFolderID As String, ByVal sStoreID As String) As Boolean

Dim objMAPIFolder As MAPI.Folder

Dim objMAPIFields As MAPI.Fields

Const PR_DEF_POST_DISPLAYNAME = &H36E6001E '定制form的显示名字

Const PR_DEF_POST_MSGCLASS = &H36E5001E '定制form的MessageClass名称

Try

objMAPIFolder = g_objMAPISession.GetFolder(sFolderID, sStoreID)

objMAPIFields = objMAPIFolder.Fields

Try

If objMAPIFields.Item(PR_DEF_POST_MSGCLASS).value = cVerseMessageClass Then

Exit Try

End If

Catch ex As Exception

With objMAPIFields

.Add(PR_DEF_POST_DISPLAYNAME, cVerseFormName)

.Add(PR_DEF_POST_MSGCLASS, cVerseMessageClass)

End With

objMAPIFolder.Update()

End Try

Catch ex As Exception

Finally

End Try

DisposeObject(objMAPIFields)

DisposeObject(objMAPIFolder)

End Function

4. 其他零零碎碎的也满多的,不再罗嗦了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有