BlinCT
BlinCT29 июля 2019 г. 8:41

Врапер для класса и работа с мета обьектами

qt5

Всем привет.
Вопрос о возможности подобной реализации:
Есть класс worker(внутри есть проперти, сигналы и т.д.), он работает в отдельном потоке.
Есть класс wrapper, он должен считать все проперти из класса worker и передать данные тому кто будет данные юзать. Например аппликация с quick2.
То есть вся работа проходит через данный врапер.
Если у кого есть подобный пример или можете написать примерно как это должно работать, буду очень признателен.
Но как я понимаю это связано с dinamic properties, и Meta-Object System.
Спасибо.

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

5
Алексей Внуков
  • 29 июля 2019 г. 9:51

есть пример. пару минут

    Алексей Внуков
    • 29 июля 2019 г. 10:08
    • (ред.)
    • Ответ был помечен как решение.

    wrapper.h

    #ifndef WRAPPER_H
    #define WRAPPER_H
    
    #include <QMainWindow>
    #include <QDebug>
    #include <QThread>
    #include <QCoreApplication>
    #include <workera.h>
    #include <workerb.h>
    #include <workerc.h>
    #include <workerd.h>
    #include <QProcess>
    #include <QQmlEngine>
    #include <QJSEngine>
    
    class Wrapper : public QObject
    {
        Q_OBJECT
    public:
        explicit Wrapper(QObject *parent=nullptr);
        ~Wrapper();
    
    public slots:
        Q_INVOKABLE void run_control();
        Q_INVOKABLE void stop_control();
    
    signals:
        void sig_stop_fire();
    
    private:
        WorkerA *work_1;
        WorkerB *work_2;
        WorkerC *work_3;
        WorkerD *work_4;
        QThread *thr_work_1;
        QThread *thr_work_2;
        QThread *thr_work_3;
        QThread *thr_work_4;
    };
    
    static QObject *singeltonProvider(QQmlEngine *engine, QJSEngine *scriptEngine)
    {
        Q_UNUSED(engine);
        Q_UNUSED(scriptEngine);
    
        Wrapper *wrapper=new Wrapper();
        return wrapper;
    }
    
    #endif // WRAPPER_H
    
    

    wrapper.cpp

    #include "wrapper.h"
    
    Wrapper::Wrapper(QObject *parent)
    {
        work_1=new WorkerA();
        work_2=new WorkerB();
        work_3=new WorkerC();
        work_4=new WorkerD();
        thr_work_1=new QThread(this);
        thr_work_2=new QThread(this);
        thr_work_3=new QThread(this);
        thr_work_4=new QThread(this);
    
        work_1->moveToThread(thr_work_1);
        work_2->moveToThread(thr_work_2);
        work_3->moveToThread(thr_work_3);
        work_4->moveToThread(thr_work_4);
    
        connect(thr_work_1,&QThread::started,work_1,&WorkerA::go);
        connect(work_1,&WorkerA::sent_n, this,&Wrapper::reader_data);
    
        connect(thr_work_2,&QThread::started,work_2,&WorkerB::go);
        connect(work_2,&WorkerB::sent_n,this,&Wrapper::reader_data);
    
        connect(thr_work_3,&QThread::started,work_3,&WorkerC::go);
        connect(work_3,&WorkerC::sent_n,this,&Wrapper::reader_data);
    
        connect(thr_work_4,&QThread::started,work_4,&WorkerD::go);
        connect(work_4,&WorkerD::sent_n,this,&Wrapper::reader_data);
    
        connect(this,&Wrapper::destroyed,thr_work_1,&QThread::quit);
        connect(this,&Wrapper::destroyed,thr_work_2,&QThread::quit);
        connect(this,&Wrapper::destroyed,thr_work_3,&QThread::quit);
        connect(this,&Wrapper::destroyed,thr_work_4,&QThread::quit);
    
    }
    
    Wrapper::~Wrapper()
    {
        stop_control();
        QThread::sleep(2);
    }
    
    void Wrapper::run_control()
    {
        thr_work_1->start();
        thr_work_2->start();
        thr_work_3->start();
        thr_work_4->start();
    
        //emit print("started");
        //qDebug("started");
    }
    
    void Wrapper::stop_control()
    {
        stop_thr=false;
        thr_work_1->quit();
        thr_work_2->quit();
        thr_work_3->quit();
        thr_work_4->quit();
    
       // qDebug("controller stoped");
    }
    
    
    

    main.cpp

    #include <QGuiApplication>
    #include <QQmlApplicationEngine>
    #include <QQmlEngine>
    #include <QQmlContext>
    #include <QtQml>
    #include <wrapper.h>
    
    int main(int argc, char *argv[])
    {
        QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
    
        QGuiApplication app(argc, argv);
    
        QQmlApplicationEngine engine;
    
        QmlTranslator qmlTranslator(&engine);
    
        qmlRegisterSingletonType <Wrapper>("Wrapper",1,0,"Wrapper", singeltonProvider);
    
        engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
        if (engine.rootObjects().isEmpty())
            return -1;
    
        return app.exec();
    }
    
    

    воркеры живут в отдельных потоках, у каждого всегда запущен бесконечный цыкл для обработки данных, потом через сигналы передают в враппер, при необходимости во враппере или передаются в другой поток и обрабатываются дальше или обрабатываются во враппере
    в QML потом делаем

    import Wrapper 1.o
    Item
    {
        Connections
        {
            target:Wrapper
            // слот сигнала из С++
        }
    
        Wrapper.run_control()
    }
    

    п.с. вроде то что искали. если я правильно понял

      BlinCT
      • 29 июля 2019 г. 10:39

      Скорее всего это то что я и искал. Но хотел кое что уточнить, я правильно понимаю что для всех воркеров только один врапер? Не правильней ли иметь для каждого воркера только свой врапер?

        Алексей Внуков
        • 29 июля 2019 г. 10:48

        вам нужна точка взаимодействия, даже если вы сделаете для каждого воркера свой враппер, вам нужно будет делать базовый класс в котором нужно будет прописать их коннекты и взаимодействие, если этого не нужно и они должны быть полностью изолированы друг от друга, то можно попробовать объявить объект каждого враппера в main.cpp и добавить их в rootContextPropperty, и потом с ним работать как с врапером из примера

          BlinCT
          • 29 июля 2019 г. 10:52

          Спасибо за инфу) будем пробовать.

            Комментарии

            Только авторизованные пользователи могут публиковать комментарии.
            Пожалуйста, авторизуйтесь или зарегистрируйтесь
            AD

            C++ - Тест 004. Указатели, Массивы и Циклы

            • Результат:50баллов,
            • Очки рейтинга-4
            m
            • molni99
            • 26 октября 2024 г. 6:37

            C++ - Тест 004. Указатели, Массивы и Циклы

            • Результат:80баллов,
            • Очки рейтинга4
            m
            • molni99
            • 26 октября 2024 г. 6:29

            C++ - Тест 004. Указатели, Массивы и Циклы

            • Результат:20баллов,
            • Очки рейтинга-10
            Последние комментарии
            i
            innorwall15 ноября 2024 г. 7:27
            Релиз утилиты развертывания С++/Qt и QML приложений CQtDeployer v1.4.0 (Binary Box) optionally substituted alkoxy, optionally substituted alkenyloxy, optionally substituted alkynyloxy, optionally substituted aryloxy, OCH, OC H, OC H, OC H, OC H, OC H, OC H, O C CH, OCH CH OH, O…
            i
            innorwall15 ноября 2024 г. 2:26
            Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
            i
            innorwall15 ноября 2024 г. 0:03
            Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
            i
            innorwall14 ноября 2024 г. 16:42
            Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
            Сейчас обсуждают на форуме
            i
            innorwall14 ноября 2024 г. 8:39
            добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
            i
            innorwall11 ноября 2024 г. 15:55
            Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
            9
            9Anonim25 октября 2024 г. 14:10
            Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
            ИМ
            Игорь Максимов3 октября 2024 г. 9:05
            Реализация навигации по разделам Спасибо Евгений!

            Следите за нами в социальных сетях