CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  VB >  基础类

有的媒体播放软件,如WINAMP,在他播放时,你双击MP3文件,他会播放你刚选的MP3,怎么用VB实现类似的效果,当我的程序已经启动了,双击我的程序关联的文档,我的程序会打开新的文档?

楼主ebombsuhocom(什么时代都有BUG)2002-01-09 10:38:09 在 VB / 基础类 提问

问题点数:50、回复次数:3Top

1 楼thinkeasy(Nothing)回复于 2002-01-09 10:42:07 得分 0

您程序启动时加一个判断,看是不是有程序在运行,如果的,就发送消息给那个程序,并关闭这个程序Top

2 楼ebombsuhocom(什么时代都有BUG)回复于 2002-01-09 10:48:05 得分 0

怎么发呢?  
  怎么知道上一个例程呢?Top

3 楼uguess(天地间,有我在行走!)回复于 2002-01-09 10:48:21 得分 50

: thinkeasy(Nothing) 你尽胡说!  
   
        给个文章你们看看吧!用DDE实现窗体防止运行多个实例并传递命令              
  关键字:  
  VB,DDE,实例,命令     贴文时间  
   
                                                使用DDE技术,为您的应用程序增辉  
   
          上网的朋友一定都用过网络蚂蚁(Net   Ants)的吧?不知你在使用过程中有没有注意过,  
  那就是如果你想调动两个“蚂蚁”为您效力是不可能的--它总会把新运行的关闭。这点在VB  
  中很容易实现:  
          Private   Sub   Form_Load()  
                If   App.PrevInstance   Then  
                      MsgBox   "你已经运行这个应用程序了"  
                      End             '   退出新运行的程序  
                End   If  
          End   Sub  
          这样如果你运行这个程序后在运行它,它会弹出一个消息框并拒绝再次运行。这非常容易。  
          而“蚂蚁”程序的妙处就在于:在重复运行“蚂蚁”时它不仅拒绝运行,而且能把已经运  
  行的“蚂蚁”激活,这样用上面的程序就无能为力了。但事实上实现拒绝运行并激活已运行的  
  程序有多种方法:  
   
          1、用FindWindow函数得到已经运行窗体的句柄(HWND),然后用SetActiveWindow等API函  
                数将其激活。其缺点也很明显,那就是没法传递参数。  
   
          2、用FindWindow函数得到已运行窗体的句柄后用SendMessage的方法给窗体传送一个自定义  
                消息(附带参数),然后在窗体中拦截并进行处理,但这样做要修改窗体的标准消息处理  
                程序,用在VC,BC或DELPHI编写的程序中还行,但在VB中工作量太大,并且容易发生“一  
                般保护行错误”使VB崩溃,不太可取(当然,如果你有足够的信心和不怕崩溃的精神,也  
                可以试一下   ^_^   )。  
   
          3、使用DDE技术。  
   
          所谓DDE技术,就是动态数据交换技术。也许你很奇怪,这与本文所讨论的内容有什么相干的?  
  且听我慢慢讲来。  
          为了实现拒绝运行并把已经运行的程序激活并实现各种功能,我们可以先用本文开头提到的方  
  法,检测一下程序有没有被运行过,如果没有,就正常运行,如果已经被运行过,就打通与它的  
  DDE通道,传给它一个(或一些)数据,然后由已经运行的程序对数据进行处理,再去实现各种  
  “意想不到”的功能,这时也许就有人对这你的程序喊:“酷、酷……”     ^_^  
          好了,耳听为虚,眼见为实,下面让我们动点真格的。  
   
          打开VB,新建一个工程,选择菜单中的“工程->工程1   属性”,把工程名称改为“P1”(我爱  
  偷懒,能短则短   ^_^   ),把已有的一个窗体的“LinkTopic”属性改为“FormDDE”,把“LinkMode”  
  属性改为“1   -   Source”,添加一个PictureBox控件作为DDE执行控件,命名为picDDE。然后添加一个  
  TextBox控件,命名为“txtInfo”,并把“MultiLine”属性设置为“True”,以便显示多行文本,作为  
  消息显示控件。  
   
  最后在窗体代码区输入以下代码:  
   
   
  Const   COMMANDLINE   =   "CommandLine="               '     还是为了省事,定义一个常量  
   
  Private   Sub   Form_LinkExecute(CmdStr   As   String,   Cancel   As   Integer)  
  Static   lngCount   As   Long  
  Dim   Info   As   String  
   
  Info   =   txtInfo.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  
   
  txtInfo.Text   =   Info           '         把信息显示出来  
   
  Cancel   =   False            
  End   Sub  
   
   
  Private   Sub   LinkAndSendMessage(ByVal   Msg   As   String)  
  Dim   t   As   Long  
  picDDE.LinkMode   =   0                               '--  
  picDDE.LinkTopic   =   "P1|FormDDE"       '     |______连接DDE程序并发送数据/参数  
  picDDE.LinkMode   =   2                               '     |             “|”为管道符,是“退格键”旁边的竖线,  
  picDDE.LinkExecute   Msg                         '--                 不是字母或数字!  
   
  t   =   picDDE.LinkTimeout           '--  
  picDDE.LinkTimeout   =   1           '     |______终止DDE通道。当然,也可以用别的方法  
  picDDE.LinkMode   =   0                 '     |             这里用的是超时强制终止的方法  
  picDDE.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  
   
  测试一下:  
          把工程“P1”编译成EXE文件(设名称为   P1.EXE   )  
          1、打开“我的电脑”,找到   P1.EXE   并执行。可以看到程序正常运行了。  
          2、再运行一次,这次新程序没有运行成功,而原来运行的程序却被最大化了,而且文本框中有以下  
                字符:  
   
    窗体已被最大化  
    你已经第   1次重复调用这个程序。  
    但怕您不多给工资,所以只运行了一个   ^_^  
    最后一次运行这个程序的时间是:00-2-6   7:11:01  
   
          3、打开   MS-DOS方式   ,用命令行方式再次运行程序,如   “P1   How   Are   You?”  
                这时原来运行的程序文本框中又多了几行字:  
   
    窗体已被最大化  
    你已经第   2次重复调用这个程序。  
    但怕您不多给工资,所以只运行了一个   ^_^  
    最后一次运行这个程序的时间是:00-2-6   7:14:32  
    新程序曾以命令行形式运行  
    命令行为:  
    How   Are   You?  
   
  OK,运行完全正确,然后你就可以把它应用的你的程序中了。  
   
  当然,这只是一些个人心得,如有疏漏之出,还请各位大虾指正。    
   
  Top

相关问题

  • 用vb编写flash的播放软件,有什么办法能够取得所播放的flash文件中的某一个变量的值?????
  • 关于LED播放软件的问题
  • 用DIRECTX 如何编制DVD播放软件!
  • 有用JAVA编写一个播放软件的吗?急用!
  • 100分求CD播放软件的源码
  • 介绍一款保护硬盘的MP3播放软件?
  • 请教视频的播放软件编写。
  • 推荐一个""""有特色""""的MP3播放软件.英文版.(可换Skin)
  • 拦截vb窗体controlbox的双击消息!
  • 请问我从FM365.COM下载的*.ram文件要用什么播放软件才能播放?

关键词

  • mp3
  • 命令行
  • 属性
  • 控件
  • 运行
  • 程序
  • 窗体
  • dde
  • vbnewline
  • linkandsendmessage

得分解答快速导航

  • 帖主:ebombsuhocom
  • uguess

相关链接

  • Visual Basic类图书
  • Visual Basic类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo