在VB.NET中实现文件的拖放

 我来答
大沈他次苹0B
2022-11-10 · TA获得超过7323个赞
知道大有可为答主
回答量:3059
采纳率:100%
帮助的人:177万
展开全部

  本文介绍了在VB NET中如何实现接受拖放的文件 即从资源管理器中拖放到应用程序中的时候 自动获取拖放的文件 文中的例子是一个接受拖放文件显示文件内容的VB NET实例程序 引言

  对于文本格式的文件 我们可以直接拖到记事本中就可以看到内容 各种类型的图片 拖到Photoshop中 就可以直接对其编辑 我们如何在VB NET开发的程序也实现上述效果呢?

  思路

  我们知道 每一个Windows的应用程序都有一个消息队列 程序的主体接受系统的消息 然后分发出去(给一个form 或者一个控件) 接受者有相应的程序来处理消息 在 NET的Form中 默认情况下程序是不翻译这些消息的 也就是说默认我们的Class是不加入应用程序的消息泵 能不能把我们的Form Class加入应用程序的消息泵呢?可以!

  在 NET中 任何一个实现IMessageFilter 接口的类 可以添加到应用程序的消息泵中 以在消息被调度到控件或窗体之前将它筛选出来或执行其他操作 使用 Application 类中的 AddMessageFilter 方法 可以将消息筛选器添加到应用程序的消息泵中

  于是我们在程序加载的时候 调用Application AddMessageFilter(Me) 然而 默认情况下一个Form或者控件是不能接受拖放的文件的 我们调用一个WIN API DragAcceptFiles源码天空 这个API可以设置对应的控件是否能接受拖放的文件 然后可以用DragQueryFile查询拖放到的文件列表 也就是拖放文件地具体路径和文件名

  代码

  Imports System Runtime InteropServices

  Public Class Form

  Inherits System Windows Forms Form

  Implements IMessageFilter

   API申明

  Const WM_DROPFILES = &H   拖放文件消息

  <DllImport( shell dll )> Public Shared Sub DragFinish(ByVal hDrop As Integer)

  End Sub

  <DllImport( shell dll )> Public Shared Sub DragAcceptFiles(ByVal hwnd As Integer ByVal fAccept As Boolean)

  End Sub

  <DllImport( shell dll )> Public Shared Function DragQueryFile(ByVal HDROP As Integer ByVal UINT As Integer ByVal lpStr As System Text StringBuilder ByVal ch As Integer) As Integer

  End Function

  Private Sub Form _Load(ByVal sender As System Object ByVal e As System EventArgs) Handles MyBase Load

  Application AddMessageFilter(Me)

  DragAcceptFiles(TextBox Handle ToInt True)

  End Sub

  Function PreFilterMessage(ByRef m As Message) As Boolean Implements IMessageFilter PreFilterMessage

  If m Msg = WM_DROPFILES Then

   设置拖放的动作

  Dim nfiles As Int

  nfiles = DragQueryFile(m WParam ToInt Nothing )

  Dim i As Int

  Dim *** As New System Text StringBuilder( )

  Dim sFirstFileName As String 记录第一个文件名

  TextBox Clear()

  For i = To nfiles

  DragQueryFile(m WParam ToInt i *** )

  If i = Then sFirstFileName = *** ToString

  TextBox AppendText(ControlChars CrLf & *** ToString)

  Next

  DragFinish(m WParam ToInt ) 拖放完成

   显示文件内容

  Dim fs As New System IO FileStream(sFirstFileName IO FileMode Open)

  Dim sr As New System IO StreamReader(fs System Text Encoding GetEncoding( gb ))

  TextBox AppendText(ControlChars CrLf & sr ReadToEnd() ToString)

  fs Close()

  sr Close()

  End If

  Return False

  End Function

  Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)

  If disposing Then

  If Not (ponents Is Nothing) Then

  ponents Dispose()

  End If

  End If

  Application RemoveMessageFilter(Me)

  DragAcceptFiles(TextBox Handle ToInt False)

  MyBase Dispose(disposing)

  End Sub

lishixinzhi/Article/program/net/201311/13043

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式