Использование функций перечисления WinAPI
Использование функций перечисления WinAPI
Использование функций перечисления WinAPI Для получения информации о множественных объектах windows (окнах, принтерах, шрифтах, настройках экрана и так далее - всего несколько десятков вариантов) используются функции, начинающиеся с enum. Эти функции работают по принципу, аналогичному итератору tcollection.firstthat, то есть они вызывают функцию, переданную им в качестве параметра для каждого перечисляемого объекта, передавая ей в параметрах данные объекта и, в последнем параметре, указатель на пользовательские данные, переданный функции enumxxx. Перечисление продолжается до тех пор, пока не будут перечислены все объекты. Немедленно прекратить перечисление можно, возвратив false. Ниже приведен пример заполнения списка listbox1 данными по всем окнам windows в виде "класс - заголовок" по нажатию кнопки button1. function addwininfo(winhandle: hwnd; list: tstringlist): boolean; stdcall; var wincaption,winclass: array[0..255] of char; begin result:=true; getclassname(winhandle,winclass,sizeof(winclass)); getwindowtext(winhandle,wincaption,sizeof(wincaption)); list.add(winclass+' - '+wincaption); end; procedure tfrmmain.button1click(sender: tobject); begin with listbox1,items do begin clear; enumwindows(@addwininfo,lparam(items)); end; end;