分享
 
 
 

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

王朝vb·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

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界面如下:

本例的源程序大家可以到如下地址下载:http://www.ly800.com/soft/MsnGS.rar

欢迎大家和我一起来讨论,我的电子邮件:root@ly800.com

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有