Tip 74: Scrolling Through Two List Box Controls Simultaneously

* VB-CODE (4)

Abstract
You can add code to your Visual Basic® application to allow a user to
scroll through the contents of two separate List Box controls at the
same time. This article explains how you can add this functionality to
your program.

The TopIndex Property of List Box Controls
When using a List Box control, the user can click the mouse on the
scroll bar to move up or down the list of items. If the user clicks
the mouse on an individual item, that item is said to be selected. The
ListIndex property is a unique value that represents the selected
item's position within the List Box.

You can also scroll through a List Box control by using the TopIndex
property. This property, however, can only be changed at run time, not
during design time. The TopIndex property moves you through the items
in the List Box control. In other words, it works just as if the user
had used the scroll bar.
Let's assume that you have two List Box controls on a form in your
Visual Basic® application. As you scroll through the items in the
first List Box control, you want to also scroll through the same items
in the second List Box control.

In an application, you can use the TopIndex property to move a
specific item in the List Box control so that that item appears at
the top of the List Box. The following statement, for example, moves
the third item in the List Box to the top of the control:

List1.TopIndex = (2)

In the example program below, we want to scroll through both List Box
controls at the same time. To do this, we use a Timer control so that
the second List Box control is updated as soon as the item is selected
in the first List Box control.

We first use a static variablethat is, a variable whose contents do
not change when we exit a procedureto keep track of the currently
selected item in the first List Box. Each time a new item is selected
in the List Box, this variable is set to that item's TopIndex value.
Next, we set the ListIndex property of the second List Box control
equal to that of the first List Box control. This highlights the two
items in each List Box that have the same ListIndex value. It doesn't
matter what the actual item is the items are both selected based on
their position within the controls.

Each time you select an item in the first List Box, that same item is
also selected in the second List Box.

Example Program
This example program shows how to scroll through the contents of two
List Box controls simultaneously.

1. Create a new project in Visual Basic. Form1 is created by default.
2. Add the following code to the General Declarations section of
Form1:

Option Explicit
DefInt A-Z

3. Add the following code to the Form_Load event for Form1:

Private Sub Form_Load()
Dim X As Integer
'Initialize two list boxes with alphabet
For X = 1 To 26
List1.AddItem Chr$(X + 64)
Next X
For X = 1 To 26
List2.AddItem Chr$(X + 64)
Next X
timer1.Interval = 1
timer1.Enabled = True
End Sub

4. Add a List Box control to Form1. List1 is created by default.
5. Add a second List Box control to Form1. List2 is created by
default.
6. Add a Command Button control to Form1. Command1 is created by
default.
7. Add the following code to the Click event for Command1:

Private Sub Command1_Click()
End
End Sub

8. Add a Timer control to Form1. Timer1 is created by default.
9. Add the following code to the Timer1 event for Timer1:

Private Sub timer1_Timer()
Static PrevList1
Dim TopIndex_List1 As Integer

'Get the index for the first item in the visible list.
TopIndex_List1 = List1.TopIndex

'See if top index has changed.
If TopIndex_List1 <> PrevList1 Then
'Set the top index of List2 equal to List1,
'so that the list boxes scroll together.
List2.TopIndex = TopIndex_List1
PrevList1 = TopIndex_List1
End If
'Select the item in the same position in both list boxes.
If List1.ListIndex <> List2.ListIndex Then
List2.ListIndex = List1.ListIndex
End If

End Sub

Additional Information
This article expands upon and is intended to replace Knowledge Base
article Q103809.
"List Box Control." (Product Documentation, Office Developer's
Kit 1.0, Visual Basic 3.0 Professional Edition, Language Reference)
"TopIndex Property." (Product Documentation, Office Developer's
Kit 1.0, Visual Basic 3.0 Professional Edition, Language Reference)

No comments: