版主给个实例吧!wx-flw@谢谢!新手在学习中!~~
看了个DDE的不怎么满意~~好像以后这个方法会不太方便
如下:
Const COMMANDLINE = "CommandLine="
'
还是为了省事,定义一个常量
Private Sub Form_LinkExecute(CmdStr As String, Cancel As Integer)
Static lngCount As Long
Dim Info As String
Info = Text1.Text
'
保留原有信息
Select Case CmdStr
'
CmdStr
是DDE程序传送过来的参数
Case "Max"
Me.WindowState = 2
Info = Info + vbNewLine + "窗体已被最大化 "
Case "ShowTime"
Info = Info + vbNewLine + "最后一次运行这个程序的时间是: " + Str(Now)
Case "Count"
lngCount = lngCount + 1
Info = Info + vbNewLine + "你已经第 " + Str(lngCount) + "次重复调用这个程序。 " _
+ vbNewLine + "但怕您不多给工资,所以只运行了一个
^_^ "
End Select
If Left(CmdStr, Len(COMMANDLINE)) = COMMANDLINE Then
Info = Info + vbNewLine + "新程序曾以命令行形式运行 " + vbNewLine + "命令行为: " _
+ vbNewLine + Right(CmdStr, Len(CmdStr) - Len(COMMANDLINE))
End If
Text1.Text = Info
'
把信息显示出来
Cancel = False
End Sub
Private Sub LinkAndSendMessage(ByVal Msg As String)
Dim t As Long
Picture1.LinkMode = 0
'--
Picture1.LinkTopic = "工程1|form1"
'
|______连接DDE程序并发送数据/参数
Picture1.LinkMode = 2
'
|
“|”为管道符,是“退格键”旁边的竖线,
Picture1.LinkExecute Msg
'--
不是字母或数字!
t = Picture1.LinkTimeout
'--
Picture1.LinkTimeout = 1
'
|______终止DDE通道。当然,也可以用别的方法
Picture1.LinkMode = 0
'
|
这里用的是超时强制终止的方法
Picture1.LinkTimeout = t
'--
End Sub
Private Sub Form_Load()
If App.PrevInstance Then
'
程序是否已经运行
Me.LinkTopic = ""
'
这两行用于清除新运行的程序的DDE服务器属性,
Me.LinkMode = 0
'
否则在连接DDE程序时会出乱子的
LinkAndSendMessage "Max"
'--
LinkAndSendMessage "Count"
'
|-----连接DDE接受程序并传送数据/参数
LinkAndSendMessage "ShowTime"
'--
If Command <> "" Then
'
如果有命令行参数,就传递过去
LinkAndSendMessage COMMANDLINE + Command
End If
End
'
结束新程序的运行
End If
End Sub
[
本帖最后由 wxflw 于 2012-4-18 20:50 编辑 ]