Windows 实时通信技术的应用
原著:Tom Fout
翻译:孟谨
原文出处:MSDN Library January 15, 2002
摘要Windows XP RTC 的客户端 API 使得开发人员能够在自己的应用程序中实现实时通信。本文介绍了 RTC 技术和应用这一技术所必须的组件。
目录 绪论今天,我们可以采取很多方法和我们的伙伴、客户、支持者、家庭和朋友进行交流。E-mail已经成为一个普遍深入的交流方式,但是它的实时性不强。电话被证明是一种好的交流方式并且具有实时性,但是它也有局限性,比如只有声音的交流,并且它缺乏一种机制来使我们知道是否我们交流的另一方已经准备好接听我们的电话。
走进实时通信
Real-Time Communications (RTC)提供了丰富的与现场信息相结合的通信和协作特征,使你能够知道在何时何地找到你的联系人。RTC的许多特征以另外的形式或者在其他的应用中有所体现,但是这些特征从未被结合为一个单独的实现。
例如,Instant Messaging (IM)即时消息是发展最快的Internet通信机制之一,因为它实现简单并且效率高。IM具有实时性,而且具有现场能力,使你知道何时能找到你的联系人。但是它不具备另外一些特征,例如音频和视频会议以及在线合作等。
Microsoft Windows XP 在 Microsoft Windows Messenger 中包含了所有的实时通信功能。Windows Messenger使你能与你的客户和同事通过使用文本、音频(语音电话可以在PC到PC、PC到电话、电话到电话之间建立)、视频、共享白板和应用程序的方式进行交流。你可以建立一个联系人清单,通过现场信息得知你的联系人何时在线何时可以联系得到。并且,这些能力并非只限于Windows Messenger,通过使用RTC客户端API可用来丰富其他的应用程序。
具有 RTC 功能的应用程序Windows Messenger 客户端利用 Windows XP 的 RTC 客户端组件。这一客户端在一个单独的应用程序中体现了所有 RTC 能力。然而,在许多情况下,需要辅助程序进行通信颇显累赘。
RTC 是基于 Internet 技术和协议标准的,这使得其它设备和应用程序能使用这一技术与 Windows Messenger 进行沟通。
Windows XP RTC 客户端实现还提供了一个开放的应用程序接口,因此,基于 Windows 平台的应用程序可增加这些 RTC 功能。例如,一个基于 Web 的购买程序可包含一个即时求助按钮。点击该按钮之后,应用程序就会打开一个在客户与技术支持人员之间建立的 IM 会话。
RTC 程序的应用场合Windows Messenger 在一个单独的应用中包含了 RTC 的许多功能。这一解决方案有许多用处并且在许多场合可能是最好的解决方案。很多情况下,在你的应用程序中包含这些功能会使事情变得更容易,更完善,更棒。
下面是一些将 RTC 功能包含进应用程序的例子。使用这一技术的其它例子还有很多。
客户关系管理-——桌面远程帮助
Jim 想通过在线书店购买一本书,但是他的信用卡好像有点问题。通过点击网页上的一个按钮,他立即与 Amazon(书店的名字)的销售代表建立了 IM 会话。通过 IM 和应用程序共享,该销售代表发现并解决了问题。这本书也被定购了。若没有这种实时帮助的能力,Jim 很可能就放弃了这次购买,这笔生意也就丢掉了。
知识管理--团队和项目的通信站点
产品研发团队的站点有几个责任功能区(例如,客户端和服务器团队)。通过导航到相关的责任区域,用户能够找到一个列出了团队所有成员以及他们在场与否的面板。通过点击相关成员的联系方式,用户能够立即与该团队的那个成员通信。这种即时出席信息减少了潜在的 E-mail 和电话数量,也减少了失败。
电子商务--合作伙伴/供应商的通信
一个大型制造厂商有很多供应商,这些供应商连接到不同的外部网络中。不采用发送电子邮件等方式来讨论订单,他们可以使用 RTC 的客户端 API 开发一个应用程序,用该程序传达特定信息。例如,制造厂商可以使用 IM 发一个 1000 个零部件订单,并使用 IM 能够立即确认订单已经传送到了供应商一方并且进入了供应商的系统。在该订单的处理过程中,状态信息可以根据需要被自动获取。
系统警告--发送至用户桌面 PC 机或者移动设备
某个公司已经开发了一个 E-mail 服务器。为了使技术支持的电话能减少,他们开发了一个小型应用程序,这个程序能通知某一特定 E-mail 服务器的所有用户(使用 IM)该服务器将要暂停以便进行例行的维护保养。即使 E-mail 服务器已经不在线,用户也能收到该消息,使得技术支持人员得以清静。
游戏
大多数的多人游戏都包括了和对手以及同伴聊天的机制。但是你能想象在你将要结束你的朋友的游戏的时候看到他的脸么?
其它用处
在应用程序中 RTC 的功能还有很多其它潜在的用处。通过将 RTC 集成到现存的商业软件中可以实现即时通信和协作,这将提高生产力。使很多行业和部门,包括金融、制造业、医疗保健和人力资源等等从中受益。
RTC客户端应用程序接口为了获得与在 Windows Messenger 中实现的同样的 RTC 客户端功能,Windows XP 通过 RTC 客户端 API 开放了 RTC。这些 API 使应用程序能够创建从 PC-PC, PC-phone 或者 phone-phone 的呼叫。应用程序能够增添在 Internet 或者 Intranet 上创建 IM 会话的功能。在 PC 机用户之间,语音和视频呼叫都可以建立。应用程序能获得并显示一系列联系人的现场信息。通过增加应用程序和白板的共享的功能,可以加强双方的合作。
谁可以使用这些接口呢?内部的开发团体可以使用这些 API 增加内部工具的功能。软件公司可以使用 RTC API 将 RTC 功能集成到自己的应用程序中,或者建立用于出售的专门软件,或者用来满足客户的需要。电话服务提供者可为住宅或者公司用户建立应用程序。想要出售 RTC 服务的电信提供者可通过使用这些 APIs 为他们的客户建立客户端应用程序。可使用 C++ 和 Microsoft Visual Basic建立应用程序。
RTC 对象RTC 的基本编码模型是 COM。在 RTC 中用于通信的对象分别是 Client、Session 对象和Participant 对象。
图一 RTC客户端COM对象
Client 对象:Client 对象实现了 IRTCClient 接口,并且为会话建立了允许的类型和参数,比如首选设备、媒体类型和比特率以及其它的媒体属性,比如音量和回波抵消。这个接口也被用于创建会话对象。
Session 对象:Session 对象通过 IRTCClient::CreateSession 方法创建,被用于管理一个会话。这个对象实现了 IRTCSession 接口,这一接口用于初始化、回复或者终止一个会议,增加参加者和其它的会议管理。这个对象支持 IM 和其它的会话类型。Session 对象可用于,例如,创建一个与你的朋友的IM会议,或者开始一个与 Web 站点代表的音频呼叫。
Participant 对象:Participant 对象由 IRTCSession::AddParticipant 方法创建,包含了与会议参加者有关的所有方法。它包括了参加者的姓名和当前状态。IRTCParticipant 接口由该对象实现。 出席信息由 Buddy 和 Watcher 对象管理。这些对象提供接口,用于管理获取与联系人和出席成员有关的信息。
Buddy 对象:Buddy 对象用于管理、设置和获取与联系人相关的信息。当通过 IRTCClientPresence::AddBuddy 方法添加 某个联系人时(IRTCClientPresence 由 Client 对象实现),Buddy 对象便被创建。诸如联系人姓名和状态这样的信息可由 IRTCBuddy 接口获得。
Watcher 对象:Watcher 用于获取与某个看守人有关的状态(watcher)信息, 看守人就是将你添加为联系人的某人。这个对象也可使用 AddWatcher 方法通过 IRTCClientPresence 接口添加。Watcher 的状态和其 它信息使用在 IRTCWatcher 接口中实现的方法获得。
配置文件和设置配置文件对象用于维护客户端的设置。一个配置文件对象包括了客户端的显示、用户姓名、支持的会议类型和客户端 RTC 提供者的信息。通过这一信息可以获得网络资源情况,并且能用于设置呼叫或者处理出席信息。 配置文件对象由 IRTCClientProvisioning 接口(在 Client 对象中实现)创建。
客户端创建了一个配置文件来存储信息,用于客户进入网络上的服务。一个客户端应用程序必须创建一个 XML 文档来保存客户端的配置。配置文件可 被用于单独设置不同的提供者、代理服务器或者网关给客户端所提供的不同的服务类型。
初始化 RTC 之后,客户端应用程序创建并且激活一个配置文件。
客户端事件RTC 的客户端 API 允许通过不同的客户端事件通知应用程序,包括消息事件、会话状态变化、参与者状态变化、出席状态变化、设备变化和网络质量变化等。在具体实现中,应用程序通过 IRTCClien 接口 建立一个事件过滤器(以屏蔽码形式),并且在应用程序事件接收对象中注册一个 IRTCEventNotification 事件接口。当感兴趣的事件发生时,事件类型和对象 将被提供给客户端的Event 方法进行处理。
RTC 接口上文所讨论了 RTC 对象实现的几个接口。利用这些接口可添加期望的 RTC 功能到某个应用程序中。这些 RTC 接口及其相关方法在 SDK 中有详细的文档描述。
更多信息要想获得关于 XP 的最新信息,请参阅 Windows XP 主页。
要想获得关于 RTC 客户端 API 的详细信息,请参考 SDK 里的 Real-Time Communications (RTC) Client documentation。