zoukankan      html  css  js  c++  java
  • 【WPF】鼠标拖拽功能DragOver和Drop

    在Winform里面实现拖入功能只要设置控件AllowDrop=true;

    然后实现方法

    //拖入
    private void txtInputPath_DragOver(object sender, DragEventArgs e)
            {
                e.Effects = DragDropEffects.Link;
            }
    //拖放结束
    private void txtInputPath_Drop(object sender, DragEventArgs e)
            {
                string[] data = (string[])e.Data.GetData(DataFormats.FileDrop);
                if (data == null || data.Length < 1 || !data[0].ToLower().EndsWith(".txt"))
                    return;
                txtInputPath.Text = data[0];
            }

    但是,再WPF里面用同样的方法就是不行,实现不了。经过百度后发现,不能使用DrapOver,改为PreviewDragOver就可以了。所以代码修改为:

     /// <summary>
            /// 拖入
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void txtInputPath_PreviewDragOver(object sender, DragEventArgs e)
            {
                e.Effects = DragDropEffects.Link;
                e.Handled = true;//必须加
            }
            /// <summary>
            /// 拖放结束
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void txtInputPath_PreviewDrop(object sender, DragEventArgs e)
            {
                 string[] data = (string[])e.Data.GetData(DataFormats.FileDrop);
                if (data == null || data.Length < 1 || !data[0].ToLower().EndsWith(".txt"))
                    return;
                txtInputPath.Text = data[0];
            }    

    经过测试,确实就可以了。那么问题来了,为什么Winform里面可以,WPF里面不可以呢。查了下,可能是事件的机制及触发时间不一样吧。

    以下是找到的一段翻译是这么说的:

    Drag-and-drop操作过程中,会由一系列事件,DragSource包含的Event包括,GiveFeedback、QueryContinueDrag、PreviewGiveFeedback 和 PreviewQueryContinueDrag;DragTarget包含的Event包括:DragEnter[dragged object 进入这个target的边界时],DragLeave[dragged object 离开garget的边界之外],DragOver[dragged object 在target范围内移动],Drop[dragged object 被放置到target内],PreviewDragEnter,PreviewDragLeave,PreviewDragOver,PreviewDrop。

    这些Event有两种模型,一个是Bubbling,一个是Tunnelling(带Preview前缀的)。

    Bubbling的event是动作发生后触发;Tunnelling的event是动作发生前触发。

    那么是不是可以这么理解DragOver里面代码是设置链接方式,但是触发时间点是发生后才触发这个事件,那么这个时候修改e.Effects = DragDropEffects.Link;可能为时已晚,所以要使用PreviewDragOver。不知道这样理解有没有错^_^。

  • 相关阅读:
    android listview 添加数据
    Android 打开其他程序
    Android 自定义ListView Item侧滑删除
    Intent 传递对象
    openfire Android学习(六)----总结
    openfire Android学习(五)------连接断开重连
    openfire Android 学习(四)----单人聊天和多人聊天(发送消息、接收消息)
    openfire Android学习(三)----会议室创建、加入以及查询会议室中所有成员等
    openfire Android学习(二)----对分组、好友和头像等一些操作
    openfire Android学习(一)----实现用户注册、登录、修改密码和注销等
  • 原文地址:https://www.cnblogs.com/mqxs/p/7534730.html
Copyright © 2011-2022 走看看