您的位置: 首页 >> 新闻中心 >> 计算机 >> 软件开发
用VB做一个MSN的信息群发工具
精英教育阅读提示:MSN是目前网络上广泛使用的一个即时信息交流工具(IM),笔者就常用它与同事或朋友联系,但是在使用过程中发现缺乏一个群发信息的功能,于是笔者寻思着自己编写一个MSN信息群发的软件,在查阅了一番资料之后,终于写出来了。
■ 最新课程推荐更多课程>>
学校培训课程开课时间上课地点精英价报名
正辰培训 微软软件测试工程师电话预约西直门教学区¥4704
新 科 海 软件测试工程师就业班电话预约海淀长远天地¥6280
北 师 大 软件工程与测试实战班电话预约北京师范大学¥1800
北 师 大 高级网络工程师就业班电话预约北京师范大学¥13000
金 同 方 网络工程师就业周末班电话预约人大总部¥7000

  下面大家和我一起动手来自己做一个MSN的信息群发工具。

  第一步:新建一个工程。启动VB,选择“文件”菜单的“新建”子菜单新建一个VB工程,系统回自动添加一个窗体,并且取名叫Form1。

  第二步:添加MSN接口的引用。点击VB的IDE环境的菜单中的工程菜单,在弹出的下拉菜单中选择“引用(N)...”子菜单。在弹出的“引用”窗体中的“可用的引用”下拉列表中找到“Messenger API Type Library” 项,将起前面的钩打上,然后关闭“引用”窗口。

  第三步:设置窗体,添加控件。首先在VB的工程管理器中双击Form1,打开窗体设计环境。选中窗体,将它的Caption值改为“MSN消息群发”。然后在窗体上添加控件,并且设置其初始属性。要添加的控件的信息见下表:

  名称 类型 Caption属性的值

  Label1 Label 群发对象:

  Combo1 ComboBox

  Check1 CheckBox 只发送在线的

  Label2 Label 消息内容:

  Text1 TextBox

  Command1 CommandButton 发送[&O]

  Command2 CommandButton 退出[&X]

  添加完控件后调整其位置,

  第四步:编写代码。

以下是引用片段:
  Dim m_MSG As New MessengerAPI.Messenger 'MSN的Com对象
  Dim m_Groups As MessengerAPI.IMessengerGroups 'MSN中的分组
  Dim m_Group As MessengerAPI.IMessengerGroup 'MSN中组的内容
  Dim m_Contracts As MessengerAPI.IMessengerContacts 'MSN中的所有的好友的信息
  Dim m_Contract As MessengerAPI.IMessengerContact 'MSN中每个好友对象的内容
  Private Sub Command1_Click()
  Dim i As Integer
  '检测需要发送的信息是否合法
  If Trim(Text1.Text) = "" Then
  MsgBox "发送的信息不能为空!", VBInformation, "提示"
  Text1.SetFocus
  Exit Sub
  End If
  '判断消息的发送对象是全部好友还是某个组的成员
  If Combo1.ListIndex = 0 Then
  Set m_Contracts = m_MSG.MyContacts
  Else
  Set m_Groups = m_MSG.MyGroups
  Set m_Group = m_Groups.Item(Combo1.ListIndex - 1)
  Set m_Contracts = m_Group.Contacts
  End If
  '遍历要发送的对象,发送信息
  For i = 0 To m_Contracts.Count - 1
  Set m_Contract = m_Contracts.Item(i)
  If Check1.Value = 1 Then
  If m_Contract.Status = 2 Then
  m_MSG.InstantMessage m_Contract '打开要发送的好友窗体
  DoEvents
  SendKeys Text1.Text '写入信息
  DoEvents
  SendKeys "{enter}" '发送出信息
  DoEvents
  SendKeys "%{F4}" '关闭好友窗口
  End If
  Else
  m_MSG.InstantMessage m_Contract
  DoEvents
  SendKeys Text1.Text
  DoEvents
  SendKeys "{enter}"
  DoEvents
  SendKeys "%{F4}"
  End If
  Next i
  '成功发送完毕信息
  If MsgBox("发送完毕!是否清空消息?", vbInformation + vbYesNo, "提示") = VBYes Then
  Text1.Text = ""
  Text1.SetFocus
  Else
  Text1.SetFocus
  End If
  End Sub
  Private Sub Command2_Click()
  Unload Me
  End
  End Sub
  '初始化控件
  Private Sub Form_Load()
  Dim i As Integer
  '初始化发送对象的下拉框
  Set m_Groups = m_MSG.MyGroups
  With Combo1
  .AddItem "全部的组"
  For i = 0 To m_Groups.Count - 1
  Set m_Group = m_Groups.Item(i)
  .AddItem m_Group.Name
  Next i
  .ListIndex = 0
  End With
  End Sub
  '释放变量
  Private Sub Form_Unload(Cancel As Integer)
  Set m_MSG = Nothing
  Set m_Groups = Nothing
  Set m_Group = Nothing
  Set m_Contracts = Nothing
  Set m_Contract = Nothing
  End Sub

本新闻共2页,当前在第1页  1  2

  影视动画培训   北大BEC培训官方报名网站   2008美国夏令营启航官方指定报名网站   2008留学第一站!  
  北师大 火星时代
共举影视动画培训之鼎
  北大BEC培训官方报名网站
现在报名独享95折!
  2008年国家职业资格考试
一次过关完全备考手册
  2008留学第一站
留学资讯尽在精英留学站!
 
上一篇:VB与Oracle数据库中的日期转换
下一篇:有关VB记录类型变量
 相关新闻
·2006年下半年软件设计师考试答案·我从外行到专业的软件测试工程师
·软件工程师现有工作满意率仅为7.1%·软件资格和软件水平考试的业界评价
·风雨过后见彩虹 谈我的软考经历·自学通过软件设计师考试后的一些感想
·关于软件资格水平考试,我很想说几句·从软件设计师试题看软件测试七原则
·软件设计师考试必看 如何应考?·45天考过软考中级信息系统监理师心得
·软考超级Fans-五次软考心路历程·计算机软件水平考试应避免的五大失误
·通过软件设计师考试 专业能力很重要·2007年软件测试工程师需求继续增大
·从人性格看哪些人不适合做软件测试·软考三考三捷 我是怎么备考和应考的
 
◇ 重点栏目导航
◇ 精英服务承诺
教育顾问:010-51660910
QQ交流:138660910
相关资料
·软件测试新手的修炼之路
·Smarty简体中文参考手册
·Struts中文手册
·Struts快速学习指南
·ultradev动态网页制作教程
·UML工具箱
·《设计模式》中文版
·学友Flash伴侣 1.11
·阿须图像水印(AssureMark)V2.0
·超级语霸
相关试题
·2007年全国CPA考试试卷及答案解析之《会
·2007年CPA试卷及答案解析之《财务成本管
·2008年注会考前模拟试题之《财务成本管理
·2007年全国CPA《税法》考试试卷及答案解
·2008年中级会计职称《经济法》试题及答案
·2008年注册会计师考前模拟试题参考答案之
·2008年注册会计师考前模拟试题之《会计》
·2008年注册会计师考前模拟试题之《税法》
·2008年高校招生全国统考理数试题(四川延
·2008年全国高考物理科试题参考答案(上海
相关热贴
·如何改QQ IP地址!
·恰当选择软件测试自动化方案
·ADO.NET学习总结
·.net操纵xml文件类(c#)
·Log4net教程
·VPN技术详解
·高手必读 网络端口安全防护技巧放送
·访问XP共享出现的问题解决办法
·Web2.0时代,RSS你会用了吗?(技术实现总
·.NET下正则表达式应用的四个示例