DF
Ақп. 6, 2022, 7:24 Т.Ж.

Qwt не обновляется информация на графике

QWT, Qt

Добрый день, использую Qwt для тестового задания, программа работает правильно, но не получается заставить график обновиться для отображения новых точек. Отображение новых точек происходит только при изменении масштаба графика колесиком мыши. Пробовал прописывать в слоте таймера следующие вещи:

plot->update();
plot->repaint();
vlayout->update();
centralWidget()->update();
centralWidget()->repaint();
this->update();
this->repaint(); // mainwindow

Подскажите пожалуйста, как динамически обновлять информацию на графике.

2

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

5
glum_psyche
  • Ақп. 6, 2022, 1:57 Т.Қ.
  • Жауап шешім ретінде белгіленді.

Попробуйте функцию replot()

    DF
    • Ақп. 7, 2022, 3:34 Т.Ж.

    Большое спасибо, помогло.
    Если можно, еще небольшой вопрос, каким средством лучше пользоваться для приостановки/возобновления потока в qt ?

      glum_psyche
      • Ақп. 7, 2022, 4:11 Т.Ж.

      Работа с потоками в Qt может осуществляться несколькими разными способами и это влияет на управление ими.
      В общем случае приостановка всегда временная (с указанием длительности), например QThread::msleep . По истечении указанного времени поток возобновится. Извне поток напрямую поставить на паузу/возобновить не удастся, хотя можно немедленно прекратить его (метод QThread::terminate ). Взаимодействовать можно и не напрямую.
      Если идёт взаимодествие с объектом (наследником QObject), помещённым в индивидуальный поток (при помощи moveToThread), то у него можно предусмотреть методы, позволяющие прекратить поток либо поставить его на паузу. Так как постановка на паузу происходит вызовом статического метода типа QThread::msleep (или аналогичным), то следует убедиться, что тело метода вызывается в потоке целевого объекта (через соединение сигнал-слот либо вызов QMetaMethod::invoke c с типом соединения Qt::QueuedConnection).
      При взаимодействии с созданием потока под функцию (Qthread::create) вряд ли будет иметь место пауза/продолжение потока, более вероятно досрочное прекращение потока (по return).
      При реализации потока через переопределение QThread::run имеет смысл отслеживать в основном цикле QThread::isInterruptionRequested и следовать нужной логике.
      Помимо документации стоит почитать статьи отсюда: Урок 46 , Урок 47 , Урок 48 .
      Надеюсь, что-то из пречисленного будет полезным.

        DF
        • Ақп. 7, 2022, 5:01 Т.Ж.
        • (өңделген)

        Спасибо за развернутый ответ.
        Наверное, надо было уточнить, виноват. У меня используется вариант через moveToThread(), обертку класса worker проталкиваем в поток, и в нём создается worker. Надо иметь возможность ставить поток на паузу из главного потока. Я осуществил это через сигналы-слоты, вызывая метод doWork, в котором есть while(true). По сигналу из гл. окна происходит mutex.lock(), а по другому unlock(). Программа работает, но я не уверен, хороший ли это способ приостанавливать поток, в плане выбора самого метода.

          glum_psyche
          • Ақп. 7, 2022, 10:51 Т.Қ.

          Если ссылаться на существующую практику, то ваш вариант похож на такой пример (на "чистом" C++) . Только стоит иметь в виду, что под каждый воркер нужен индивидуальный поток.
          Также можно рассмотреть возможность короткоживущих воркеров, а потоки для них выделять из пула (QThreadPool), чтобы не порождать их в огромном количестве. А организовывать порядок выполнения можно через постановку в очередь, управление в таком случае будет через обработчик очереди. Но это как вариант.

            Пікірлер

            Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
            Кіріңіз немесе Тіркеліңіз