+ Reply to Thread
Results 1 to 5 of 5

Fast way to clear Listbox selection

Hybrid View

Guest Fast way to clear Listbox... 08-26-2005, 02:05 PM
Guest Re: Fast way to clear Listbox... 08-26-2005, 03:05 PM
Guest Re: Fast way to clear Listbox... 08-26-2005, 03:05 PM
Guest Re: Fast way to clear Listbox... 08-26-2005, 04:05 PM
Guest Re: Fast way to clear Listbox... 08-26-2005, 06:05 PM
  1. #1
    sebastienm
    Guest

    Re: Fast way to clear Listbox selection

    Hi,
    When swithing from multiselect to singleselect, the listbox is rebuilt
    internaly, and the selection is cleared. I don't kow if it is faster with
    large list but it is easy and convenient:

    Private Sub CommandButton1_Click()
    With ListBox1
    .MultiSelect = fmMultiSelectSingle
    .MultiSelect = fmMultiSelectMulti 'switch back to multi
    End With
    End Sub

    I hope this helps
    --
    Regards,
    Sébastien
    <http://www.ondemandanalysis.com>


    "Doug Glancy" wrote:

    > Jim,
    >
    > I tried turning off multiselect, setting the selection to none (-1) and
    > tunring multiselect back on. It seems to do what you want:
    >
    > Private Sub btnClearAll_Click()
    > Me.ListBox1.MultiSelect = fmMultiSelectSingle
    > Me.ListBox1.ListIndex = -1
    > Me.ListBox1.MultiSelect = fmMultiSelectMulti
    > End Sub
    >
    > hth,
    >
    > Doug
    >
    > <jrushing@ea.com> wrote in message
    > news:1125079175.642474.63140@g44g2000cwa.googlegroups.com...
    > >I have a large Listbox in a Userform that has 5 columns and can have up
    > > to 1200 row entries. I have run into a curious behavior.
    > >
    > > I have buttons to Select all entries in the Listbox and to Clear all
    > > selections in the Listbox. My code is virtually idential to do the
    > > Select All and Clear All. Here's the curious part: when I have ~ 1000
    > > rows in the Listbox, it takes ~ 3 seconds to do a Clear All, but only ~
    > > 1 second to do the Select All. With a small number of rows, it
    > > impossible to see any difference, but with a large number of entries it
    > > takes noticeably longer to do the clear I have written the Clear All
    > > code as fast as I can think of (no calculations within the loop). I
    > > also tried turning off screen updating and calculations, but it doesn't
    > > seem to make any difference.
    > >
    > > Does anyone know of a faster way to do the clear? Here is my code.
    > >
    > > Private Sub btnClearAll_Click()
    > > Dim I As Integer
    > > Dim count As Integer
    > >
    > > With NameForm.ListBox1
    > > count = .ListCount - 1
    > > For I = 0 To count
    > > .Selected(I) = False
    > > Next I
    > > End With
    > > End Sub
    > >
    > > The only difference between the Clear All code and the Select All
    > > codeis False/True in line .Selected(I) = False.
    > > Any ideas? Why would be it faster to do the selection?
    > >
    > > Any info would be appreciated,
    > > Thanks,
    > > Jim
    > >

    >
    >
    >


  2. #2
    Doug Glancy
    Guest

    Re: Fast way to clear Listbox selection

    Sébastien,

    Interesting. I didn't think to try it like that.

    Doug

    "sebastienm" <sebastienm@discussions.microsoft.com> wrote in message
    news:66964C60-ED40-458B-8FD8-93A73DEA1953@microsoft.com...
    > Hi,
    > When swithing from multiselect to singleselect, the listbox is rebuilt
    > internaly, and the selection is cleared. I don't kow if it is faster with
    > large list but it is easy and convenient:
    >
    > Private Sub CommandButton1_Click()
    > With ListBox1
    > .MultiSelect = fmMultiSelectSingle
    > .MultiSelect = fmMultiSelectMulti 'switch back to multi
    > End With
    > End Sub
    >
    > I hope this helps
    > --
    > Regards,
    > Sébastien
    > <http://www.ondemandanalysis.com>
    >
    >
    > "Doug Glancy" wrote:
    >
    >> Jim,
    >>
    >> I tried turning off multiselect, setting the selection to none (-1) and
    >> tunring multiselect back on. It seems to do what you want:
    >>
    >> Private Sub btnClearAll_Click()
    >> Me.ListBox1.MultiSelect = fmMultiSelectSingle
    >> Me.ListBox1.ListIndex = -1
    >> Me.ListBox1.MultiSelect = fmMultiSelectMulti
    >> End Sub
    >>
    >> hth,
    >>
    >> Doug
    >>
    >> <jrushing@ea.com> wrote in message
    >> news:1125079175.642474.63140@g44g2000cwa.googlegroups.com...
    >> >I have a large Listbox in a Userform that has 5 columns and can have up
    >> > to 1200 row entries. I have run into a curious behavior.
    >> >
    >> > I have buttons to Select all entries in the Listbox and to Clear all
    >> > selections in the Listbox. My code is virtually idential to do the
    >> > Select All and Clear All. Here's the curious part: when I have ~ 1000
    >> > rows in the Listbox, it takes ~ 3 seconds to do a Clear All, but only ~
    >> > 1 second to do the Select All. With a small number of rows, it
    >> > impossible to see any difference, but with a large number of entries it
    >> > takes noticeably longer to do the clear I have written the Clear All
    >> > code as fast as I can think of (no calculations within the loop). I
    >> > also tried turning off screen updating and calculations, but it doesn't
    >> > seem to make any difference.
    >> >
    >> > Does anyone know of a faster way to do the clear? Here is my code.
    >> >
    >> > Private Sub btnClearAll_Click()
    >> > Dim I As Integer
    >> > Dim count As Integer
    >> >
    >> > With NameForm.ListBox1
    >> > count = .ListCount - 1
    >> > For I = 0 To count
    >> > .Selected(I) = False
    >> > Next I
    >> > End With
    >> > End Sub
    >> >
    >> > The only difference between the Clear All code and the Select All
    >> > codeis False/True in line .Selected(I) = False.
    >> > Any ideas? Why would be it faster to do the selection?
    >> >
    >> > Any info would be appreciated,
    >> > Thanks,
    >> > Jim
    >> >

    >>
    >>
    >>




  3. #3
    jrushing@ea.com
    Guest

    Re: Fast way to clear Listbox selection

    Thanks Doug and Sebastien,
    Now almost instantaneous even with large list.

    Much appreciated!

    Jim


+ Reply to Thread

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts

Search Engine Friendly URLs by vBSEO 3.6.0 RC 1