BlinCT
BlinCTJuly 29, 2019, 8:41 a.m.

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

qt5

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

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

5
Алексей Внуков
  • July 29, 2019, 9:51 a.m.

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

    Алексей Внуков
    • July 29, 2019, 10:08 a.m.
    • (edited)
    • The answer was marked as a solution.

    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
      • July 29, 2019, 10:39 a.m.

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

        Алексей Внуков
        • July 29, 2019, 10:48 a.m.

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

          BlinCT
          • July 29, 2019, 10:52 a.m.

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

            Comments

            Only authorized users can post comments.
            Please, Log in or Sign up
            AD

            C ++ - Test 004. Pointers, Arrays and Loops

            • Result:50points,
            • Rating points-4
            m

            C ++ - Test 004. Pointers, Arrays and Loops

            • Result:80points,
            • Rating points4
            m

            C ++ - Test 004. Pointers, Arrays and Loops

            • Result:20points,
            • Rating points-10
            Last comments
            i
            innorwallNov. 11, 2024, 10:12 p.m.
            Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
            i
            innorwallNov. 11, 2024, 6:23 p.m.
            QML - Tutorial 035. Using enumerations in QML without C ++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
            i
            innorwallNov. 11, 2024, 3:50 p.m.
            Qt/C++ - Lesson 052. Customization Qt Audio player in the style of AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
            i
            innorwallNov. 11, 2024, 2:19 p.m.
            Heap sorting algorithm The role of raloxifene in preventing breast cancer priligy precio
            i
            innorwallNov. 11, 2024, 1:55 p.m.
            PyQt5 - Lesson 006. Work with QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
            Now discuss on the forum
            i
            innorwallNov. 11, 2024, 8:56 p.m.
            добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
            i
            innorwallNov. 11, 2024, 10:55 a.m.
            Всё ещё разбираюсь с кешем. 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
            9AnonimOct. 25, 2024, 9:10 a.m.
            Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

            Follow us in social networks