Use a ListBox as a poor man’s grid

You can easily create columns of data in a ListBox control by setting its tab stop at appropriate positions. This way, you can use a ListBox control as a sort of grid control with (very) limited functionality, but without using third-party controls.

You can set ListBox’s tab stop by sending the control a LB_SETTABSTOPS message, where wParam contains the number of desired tab stops, and lParam points to the first element of an array of Long values that contains the new tab stop positions. The following reusable routine does the trick

Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal _    hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, _    lParam As Any) As LongConst LB_SETTABSTOPS = &H192' Set tab stops positions for a ListBox control ' Each element of the array is expressed in dialog units,' where each dialog unit is 1/4 of the average character width.Sub ListBoxSetTabStops(lb As ListBox, tabStops() As Long)    Dim numEls As Long    numEls = UBound(tabStops) - LBound(tabStops) + 1    SendMessage lb.hwnd, LB_SETTABSTOPS, numEls, tabStops(LBound(tabStops))End Sub

Note that the values in the array are expressed in dialog units, where the average character’s width corresponds to 4 dialog units. The following code example set the tab stop position at (approximately) the 10th, 18th and 25th character:

Dim tabs(2) As Longtabs(0) = 40   ' 10*4tabs(1) = 72   ' 18*4tabs(2) = 100  ' 25*4ListBoxSetTabStops List1, tabs()

Once you have set the tab stops appropriately, you just add new items to the ListBox, where the values in each column should be separated by vbTab characters:

List1.AddItem "col 1" & vbTab & "col 2" & vbTab & "col 3" & vbTab & "col 4"

Share the Post:
Share on facebook
Share on twitter
Share on linkedin


The Latest

your company's audio

4 Areas of Your Company Where Your Audio Really Matters

Your company probably relies on audio more than you realize. Whether you’re creating a spoken text message to a colleague or giving a speech, you want your audio to shine. Otherwise, you could cause avoidable friction points and potentially hurt your brand reputation. For example, let’s say you create a

chrome os developer mode

How to Turn on Chrome OS Developer Mode

Google’s Chrome OS is a popular operating system that is widely used on Chromebooks and other devices. While it is designed to be simple and user-friendly, there are times when users may want to access additional features and functionality. One way to do this is by turning on Chrome OS

homes in the real estate industry

Exploring the Latest Tech Trends Impacting the Real Estate Industry

The real estate industry is changing thanks to the newest technological advancements. These new developments — from blockchain and AI to virtual reality and 3D printing — are poised to change how we buy and sell homes. Real estate brokers, buyers, sellers, wholesale real estate professionals, fix and flippers, and beyond may