Outlook Add-in(COM加载项)技术指南
2.1.2.2. IDTExtensibility2_OnDisconnection事件
OnDisconnection事件中,我们销毁所有的全局对象。
2.1.2.3. IDTExtensibility2_OnStartupComplete事件
OnStartupComplete事件主要的工作就是,创建工具栏和按钮,如果它们不存在的话。
我们首先搜索Explorer对象的CommandBars集合,以察看我们的“短信速递”工具栏是否存在。如果找到该工具栏,则只需使之可见。
如果没有找到我们的工具栏,那么我们将创建工具栏:
通过传递命令栏的名称及Temporary参数,代码将把新的CommandBar对象添加到CommandBars集合中。
Temporary参数指出Outlook应该在Outlook会话间保持命令栏。然后,代码开始创建命令上的按钮。
为了创建按钮,代码将使用CommandBars对象的Controls集合。
然后,代码将把2个按钮控件添加到集合中。控件类型是由msoControlButton常量来标识的。
代码还将为所有控件传递ID 1;表示这个控件是自定义控件而不是内置控件。
代码还将传递Temporary参数并将它设置为False,以使Outlook在会话间保持按钮。
代码接收到来自于Control集合Add方法的CommandBarButton对象之后,它将开始设置CommandBarButton对象的属性:
u Caption属性:控件的默认屏幕提示;
u FaceId属性:指定按钮的外观。
u Style属性:比如,显示按钮外观和标题文本的msoButtonIconAndCaption。
您看到,我们前面声明g_oCreateSMSBHandler使用WithEvents关键词,被声明为Office.CommandBarButton,
它指出g_oCreateSMSBHandler用来响应CommandBarButton的事件。
2.1.2.4. IDTExtensibility2_OnBeginShutdown事件
OnBeginShutdown事件中,我们销毁所有的全局对象。
2.2.全局引用的变量
在VB中,我们需要使用一些Outlook中的对象模型。下面我们一一列出:
2.2.1.Application对象
这是整个模型的根对象。
根对象提供对其他对象模型的访问。在 Outlook 中使用 VBA 时,Application 对象被隐含声明,
这样您可以选择是否使用 Application 关键字。
2.2.2.NameSpace对象
用于访问存储项目(如文件夹)。“MAPI”是唯一可以使用的名称空间。
2.2.3.Explorer对象
这是显示 Outlook 项目集合的默认界面。每个不同的项目类型都有不同的浏览器。
2.2.4.CommandBars集合
在Office应用程序中,尽管菜单和工具栏按钮看上去不太一样,但实质上它们是相同类型的对象。
CommandBars集合包含程序中的所有命令条,如:工具条和菜单条。
每一个CommandBars集合都有一个CommandBar对象和它对应,CommandBar 对象可以包含其它的 CommandBar 对象,这些对象是作为按钮或菜单命令来用的。每一个CommandBar都将通过CommandBarControls 对象被引用,
CommandBarControls又可以包含一组CommandBarControl对象。每一个CommandBarControl可以包含一个CommandBar对象,并可以通过它来存取控件属性。每一个CommandBarControl对象,实际是对应CommandBarControls中的控件集合。
CommandBarControl可以有三种表现形式:
n 弹出式 (CommandBarPopup): 相当于菜单条的一个菜单项?
n 组合框(CommandBarComboBox):类似于工具条中组合框控件。它包括一个工具栏和紧接着工具栏的一个下拉箭头。单击该按钮,将显示出更多的带图标的菜单命令。
n 按钮(CommandBarButton):相当于标准的工具栏按钮,即带有图标的按钮。
2.2.5.Items集合
Items对象集合包括指定文件夹中所有Item条目对象。其中,
Item对象用于包含特定的 Outlook 数据,例如电子邮件消息、约会或联系人。
Ø Outlook.AppointmentItem 日程的条目对象
Ø Outlook.ContactItem 联系人的条目对象
Ø Outlook.MailItem 邮件的条目对象
Ø Outlook.NoteItem 便笺的条目对象
2.2.6.Selection集合
Selection对象包括在用户界面中用户选定的项目组。
2.3.处理按钮事件
在VB中,我们需要填写类似于“g_oCreateSMSBHandler_Click”函数,对按钮的点击作出响应。下面我们一一列出两个按钮的事件:
2.3.1. g_oCreateSMSBHandler_Click事件
这个按钮的名称是“创建短信”。
“联系人列表”将从您的Outlook联系人中读取,只显示那些提供了移动电话号码的联系人。您点击某一个联系人,我们把这个联系人加入“收信人手机号码”的编辑框中。
本事件主要的事情就是,弹出一个“发送短信”的对话框。并取出联系人中设置了移动号码的。
其他的细节我们就不再介绍了,介绍一下默认Outlook联系人的获取问题:
首先我们通过
Set olContacts = g_oNS.GetDefaultFolder(olFolderContacts).Items
获得默认的联系人文件夹的Items集合。
然后,用
For Each olContact In olContacts
遍历这个Items集合。这个集合中的每一个对象都应该是一个“Outlook.ContactItem”Item对象。所以我们可以获得这个Item对象的显示名称和移动手机号码。
我们只显示那些拥有移动手机号码的联系人。
代码如下所示:
' 准备取出联系人中带有移动号码的作为收信人:
'
Dim olContacts As Outlook.Items
Dim olContact As Outlook.ContactItem
'
' GetDefaultFolder 方法基于 FolderType 参数返回默认的文件夹
' (例如,olFolderInbox 常量将“收件箱”文件夹返回给当前登录的用户)。
' 我们现在选择进入的是:
' 包含 ContactItem 对象和 DistListItem 对象的“联系人”文件夹 (olFolderContacts)。
Set olContacts = g_oNS.GetDefaultFolder(olFolderContacts).Items
frmMenuMain.listContact.Clear
Dim nIndex As Integer
Dim szContactItem As String
nIndex = 0
On Error Resume Next
' 遍历每一个联系人:
For Each olContact In olContacts
If Len(olContact.MobileTelephoneNumber) = 11 Then
' 联系人的显示名称:
szContactItem = Replace(olContact.FileAs, "[", "")
szContactItem = Replace(szContactItem, "]", "")
' 联系人的移动号码:
frmMenuMain.listContact.AddItem szContactItem & "[" & _
olContact.MobileTelephoneNumber & "]", nIndex
nIndex = nIndex + 1
End If
Next
On Error GoTo 0
[版权声明:
第二章部分文字引用自《Programming Microsoft Outlook and Exchange》一书,该书作者Thomas Rizzo,特此声明]
本文档仅供参考。本文档所包含的信息代表了在发布之日,zhengyun对所讨论问题的当前看法,zhengyun不保证所给信息在发布之日以后的准确性。