zoukankan      html  css  js  c++  java
  • VC++ 文件拖拽功能实现

    使用过QQ的人都知道,只要把文件拖拽到消息框中就可以传送文件了。那么这种功能是如何实现的呢?其实很简单,只需要响应一个WM_DROPFILES消息就可以了。

      在基于对话框的程序中,默认是没有这个消息的,按下Ctrl+W,弹出类向导对话框,选择Class Info标签,在Message fileter下拉列表中选择Window,然后再点击Message Maps标签,就出现WM_DROPFILES消息了,添加该消息的响应函数:

      void CTestDlg::OnDropFiles(HDROP hDropInfo)

      {

      // TODO: Add your message handler code here and/or call default

      //.........................

       CDialog::OnDropFiles(hDropInfo);

      }

      另外,要让对话框能够接受文件拖拽,还需要设置对话框属性。在对话框上点击右键,选择Properties->Extended Styles,点选Accept files选项即可。

      要获得当前拖拽的文件的完整文件名(含路径),只需要一个函数:

      UINT DragQueryFile(

      HDROP hDrop,

      UINT iFile,

      LPTSTR lpszFile,

      UINT cch

      );

      参数解释:

      hDrop: HDROP标识符,即响应函数中的hDropInfo参数

      iFile: 待查询的文件索引号,从0开始。可以同时拖拽多个文件,因此就需要一个索引号来进行区分。如果该参数为0xFFFFFFFF,则该函数返回拖拽的文件的个数

      lpszFile: 用于存放文件名的缓冲区首地址

      cch: 缓冲区长度

      返回值:文件名长度

      另外,查询完成后需要释放系统分配内存,使用下面这个函数:

      VOID DragFinish(

      HDROP hDrop

      );

      下面是一个完整的代码示例,将文件拖拽到对话框上后会弹出消息框显示完整文件名:

      

    void CTestDlg::OnDropFiles(HDROP hDropInfo)
    
      {
    
        // TODO: Add your message handler code here and/or call default
    
        UINT count = 0;
    
        char filePath[MAX_PATH] = {0};
    
        count = DragQueryFile(hDropInfo, 0xFFFFFFFF, NULL, 0);
    
        if(count)
    
        {
    
          for(UINT i=0; i<count; i++)
    
          {
    
            int pathLen = DragQueryFile(hDropInfo, i, filePath, sizeof(filePath));
    
            AfxMessageBox(filePath);
    
          }
    
       }
    
      DragFinish(hDropInfo);
    
      CDialog::OnDropFiles(hDropInfo);
    
      }
    

      同理,如果只有把文件拖拽到特定的控件中时才有响应,只需要把该控件的Accept files样式勾选上即可。

  • 相关阅读:
    使用Boost::ptime构建高精度计时器
    static和extern
    通用js地址选择器
    js模拟抛出球运动
    前端用Webpact打包React后端Node+Express实现简单留言版
    webpack 打包一个简单react组件
    img及父元素(容器)实现类似css3中的background-size:contain / background-size:cover
    通用js函数集锦<来源于网络> 【二】
    通用js函数集锦<来源于网络/自己> 【一】
    向上滚动或者向下滚动分页异步加载数据(Ajax + lazyload)[上拉加载组件]
  • 原文地址:https://www.cnblogs.com/nsxz85/p/4821054.html
Copyright © 2011-2022 走看看