Это продолжение моего предыдущего вопроса.
Как обрабатывать удержание кнопки в WinAPI?
Мне удалось получить Кнопка для непрерывного обновления счетчика, пока кнопка нажата, на основе полученных мной комментариев, но теперь у меня возникла новая проблема.
Если я нажимаю кнопку, счетчик увеличивается и обновляется редактирование контроль. Если я отпущу кнопку, а затем сразу же снова нажму кнопку, она не увеличится и не обновится.
Похоже, что существует задержка, связанная с сообщением WM_LBUTTONDOWN, независимая от задержки, которую я принудительное выполнение при обработке WM_TIMER. Как решить эту проблему?
#include
HINSTANCE g_hInst;
HWND hEdit;
HWND hButton;
WNDPROC btnProc;
int counter = 0;
int t = 0;
static LRESULT CALLBACK StaticButtonProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam) {
switch (uMsg) {
case WM_LBUTTONDOWN:
// increment counter & update Edit Control
counter++;
wchar_t buf[40];
wsprintf(buf, L"%d", counter);
SetWindowText(hEdit, buf);
// start the timer
SetTimer(GetParent(hWnd), 1, 100, 0);
return btnProc(hWnd, uMsg, wParam, lParam);
case WM_LBUTTONUP:
// reset t
t = 0;
// stop the timer
KillTimer(GetParent(hWnd), 1);
return btnProc(hWnd, uMsg, wParam, lParam);
default:
return btnProc(hWnd, uMsg, wParam, lParam);
}
return 0;
}
LRESULT CALLBACK WindowProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam) {
switch (uMsg) {
case WM_CREATE:
hEdit = CreateWindow(L"EDIT", L"0", WS_CHILD | WS_VISIBLE | ES_CENTER | ES_READONLY, 100, 100, 100, 20, hWnd, (HMENU)1, g_hInst, NULL);
hButton = CreateWindow(L"BUTTON", L"▴", WS_CHILD | WS_VISIBLE | BS_LEFT, 200 + 4, 100, 20, 20, hWnd, (HMENU)2, g_hInst, NULL);
// subclass the button control
btnProc = (WNDPROC)SetWindowLongPtr(hButton, GWLP_WNDPROC, (LONG_PTR)StaticButtonProc);
break;
case WM_TIMER:
// 300ms delay
if (t < 300) {
t += 100;
}
else {
// increment counter & continuously update Edit Control while button is depressed
counter += 1;
wchar_t buf[32];
wsprintf(buf, L"%d", counter);
SetWindowText(hEdit, buf);
}
break;
case WM_DESTROY:
PostQuitMessage(EXIT_SUCCESS);
break;
default:
return DefWindowProc(hWnd, uMsg, wParam, lParam);
}
return 0;
}
int WINAPI WinMain(
HINSTANCE hInst,
HINSTANCE hPrevInst,
LPSTR lpCmdLine,
int iCmdShow)
{
g_hInst = hInst;
WNDCLASS wndClass = {
.style = CS_HREDRAW | CS_VREDRAW,
.lpfnWndProc = WindowProc,
.hInstance = hInst,
.hIcon = LoadIcon(NULL, IDI_APPLICATION),
.hCursor = LoadCursor(NULL, IDC_ARROW),
.hbrBackground = (HBRUSH)GetStockObject(LTGRAY_BRUSH),
.lpszMenuName = NULL,
.lpszClassName = L"app",
};
if (!RegisterClass(&wndClass)) {
OutputDebugString(L"Failed to register window class\n");
return EXIT_FAILURE;
}
if (!CreateWindow(
L"app",
L"Counter",
WS_OVERLAPPEDWINDOW | WS_VISIBLE,
0, 0,
1280, 720,
NULL, NULL,
hInst, NULL))
{
OutputDebugString(L"Failed to create window\n");
return EXIT_FAILURE;
}
MSG msg = {};
while (GetMessage(&msg, NULL, 0, 0)) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return (int)msg.wParam;
}
Подробнее здесь: https://stackoverflow.com/questions/787 ... -in-winapi
Проблема задержки WM_LBUTTONDOWN в WinAPI ⇐ C++
Программы на C++. Форум разработчиков
1720449642
Anonymous
Это продолжение моего предыдущего вопроса.
Как обрабатывать удержание кнопки в WinAPI?
Мне удалось получить Кнопка для непрерывного обновления счетчика, пока кнопка нажата, на основе полученных мной комментариев, но теперь у меня возникла новая проблема.
Если я нажимаю кнопку, счетчик увеличивается и обновляется редактирование контроль. Если я отпущу кнопку, а затем сразу же снова нажму кнопку, она не увеличится и не обновится.
Похоже, что существует задержка, связанная с сообщением WM_LBUTTONDOWN, независимая от задержки, которую я принудительное выполнение при обработке WM_TIMER. Как решить эту проблему?
#include
HINSTANCE g_hInst;
HWND hEdit;
HWND hButton;
WNDPROC btnProc;
int counter = 0;
int t = 0;
static LRESULT CALLBACK StaticButtonProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam) {
switch (uMsg) {
case WM_LBUTTONDOWN:
// increment counter & update Edit Control
counter++;
wchar_t buf[40];
wsprintf(buf, L"%d", counter);
SetWindowText(hEdit, buf);
// start the timer
SetTimer(GetParent(hWnd), 1, 100, 0);
return btnProc(hWnd, uMsg, wParam, lParam);
case WM_LBUTTONUP:
// reset t
t = 0;
// stop the timer
KillTimer(GetParent(hWnd), 1);
return btnProc(hWnd, uMsg, wParam, lParam);
default:
return btnProc(hWnd, uMsg, wParam, lParam);
}
return 0;
}
LRESULT CALLBACK WindowProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam) {
switch (uMsg) {
case WM_CREATE:
hEdit = CreateWindow(L"EDIT", L"0", WS_CHILD | WS_VISIBLE | ES_CENTER | ES_READONLY, 100, 100, 100, 20, hWnd, (HMENU)1, g_hInst, NULL);
hButton = CreateWindow(L"BUTTON", L"▴", WS_CHILD | WS_VISIBLE | BS_LEFT, 200 + 4, 100, 20, 20, hWnd, (HMENU)2, g_hInst, NULL);
// subclass the button control
btnProc = (WNDPROC)SetWindowLongPtr(hButton, GWLP_WNDPROC, (LONG_PTR)StaticButtonProc);
break;
case WM_TIMER:
// 300ms delay
if (t < 300) {
t += 100;
}
else {
// increment counter & continuously update Edit Control while button is depressed
counter += 1;
wchar_t buf[32];
wsprintf(buf, L"%d", counter);
SetWindowText(hEdit, buf);
}
break;
case WM_DESTROY:
PostQuitMessage(EXIT_SUCCESS);
break;
default:
return DefWindowProc(hWnd, uMsg, wParam, lParam);
}
return 0;
}
int WINAPI WinMain(
HINSTANCE hInst,
HINSTANCE hPrevInst,
LPSTR lpCmdLine,
int iCmdShow)
{
g_hInst = hInst;
WNDCLASS wndClass = {
.style = CS_HREDRAW | CS_VREDRAW,
.lpfnWndProc = WindowProc,
.hInstance = hInst,
.hIcon = LoadIcon(NULL, IDI_APPLICATION),
.hCursor = LoadCursor(NULL, IDC_ARROW),
.hbrBackground = (HBRUSH)GetStockObject(LTGRAY_BRUSH),
.lpszMenuName = NULL,
.lpszClassName = L"app",
};
if (!RegisterClass(&wndClass)) {
OutputDebugString(L"Failed to register window class\n");
return EXIT_FAILURE;
}
if (!CreateWindow(
L"app",
L"Counter",
WS_OVERLAPPEDWINDOW | WS_VISIBLE,
0, 0,
1280, 720,
NULL, NULL,
hInst, NULL))
{
OutputDebugString(L"Failed to create window\n");
return EXIT_FAILURE;
}
MSG msg = {};
while (GetMessage(&msg, NULL, 0, 0)) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return (int)msg.wParam;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/78719782/wm-lbuttondown-delay-issue-in-winapi[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия