A2 Из вопроса не ясно, использует ли автор стили WS_HSCROLL и WS_VSCROLL или элемент управления scroll bar. Однако и в том, и в другом случае можно использовать одни и те же функции (SetScrollInfo/GetScrollInfo), чтобы управлять полосой прокрутки. Сначала (с помощью SetScrollInfo) для неё задаются 32-разрядные значения основных параметров (положения ползунка, диапазона изменения его положения и размера страницы). Затем в обработчике сообщений WS_HSCROLL и WS_VSCROLL можно использовать GetScrollInfo, чтобы получить значения всех этих параметров (опять же 32-разрядные!).
Допустим, окно имеет стиль WS_VSCROLL. Тогда в указанные функции нужно передавать HWND этого окна и константу SB_VERT (в случае с горизонтальной полосой прокрутки используется SB_HORZ). Например:
// Создаём окно и инициализируем scroll bar.
HWND hWnd = CreateWindow(…);
SCROLLINFO si;
si.cbSize = sizeof(si);
si.fMask = SIF_POS | SIF_RANGE | SIF_PAGE;
si.nMin = 0;
si.nMax = 100000; // больше, чем вмещает short!
si.nPos = 0;
si.nPage = 100;
SetScrollInfo(hWnd, SB_VERT, &si, TRUE);
…
LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam) {
switch (message) { // Обрабатываем сообщение WM_VSCROLL.
case WM_VSCROLL:
{
SCROLLINFO si;
si.cbSize = sizeof(si);
si.fMask = SIF_PAGE | SIF_POS | SIF_RANGE | SIF_TRACKPOS;
GetScrollInfo(hWnd, SB_VERT, &si);
int pos = si.nPos;
switch(LOWORD(wParam)) {
case SB_LINEUP:
pos--;
break;
case SB_LINEDOWN:
pos++;
break;
case SB_PAGEUP:
pos -= si.nPage;
break;
case SB_PAGEDOWN:
pos += si.nPage;
break;
case SB_TOP:
pos = si.nMin;
break;
case SB_BOTTOM:
pos = si.nMax;
break;
case SB_THUMBPOSITION:
pos = si.nTrackPos;
break;
}
// Устанавливаем новое положение ползунка.
SetScrollPos(hWnd, SB_VERT, pos, TRUE);
break;
}
…
}
return DefWindowProc(hWnd, message, wParam, lParam);
}
В том случае, когда вместо стилей WS_xSCROLL используется элемент управления scroll bar, код выглядит совершенно аналогично, но функциям SetScrollInfo, GetScrollInfo и пр. передаётся HWND самой полосы прокрутки (а не владеющего ею окна), а в качестве второго параметра передаётся SB_CTL.
Q. Как сделать так, чтобы программа сама себя могла стереть, т.е. свой *.exe файл?
Это все на сегодня. Пока!
Программирование на Visual C++
Выпуск №32 от 11 февраля 2001 г.
Приветствую вас, уважаемые подписчики!
СТАТЬЯ
Автоматизация и моторизация приложения
Автор:
Редактор журнала СофтТерра
Софт Терра: Технологии Microsoft для разработчиков