使用NameCtrl为网页集成Office Communicator状态信息

NameCtrl是Office自带的一个ActiveX控件,它存在于C:\Program Files\Microsoft Office\Office12\NAME.DLL中。利用它可以显示 Office Communicator的状态图标,并且图标包含了菜单,通过菜单可以进行聊天,发送邮件等操作。
关于NameCtrl的细节请访问 http://msdn.microsoft.com/en-us/library/bb862236.aspx
Spirit在《 Web系统集成OCS在线状态功能》一文中向大家介绍了如何使用这个控件,而我这篇文章将从NameCtrl的一个方法和一个事件入手,来更完美的在网页中集成Office Communicator状态信息。

先来谈谈直接使用NameCtrl来显示状态的好处吧:
NameCtrl是Office提供的ActiveX控件,我们只需要直接在HTML中编写非常简单的JavaScript代码来和它交互,而不必编写Server端代码,轻而易举的实现Ajax效果。
但是它也有一些缺憾:
首先,NameCtrl是不可以永久显示的,它需要你调用它的 ShowOOUI来显示状态图标,当你点击此状态图标打开菜单,然后关闭菜单后,这个图标也就不见了;
其次,NameCtrl的菜单是不可以自定义的,有时候我们并不想显示这个菜单。

如果你想要像Office Communicator内置的联系人状态显示效果,方法不止一种,本文还是使用NameCtrl控件,利用它的一个方法(GetStatus)和一个事件(OnStatusChange)来完成这样的效果。


下面来介绍一下GetStatus方法和OnStatusChange事件:

GetStatus(bstrName, bstrID)
此方法用来订阅联系人的状态信息。它的参数 bstrName表示联系人的账号;而参数 bstrID则是一个HTML元素的ID,这个ID有什么用呢?请往下看。

MyOnStatusChange(name, status, id)
当通过GetStatus订阅的联系人状态发生了改变,就会触发此事件。它的参数 name表示联系人的账号;参数 status表示联系人的当前状态,是一个int值,下面我会列出可能的值和其含义;参数 id就是我们调用GetStatus是传入的参数bstrID了。
在我的测试中发现,status的值和Office Communicator的默认状态有如下对应关系:
0:空闲
1:显示为脱机;脱机
2:离开
3:忙碌
4:马上回来
9:请勿打扰
中间空了几个是什么我也不知道。

那么在我们的网页中如何使用这两个方法呢?

首先,我们在初始化联系人列表时,在所有联系人前面默认添加一个状态图标(这个图标可以显示为脱机状态),然后,调用GetStatus方法来订阅所有联系人的状态信息。
NameObj.GetStatus(childNode.Attributes[ " Email " ], childNode.ImageElement().id);

 

然后,处理OnStatusChange事件,根据传入参数来改变UI的中相应的状态图标。

   function  MyOnStatusChange(name, status, id)
  {
  
var  img  =  document.getElementById(id);
  img.src 
=   " images/ "   +  status  +   " .png " ;
  }

 

最后,别忘了初始化NameCtrl控件并为其绑定OnStatusChange事件。

   function  InitializeObject() 
  {
  
try
  {
  NameObj 
=   new  ActiveXObject( " Name.NameCtrl " ); 
  NameObj.OnStatusChange 
=  MyOnStatusChange;
  }
  
catch (e){}
  } 
  InitializeObject(); 

OK,看一下最终的效果吧:


不过NameCtrl有个缺陷,如果你为Office Communicator定制了自定义状态,那么这些自定义状态被NameCtrl捕获后,永远是空闲(0)状态。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值