Qwt не обновляется информация на графике
Добрый день, использую Qwt для тестового задания, программа работает правильно, но не получается заставить график обновиться для отображения новых точек. Отображение новых точек происходит только при изменении масштаба графика колесиком мыши. Пробовал прописывать в слоте таймера следующие вещи:
plot->update();
plot->repaint();
vlayout->update();
centralWidget()->update();
centralWidget()->repaint();
this->update();
this->repaint(); // mainwindow
Подскажите пожалуйста, как динамически обновлять информацию на графике.
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
- Akiv Doros
- 11 листопада 2024 р. 14:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
- molni99
- 26 жовтня 2024 р. 01:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
- molni99
- 26 жовтня 2024 р. 01:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Попробуйте функцию replot()
Большое спасибо, помогло.
Если можно, еще небольшой вопрос, каким средством лучше пользоваться для приостановки/возобновления потока в qt ?
Работа с потоками в Qt может осуществляться несколькими разными способами и это влияет на управление ими.
В общем случае приостановка всегда временная (с указанием длительности), например QThread::msleep . По истечении указанного времени поток возобновится. Извне поток напрямую поставить на паузу/возобновить не удастся, хотя можно немедленно прекратить его (метод QThread::terminate ). Взаимодействовать можно и не напрямую.
Если идёт взаимодествие с объектом (наследником QObject), помещённым в индивидуальный поток (при помощи moveToThread), то у него можно предусмотреть методы, позволяющие прекратить поток либо поставить его на паузу. Так как постановка на паузу происходит вызовом статического метода типа QThread::msleep (или аналогичным), то следует убедиться, что тело метода вызывается в потоке целевого объекта (через соединение сигнал-слот либо вызов QMetaMethod::invoke c с типом соединения Qt::QueuedConnection).
При взаимодействии с созданием потока под функцию (Qthread::create) вряд ли будет иметь место пауза/продолжение потока, более вероятно досрочное прекращение потока (по return).
При реализации потока через переопределение QThread::run имеет смысл отслеживать в основном цикле QThread::isInterruptionRequested и следовать нужной логике.
Помимо документации стоит почитать статьи отсюда: Урок 46 , Урок 47 , Урок 48 .
Надеюсь, что-то из пречисленного будет полезным.
Спасибо за развернутый ответ.
Наверное, надо было уточнить, виноват. У меня используется вариант через moveToThread(), обертку класса worker проталкиваем в поток, и в нём создается worker. Надо иметь возможность ставить поток на паузу из главного потока. Я осуществил это через сигналы-слоты, вызывая метод doWork, в котором есть while(true). По сигналу из гл. окна происходит mutex.lock(), а по другому unlock(). Программа работает, но я не уверен, хороший ли это способ приостанавливать поток, в плане выбора самого метода.
Если ссылаться на существующую практику, то ваш вариант похож на такой пример (на "чистом" C++) . Только стоит иметь в виду, что под каждый воркер нужен индивидуальный поток.
Также можно рассмотреть возможность короткоживущих воркеров, а потоки для них выделять из пула (QThreadPool), чтобы не порождать их в огромном количестве. А организовывать порядок выполнения можно через постановку в очередь, управление в таком случае будет через обработчик очереди. Но это как вариант.