• 【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。不知道这样理解有没有错^_^。

  • 相关阅读:
    从语料中找出低频词-去除无用信息
    pytorch seq2seq模型示例
    An Open-Source Package for Knowledge Embedding- 知识嵌入为人机交互做支撑
    jiagu-工具使用
    多线程操作数据
    pycharm安装pytorch失败的问题
    模型区分度衡量指标-KS值
    jstree: 获得根节点,checkbox事件处理
    jquery:删除第一个子元素
    js:如何在iframe重载前执行特定动作
  • 原文地址:https://www.cnblogs.com/mqxs/p/7534730.html
Copyright © 2020-2023  润新知