VBA 列表框拖放

标签 vba excel listbox excel-2010

我正在尝试在 VBA 中生成拖放功能,以允许用户在用户窗体上的列表框之间移动项目。

enter image description here

我遇到的问题是,当您向下单击鼠标按钮并移动鼠标时,列表框选择会在列表中上下移动。我已经设法编写了一些行,当您按下鼠标按钮时捕获选择,因此当您将其拖动到另一个列表框时,正确的项目会被删除,但是我觉得第一个列表框的移动突出显示的选择可能会关闭为最终用户放置。

每次在 MouseMove 事件上移动鼠标时,我都尝试将选择设置为原始项目,但是当光标与列表上的项目对齐时它根本不起作用,但当您移动时它会反弹光标位于列表下方。

Here's a copy of the macro workbook (Excel 2010)

有人可以阐明如何改进这一点吗?

编辑说明:此示例只会将左侧框中的项目添加到右侧,我计划复制在具有多个列表框的用户窗体上找到的任何解决方案,所以我希望有人知道一个好的机制来实现这一点。

最佳答案

根据 Manish 的评论,this link详细介绍了一个优雅的解决方案,请参阅后面的文章以获取更好的解决方案,该解决方案对用户窗体上的任意数量的列表框都有效。不过,我确实做了一些调整,以使其在我的情况下工作得更好。

用户窗体上除列表框之外的其他控件会引发错误,为了更正此问题,我将 UserForm_Initialize() 更改为:

Private Sub UserForm_Initialize()
    Dim Ctrl As MSForms.Control
    Dim LMB As ListBoxDragAndDropManager
    Dim x As Integer

    Set LBs = New Collection
    For Each Ctrl In Me.Controls
        If TypeName(Ctrl) = "ListBox" Then
            Set LMB = New ListBoxDragAndDropManager
            Set LMB.ThisListBox = Ctrl
            LBs.Add LMB
        End If
    Next
End Sub

ListBoxDragAndDropManager类中,我添加了以下子项,以便一次只能选择一个ListBox,它使UserForm在使用中看起来和感觉更好,但在功能上没有任何区别:

Private Sub pThisListBox_Click()
    Dim Ctrl As MSForms.Control
    Dim i As Integer

    For Each Ctrl In ThisListBox.Parent.Controls
        If Ctrl.Name <> ThisListBox.Name And TypeName(Ctrl) = "ListBox" Then
            For i = 0 To Ctrl.ListCount - 1
                Ctrl.Selected(i) = False
            Next i
        End If
    Next Ctrl
End Sub

关于VBA 列表框拖放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38145421/

相关文章:

vba - 在 Visual Basic (VBA) 中传递对象引用

vba - 显示包含两个给定值之间的值的行

excel - SharePoint 2010 : Link to open Excel file in edit-mode mode

asp.net-mvc - formcollection 只保存选定的 html.listbox 项目值? MVC

excel - VBA VLookup 按列名称

vba - "Sub or Function not defined"尝试在 Outlook 中运行 VBA 脚本时

Excel:如何将单元格值用作其他单元格地址的一部分

c# - 列表框选定项绑定(bind)从源更新

c++ - 从未调用过 Win32 ListBox WNDPROC

regex - VBA 宏运行时错误