自己动手做个MSN信息群发软件(0分)

  • 主题发起人 主题发起人 seaga
  • 开始时间 开始时间
S

seaga

Unregistered / Unconfirmed
GUEST, unregistred user!
自己动手做个MSN信息群发软件

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 '打开要发送的好友窗体
do
Events
SendKeys Text1.Text '写入信息
do
Events
SendKeys "{enter}" '发送出信息
do
Events
SendKeys "%{F4}" '关闭好友窗口
End If
else

m_MSG.InstantMessage m_Contract
do
Events
SendKeys Text1.Text
do
Events
SendKeys "{enter}"
do
Events
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界面如下:

 
好久没看vb的代码了 嘿嘿 不错不错
 
楼上的,我好象见过你
 
msn6.1 没找到那个ocx
 
没有找到ocx是因为你的系统中没有安装MSN的缘故,这个实例运行时候请确保您的MSN是在线的
 
msn6.1 没找到那个ocx
 
你可以去微软的站点下载一个MSN6.1安装啊
 
拷下来,学习。[:D]
 
我把它改成dephi在发上来行不,seaga?
 
来自:kl78pgy, 时间:2004-2-13 23:50:16, ID:2452527
我把它改成dephi在发上来行不,seaga?
好的啊,欢迎啊,到时候给我一份啊 :)
 
不错的VB程序
 

Similar threads

D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
后退
顶部