• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

自己动手做个MSN信息群发软件

发布: 2007-7-01 21:48 | 作者: admin | 来源: | 查看: 36次 | 进入软件测试论坛讨论

领测软件测试网

MSN是目前网络上广泛使用的一个即时信息交流工具(IM),笔者就常用它与同事或朋友联系,但是在使用过程中发现缺乏一个群发信息的功能,于是笔者寻思着自己编写一个MSN信息群发的软件,在查阅了一番资料之后,终于写出来了。下面大家和我一起动手来自己做一个MSN的信息群发工具。

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

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

图1

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

名称

类型

Caption属性的值

Label1

Label

群发对象:

Combo1

ComboBox

 

Check1

CheckBox

只发送在线的

Label2

Label

消息内容:

Text1

TextBox

 

Command1

CommandButton

发送[&O]

Command2

CommandButton

退出[&X]

       添加完控件后调整其位置,最后形成图2的效果:

第四步:编写代码。

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

       第五步:编译运行。选择“文件”菜单的生成“工程1.exe”菜单项,一个属于你的MSN信息群发软件就完成了。运行这个exe界面如下:

本例的源程序大家可以到如下地址下载:
欢迎大家和我一起来讨论,我的电子邮件:


延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网