What is a ControlList?

The ControlList component was introduced to the VCL a few years back to allow managing extremely large lists in a totally virtual way. A control list, in fact, has a panel with a structure that is created in a single instance in memory, but is painted for each of the list items, so that is looks like you have thousands, or even millions of such elements.

This is done by asking the program to update the controls of this panel each time of the items needs to be painted. Given that the paint requests are received only for the (few) visible items, the list does only the minimum processing required to give the perception of having a large amount of elements a user can scroll and navigate.

In practical terms, in a very minimal scenario (a list only one label) the component at design time will look like this:

The code responsible to making each item unique and distinct can be like the following:
[crayon-6742b47ad3534572929375/]
Notice that the control list items don’t exist and don’t have the concept of status. Accessing the Label1 Caption, outside of the specific ControlList event handlers use to process an element, makes no sense. After setting the list ItemCount property to 100 items, this results will be the following UI:

Now you can check the selected item by using:
[crayon-6742b47ad353d351019153/]

The ControlList Multiple Selection

What is new in Delphi 11.3 is the ability to enable multiple selection. This is done with the new MultiSelect property.

With this configuration, the user of your application can click the mouse button along with the Ctrl and Shift keys to select multiple individual items (Ctrl) or all the items from the last click position (Shift), on the line of the classic behavior of a Windows ListBox with multiple selection. The same combinations can be use to unselect items, so that the Ctrl+click oepration is actually a “toggle selection” operations. Here is an example of this bare bone UI:

To check programmatically which items are selected, you can iterate over the Selected array property, with code similar to:
[crayon-6742b47ad353f236857496/]
That’s all you need to do to use this new feature of the powerful ControlList VCL component.