|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
Qt с задержкой реагирует на клавиатуру и мышь11.10.2025, 19:23. Показов 2231. Ответов 45
Метки нет (Все метки)
В простом проекте без нагрузки сделал QWindow, рядом с позицией курсора (
QCursor::pos()) рисуется фигура. Её реакция отстаёт от курсора на целых 3 кадра. А реакция на keyPressEvent вообще 5 кадров. Причём рисование окна идёт с ускорением OpenGL. Отключение vsync задержку не убирало, только делало короче по времени (из-за того что сам кадр стал короче), но если мерить в кадрах - она даже длиннее становилась - 5 кадров вместо 3. Можно ли средствами Qt убрать эту тормознутость, или спасение только в winapi?
0
|
|
| 11.10.2025, 19:23 | |
|
Ответы с готовыми решениями:
45
QFileSystemWatcher не реагирует на изменения в общей папке сети
|
|
362 / 216 / 53
Регистрация: 18.10.2017
Сообщений: 2,337
|
|
| 11.10.2025, 20:39 | |
|
Сам я давно проектов на Qt не пишу, но думаю, что тут спросят, что Вы делаете в paintEvent() и в keyPressEvent().
И как рисуется фигура - вручную или специализированной функцией.
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
| 11.10.2025, 21:24 [ТС] | |
|
peter_irich, это не виджет, а наследник QWindow, у него нет paintEvent(). Кадр рисуется в собственном методе, по срабатыванию QTimer. В методе всё по примерам - просто создаётся QPainter, делается fillRect() и затем drawPolygon(). Таймер можно поставить хоть на 1-2 мс (будет 500 или 1000 фпс). Задержка всё равно огромная, в несколько кадров. Можно конечно и на виджете попробовать (QOpenGLWidget) но думаю будет всё так же. Я его тестировал раньше, QWindow больше понравился, и можно не тащить модуль Widgets в проект. В доках где-то видел ещё что QWindow потенциально более быстрый.
В keyPressEvent() ничего особенного не делается, только обновляется нужная переменная.
0
|
|
|
362 / 216 / 53
Регистрация: 18.10.2017
Сообщений: 2,337
|
|
| 11.10.2025, 22:12 | |
|
Т.е. в "методе" делается то, что, я думал, делается в paintEvent(). А где обрабатываются сообщения от мыши? Должен быть mousePressEvent().
Я пока ничего предположить не могу, м.б., Вы приложите весь проект? Тут есть знающие люди, если не я, то он и ответят.
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
| 11.10.2025, 23:27 [ТС] | |
|
0
|
|
|
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,654
|
||
| 16.10.2025, 00:21 | ||
|
0
|
||
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
| 16.10.2025, 01:00 [ТС] | |
|
kapbepucm, да в принципе можно открыть какой-нить из кьютишных примеров про QPainter, и сделать чтобы над курсором рисовалась всегда фигура. И просто подвигать курсор по экрану и глянуть, насколько отстаёт фигура от него. Я ещё снимал экран скоростной съёмкой и резко двигал курсор - там эти кадры отставания видно чётко.
0
|
|
|
|
||
| 17.10.2025, 10:45 | ||
|
0
|
||
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
| 17.10.2025, 12:32 [ТС] | |
|
Ilot, нет, с загрузкой проца проблем нет. Даже таймер на 1 мс совсем не грузит ядро (загрузка в диспетчере 0-1 %). Я просто приконнектил сигнал
timeout к функции отрисовки. У вас по-другому сделано, через событие. И как там правильно сказали, по идее в обработчике надо вызвать аналогичный родительский метод. В доках про это есть.
1
|
|
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
| 20.10.2025, 19:27 [ТС] | |
|
Вот пример с клавишами. Стрелками изменять размер и кол-во кружков, чтобы создать нагрузку.
Нажатие Esc - выводит момент в мс со старта программы: 1-е число - значение из timestamp события, второе - значение времени, полученное в обработчике. Видно что второе запаздывает на один кадр.Может быть маленькое расхождение из-за того что стартовый момент времени (сохранённый в конструкторе) мог быть не совсем тот что использует внутри себя механизм событий. Но явно видно что отставание обработчика от штампа всегда 1 кадр. Это ещё можно понять, но это ещё цветочки. А реальная реакция на нажатие у меня например отстаёт на 4 или 5 кадров. Т. е. можно например добавить нагрузку стрелками, чтобы кадр рисовался скажем 400 мс, и нажать Esc - программа реагирует не через эти ожидаемые 400 мс, а где-то через 2 с. Т. е. целые 4 кадра событие где-то гуляет, и только потом регается в очереди. Что за странная задержка? Кьюти какой-то жуткий тормоз в этом плане. На малых нагрузках это отставание в 4 кадра тоже есть.
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
| 21.10.2025, 17:21 [ТС] | |
|
Попробовал вместо ивентов делать через winapi (
GetAsyncKeyState), прямо в функции отрисовки, непосредственно перед рисованием. В целом всё так же! И та же задержка в 4 кадра.Как будто сами кадры перед выводом становятся в какую-то очередь и рисуются не сразу. При том что у меня игровой моник с нулевым input lag. Ещё в настройках видеокарты пробовал включать режим низкой задержки - не влияло. Может хоть кто-то прольёт свет на это всё. Как сделать по настоящему отзывчивое управление.
0
|
|
|
362 / 216 / 53
Регистрация: 18.10.2017
Сообщений: 2,337
|
|
| 21.10.2025, 21:12 | |
|
Там keyPressEvent() можно улучшить: вместо многих if,из которых выполнеяется только одим использовать switch().
При использовании таймеров попробовать таймер реального времени.
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
||
| 21.10.2025, 22:21 [ТС] | ||
Qt::PreciseTimer? Так и было изначально. Да и не даёт это ничего. А switch тем более.Кто-нибудь тестил пример? Такая же задержка?
0
|
||
|
Заблокирован
|
|
| 21.10.2025, 23:17 | |
|
Geek Geekson, может попробуешь всё тоже в UnrealEngine или в другом игровом движке?
Я уже просто ссусь кипятком так интересно, что же здесь решается)
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|
| 21.10.2025, 23:52 [ТС] | |
|
SmallEvil, а пример пробовал? Есть задержка в 4 кадра? А то я тоже начну кипятком ссаться
0
|
|
|
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,654
|
|
| 23.10.2025, 00:21 | |
|
Я запустил пример, вижу двигающийся круг. Нажимаю клавишу [esc]- появляются 2 цифры но отличаются не на 4 кадра, а на порядок, например 15464078 и 2062. Пока не понимаю, что у меня тут от чего отстаёт. Смотрю код, но понимание почемуто не приходит.
Вижу обработчик клавиатурных событий- он однозначно не вызывается в тот самый миг, когда клавиша нажата (там всё вызывается в порядке определённой очереди).
0
|
|
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
|||
| 23.10.2025, 00:54 [ТС] | |||
timestamp() полученного события. Вторая - момент в мс со старта, рассчитанный в самой проге. И почему этот timestamp() у вас такой большой - это странно, но все вопросы к Qt а не ко мне. Но на эти цифры можно пока не смотреть.Самое главное - понажимайте стрелки вверх и вправо, чтобы увеличить кол-во и размер кругов (создать нагрузку), чтобы "frame:" показывало где-нибудь 300 - 500 ms. И потом нажмите Esc и примерно прикиньте через сколько времени появилась реакция (сменился фон). У меня это время раз в 5 больше фрейма, то есть когда "frame: 400 ms" - фон меняется где-то через 2 секунды только. Хотя должен, по идее, максимум за 800 мс (т. е. 2 кадра). Можно ещё больше нагрузку дать, чтобы задержка была лучше заметна.
0
|
|||
|
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,654
|
||
| 23.10.2025, 23:33 | ||
|
Что я вижу в работающей программе (я потыкал много вверх и вправо и Escape): -куча операций выполняется в renderNow -в то же время накапливаются сигналы от таймера, что пора запускать renderNow повторно -также ждут своего часа клавиатурный обработчик -когда наконец renderNow выполнился, планировщик очереди запускает именно renderNow, а клавиатура ждёт в более низком приорите, так как у нас Qt::PreciseTimer и ещё сигналов таймера поступает огромное количество (обрабатывается только последний, остальные дропаются) -обработка Esc происходит с значительным опозданием Ну вроде всё логично... Осознание того, как мы тут замеряем реальный миг нажатия клавиатуры, который необходимо сопоставить с нужным номером кадра, ко мне всё ещё не пришло У нас же тут не разные потоки а один- или рисуем или смотрим что там от клавиатуры прилетело.
0
|
||
|
3 / 3 / 0
Регистрация: 12.07.2022
Сообщений: 213
|
||
| 24.10.2025, 00:50 [ТС] | ||
|
И например в древнем (и ныне покойном) Blitz Plus (на котором я писал когда-то) именно так. Вот прямо ща проверил, на этой же машине - реакция максимум 2 кадра, независимо от длины кадра. А крутой и современный Qt еле ворочает ластами. И задержка походу не в самом механизме событий. Т. к. пробовал и через WinAPI (см. выше). ХЗ откуда она берётся.
0
|
||
|
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,654
|
|||||||
| 24.10.2025, 09:41 | |||||||
И также не учитывается то, что порядок обработки событий в Qt не идёт строго по их поступлению, чтото может, взависимости от приоритетов, выполнится раньше или пожже. Ну то есть мы жмём на клавишу Esc, Qt это видит и знает, но в какойто момент вперёд пускает обработчика таймера, а не обработчика клавиатуры.
0
|
|||||||
| 24.10.2025, 09:41 | |
|
Помогаю со студенческими работами здесь
20
QtCreator не реагирует на изменение файлов формы KeyPressEvent не реагирует на нажатия стрелок
Слот не реагирует на сигнал Слот не реагирует Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|
Фото: Daniel Greenwood
kumehtar 13.11.2025
|
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга,
Ты же видел моря и метели.
Как сменялись короны и стяги,
Как эпохи стрелою летели.
- Этот мир — это крылья и горы,
Снег и пламя, любовь и тревоги,
И бескрайние. . .
|
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1
У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\
А в самом низу файла-профиля. . .
|