登录社区:用户名: 密码: 忘记密码 网页功能:加入收藏 设为首页 网站搜索  

文档

下载

图书

论坛

安全

源码

硬件

游戏
首页 | 信息 | 空间 | VB | VC | Delphi | Java | Flash | 补丁 | 控件 | 安全 | 黑客 | 电子书 | 笔记本 | 手机 | MP3 | 杀毒 | QQ群 | 产品库 | 分类信息 | 编程网站
  立华软件园 - Visual Basic 专区 - 技术文档 - 系统控制 技术文章 | VB源代码 | 电子图书 | VB网站 | 相关下载 | 在线论坛 | QQ群组 | 搜索   
 VB技术文档
  · 窗体界面
  · 系统控制
  · VB.Net
  · 多媒体
  · 网络编程
  · API函数
  · 游戏编程
  · 数据报表
  · 其他文档
 VB源代码
  · 窗体界面
  · 文件目录
  · 多媒体
  · 网络编程
  · 系统API
  · 数据报表
  · 游戏编程
  · VBA办公
  · 其他代码
 VB论坛
  · Visual Basic 讨论区
  · VB.Net 讨论区
  · VB数据库开发讨论区
  · VB系统API讨论区
 其他VB资源
  · VB下载资源
  · VB电子图书
  · VB QQ群组讨论区
  · VB 其他网站资源




在vb程序中如何获取剪贴板中所复制的文件的路径
发表日期:2003-12-09作者:[] 出处:  

1. 在Form1上放一个CommandButton和一个ListBox控件。

2. 在Form1中贴入以下代码。它会在ListBox中列出您在Windows Explorer中Copy的文件名。

Option Explicit

Private Const CF_HDROP = 15

Private Type POINT

  x As Long

  y As Long

End Type

Private Type DROPFILES

  pFiles As Long

  pt As POINT

  fNC As Long

  fWide As Long

End Type

Private Declare Function GlobalSize Lib "kernel32" _

  (ByVal hMem As Long) As Long

Private Declare Function GlobalLock Lib "kernel32" _

  (ByVal hMem As Long) As Long

Private Declare Function GlobalUnlock Lib "kernel32" _

  (ByVal hMem As Long) As Long

Private Declare Function OpenClipboard Lib "user32" _

  (ByVal hwnd As Long) As Long

Private Declare Function CloseClipboard Lib "user32" () As Long

Private Declare Function GetClipboardData Lib "user32" _

  (ByVal wFormat As Long) As Long

Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" _

  (Destination As Any, Source As Any, ByVal Length As Long)

Private Sub ShowFilesOnClipboard()

  Dim lHandle As Long

  Dim lpResults As Long

  Dim lRet As Long

  Dim df As DROPFILES

  Dim strDest As String

  Dim lBufferSize As Long

  Dim arBuffer() As Byte

  Dim vNames As Variant

  Dim i As Long

  If OpenClipboard(0) Then

   lHandle = GetClipboardData(CF_HDROP)

   ' If you don't find a CF_HDROP, you don't want to process anything

   If lHandle > 0 Then

     lpResults = GlobalLock(lHandle)

    

     lBufferSize = GlobalSize(lpResults)

     ReDim arBuffer(0 To lBufferSize)

    

     CopyMemory df, ByVal lpResults, Len(df)

     Call CopyMemory(arBuffer(0), ByVal lpResults + df.pFiles, _

             (lBufferSize - Len(df)))

     If df.fWide = 1 Then

      ' it is wide chars--unicode

      strDest = arBuffer

     Else

      strDest = StrConv(arBuffer, vbUnicode)

     End If

     GlobalUnlock lHandle

     vNames = Split(strDest, vbNullChar)

     i = 0

     While Len(vNames(i)) > 0

      List1.AddItem vNames(i)

      i = i + 1

     Wend

   End If

  End If

  CloseClipboard

End Sub

Private Sub Command1_Click()

  Call ShowFilesOnClipboard

End Sub

我来说两句】 【发送给朋友】 【加入收藏】 【返加顶部】 【打印本页】 【关闭窗口
中搜索 在vb程序中如何获取剪贴板中所复制的文件的路径

 ■ [欢迎对本文发表评论]
用  户:  匿名发出:
您要为您所发的言论的后果负责,故请各位遵纪守法并注意语言文明。

关于我们 / 合作推广 / 给我留言 / 版权举报 / 意见建议 / 广告投放 / 友情链接  
Copyright ©2001-2006 Lihuasoft.net webmaster(at)lihuasoft.net
网站编程QQ群   京ICP备05001064号 页面生成时间:0.0027