Форум программистов, компьютерный форум, киберфорум
C++ Qt
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97

Сигналы и слоты

25.08.2025, 13:31. Показов 2258. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    ui->ButtonOK->setDefault(true);
    connect(ui->ButtonOK ,SIGNAL(clicked(bool)),this,SLOT(on_pushButton_clicked()));
}
 
MainWindow::~MainWindow()
{
    delete ui;
}
void MainWindow::on_pushButton_clicked()
{
    QString emitent = ui->ticker->text();//берем введенный тикер и ищем
на это получаю это: QMetaObject::connectSlotsByName: No matching signal for on_pushButton_clicked()
----------------------------------------------------------------------------------------------------------------------------------------------------
HttpFetcher::HttpFetcher(QObject *parent) : QObject(parent)
{
    manager = new QNetworkAccessManager;
    connect(manager,SIGNAL(finished(QNetworkReply*)), this, SLOT(Result));
}
//Принимаем url получаем результат
void HttpFetcher::Result(const QUrl &url)
{  
    reply = manager->get(QNetworkRequest(QUrl(url)));
    //reply->ignoreSslErrors();
    if(reply->error() == QNetworkReply::NoError)
    {
        //PREVPRICE = xmlParser(reply->readAll());
        QString str = QString::fromUtf8(reply->readAll().data(),reply->readAll().size());
        int statuscode = reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
        qDebug()<<QVariant(statuscode).toString();
        qDebug() << reply->readAll();
    }
    else
    {
        qDebug()<<"Ошибка:"<<reply->errorString();
        qWarning() << "Ошибка HTTP:" << reply->errorString();
        QCoreApplication::quit();
    }
    reply->deleteLater();
    manager->deleteLater();
}
на это получаю:QObject::connect: Parentheses expected, slot HttpFetcher::Result in ..\..\httprequest.cpp:9

Добавлено через 3 минуты
а еще вот такое есть : qt.tlsbackend.ossl: Failed to load libssl/libcrypto. но не на что не влияет.

Добавлено через 5 минут
хотя по отладке переходит после нажатия на кнопку в on_pushButton_clicked().
так и в процессе отладки переходит в Result(const QUrl &url).
но возвращает код 0 и по запросу пустой ответ:"0"
""
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.08.2025, 13:31
Ответы с готовыми решениями:

Сигналы и слоты
Смысл следующий: Вводим число в spinBox, это число, с помощью сигнала, передаётся слоту объекта...

Сигналы\слоты
что можно сделать со сл. кодом ...

Сигналы и слоты
добрый ! подскажите, как вызвать функцию через нажатие кнопки? собсна то, что нужно вызвать. ...

23
1131 / 727 / 194
Регистрация: 30.03.2021
Сообщений: 2,378
25.08.2025, 14:32
по первой части хз, по второй
Цитата Сообщение от MVDmitrii Посмотреть сообщение
connect(manager,SIGNAL(finished(QNetwork Reply*)), this, SLOT(Result));
пробздел пробел
и
если сигнал что-то передает, слот должен принимать такую же сигнатуру либо не принимать ничего
SIGNAL(finished(QNetworkReply*)) и Result(const QUrl &url) не совпадает

в такой форме записи коннекта все скомпилируется, а в рантайме выдаст ошибку в лог
пиши лучше так
connect(manager, &QNetworkAccessManager::finished, this, &MainWindow::Result);
тогда ошибка вылетит при компиляции
0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
09.10.2025, 19:19  [ТС]
есть такой слот:
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void MainWindow::progressChanged(qint64 bytesSent, qint64 bytesTotal)
{
    if(bytesTotal>0)//если началась загрузка
    {
        int progress = (static_cast<double>(bytesSent)/bytesTotal)*100;
        progressBar->setValue(progress);//отобразить видимость загрузки
        //qApp->processEvents();
    }
    if(bytesTotal == bytesSent)//если загрузка завершена
    {
        progressBar->setVisible(false);//убираем видимость прогрессбара
        newlayout->addWidget(new QLabel(PREVPRICE));//выводим загруженное значение
    }
}
вот здесь коннект:
C++ (Qt)
1
2
3
4
5
6
7
void HttpFetcher::setURL(const QUrl &url)
{
    reply = manager->get(QNetworkRequest(QUrl(url)));//перезаписываем результат ответа
    connect(reply,&QNetworkReply::uploadProgress,this,&MainWindow::progressChanged);//процесс загрузки
    connect(reply,&QNetworkReply::readyRead,this,&HttpFetcher::onFinished);//Этот сигнал испускается каждый раз, когда новые данные доступны
    //для чтения из текущего канала чтения устройства. Он будет испускаться снова только после того, как новые данные станут доступны.
}
получаю ошибку:"QMetaMethod::QMetaMethod": ни одна перегруженная функция не может преобразовать все типы аргументов
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
class MainWindow : public QMainWindow
{
    Q_OBJECT
private slots:
    void on_pushButton_clicked();
    void delet_emitent();
public slots:
    void progressChanged(qint64 bytesSent, qint64 bytesTotal);
public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
Добавлено через 6 минут
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
Вывод сборки:
..\..\httprequest.cpp(19): error C2665: "QObject::connect": ни одна перегруженная функция не может преобразовать все типы аргументов
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(432): note: может быть "QMetaObject::Connection QObject::connect(const QObject *,const char *,const char *,Qt::ConnectionType) const"
..\..\httprequest.cpp(19): note: "QMetaObject::Connection QObject::connect(const QObject *,const char *,const char *,Qt::ConnectionType) const": невозможно преобразовать аргумент 2 из "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "const char *"
..\..\httprequest.cpp(19): note: Не существует контекста, в котором такое преобразование возможно
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(184): note: или       "QMetaObject::Connection QObject::connect(const QObject *,const QMetaMethod &,const QObject *,const QMetaMethod &,Qt::ConnectionType)"
..\..\httprequest.cpp(19): note: "QMetaObject::Connection QObject::connect(const QObject *,const QMetaMethod &,const QObject *,const QMetaMethod &,Qt::ConnectionType)": невозможно преобразовать аргумент 2 из "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "const QMetaMethod &"
..\..\httprequest.cpp(19): note: Причина: невозможно преобразовать "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "const QMetaMethod"
..\..\httprequest.cpp(19): note: "QMetaMethod::QMetaMethod": ни одна перегруженная функция не может преобразовать все типы аргументов
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore\qmetaobject.h(180): note: может быть "QMetaMethod::QMetaMethod(QMetaMethod &&)"
..\..\httprequest.cpp(19): note: "QMetaMethod::QMetaMethod(QMetaMethod &&)": невозможно преобразовать аргумент 1 из "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "QMetaMethod &&"
..\..\httprequest.cpp(19): note: Причина: невозможно преобразовать "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "QMetaMethod"
..\..\httprequest.cpp(19): note: Для преобразования требуется второй оператор пользовательского преобразования или конструктор
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore\qmetaobject.h(180): note: или       "QMetaMethod::QMetaMethod(const QMetaMethod &)"
..\..\httprequest.cpp(19): note: "QMetaMethod::QMetaMethod(const QMetaMethod &)": невозможно преобразовать аргумент 1 из "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "const QMetaMethod &"
..\..\httprequest.cpp(19): note: Причина: невозможно преобразовать "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "const QMetaMethod"
..\..\httprequest.cpp(19): note: Для преобразования требуется второй оператор пользовательского преобразования или конструктор
..\..\httprequest.cpp(19): note: при попытке сопоставить список аргументов "(void (__cdecl QNetworkReply::* )(qint64,qint64))"
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(181): note: или       "QMetaObject::Connection QObject::connect(const QObject *,const char *,const QObject *,const char *,Qt::ConnectionType)"
..\..\httprequest.cpp(19): note: "QMetaObject::Connection QObject::connect(const QObject *,const char *,const QObject *,const char *,Qt::ConnectionType)": невозможно преобразовать аргумент 2 из "void (__cdecl QNetworkReply::* )(qint64,qint64)" в "const char *"
..\..\httprequest.cpp(19): note: Не существует контекста, в котором такое преобразование возможно
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(201): note: или       "QMetaObject::Connection QObject::connect<void(__cdecl QNetworkReply::* )(qint64,qint64),void(__cdecl MainWindow::* )(qint64,qint64)>(const QNetworkReply *,Func1,const MainWindow *,Func2,Qt::ConnectionType)"
        with
        [
            Func1=void (__cdecl QNetworkReply::* )(qint64,qint64),
            Func2=void (__cdecl MainWindow::* )(qint64,qint64)
        ]
..\..\httprequest.cpp(19): note: "QMetaObject::Connection QObject::connect<void(__cdecl QNetworkReply::* )(qint64,qint64),void(__cdecl MainWindow::* )(qint64,qint64)>(const QNetworkReply *,Func1,const MainWindow *,Func2,Qt::ConnectionType)": невозможно преобразовать аргумент 3 из "HttpFetcher *" в "const MainWindow *"
        with
        [
            Func1=void (__cdecl QNetworkReply::* )(qint64,qint64),
            Func2=void (__cdecl MainWindow::* )(qint64,qint64)
        ]
..\..\httprequest.cpp(19): note: Типы, на которые указывают указатели, не связаны; для преобразования требуется reinterpret_cast, приведение в стиле С или приведение в стиле функции в круглых скобках
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(287): note: или       "std::enable_if<QtPrivate::FunctionPointer<Func2>::ArgumentCount==-1&&!std::is_convertible_v<Func2,const char*>,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,const QObject *,Func2,Qt::ConnectionType)"
..\..\httprequest.cpp(19): note: Сбой при специализации функции-шаблона "std::enable_if<QtPrivate::FunctionPointer<Func2>::ArgumentCount==-1&&!std::is_convertible_v<Func2,const char*>,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,const QObject *,Func2,Qt::ConnectionType)"
..\..\httprequest.cpp(19): note: Со следующими аргументами шаблона:
..\..\httprequest.cpp(19): note: "Func1=void (__cdecl QNetworkReply::* )(qint64,qint64)"
..\..\httprequest.cpp(19): note: "Func2=void (__cdecl MainWindow::* )(qint64,qint64)"
..\..\httprequest.cpp(19): note: type: не является прямым или косвенным базовым классом для "std::enable_if<false,QMetaObject::Connection>"
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(276): note: или       "std::enable_if<QtPrivate::FunctionPointer<Func2>::ArgumentCount==-1&&!std::is_convertible_v<Func2,const char*>,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,Func2)"
..\..\httprequest.cpp(19): note: "std::enable_if<QtPrivate::FunctionPointer<Func2>::ArgumentCount==-1&&!std::is_convertible_v<Func2,const char*>,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,Func2)": ожидаются аргументы 34 предоставлены
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(242): note: или       "std::enable_if<>=0&&!QtPrivate::FunctionPointer<Func2>::IsPointerToMemberFunction,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,const QObject *,Func2,Qt::ConnectionType)"
..\..\httprequest.cpp(19): note: Сбой при специализации функции-шаблона "std::enable_if<>=0&&!QtPrivate::FunctionPointer<Func2>::IsPointerToMemberFunction,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,const QObject *,Func2,Qt::ConnectionType)"
..\..\httprequest.cpp(19): note: Со следующими аргументами шаблона:
..\..\httprequest.cpp(19): note: "Func1=void (__cdecl QNetworkReply::* )(qint64,qint64)"
..\..\httprequest.cpp(19): note: "Func2=void (__cdecl MainWindow::* )(qint64,qint64)"
..\..\httprequest.cpp(19): note: type: не является прямым или косвенным базовым классом для "std::enable_if<false,QMetaObject::Connection>"
D:\Programm\Qt\6.4.1\msvc2019_64\include\QtCore/qobject.h(233): note: или       "std::enable_if<>=0,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,Func2)"
..\..\httprequest.cpp(19): note: "std::enable_if<>=0,QMetaObject::Connection>::type QObject::connect(const QtPrivate::FunctionPointer<Func>::Object *,Func1,Func2)": ожидаются аргументы 34 предоставлены
..\..\httprequest.cpp(19): note: при попытке сопоставить список аргументов "(QNetworkReply *, void (__cdecl QNetworkReply::* )(qint64,qint64), HttpFetcher *, void (__cdecl MainWindow::* )(qint64,qint64))"
Добавлено через 5 минут
короче, как я понял проблема из-за того что сигнал и слот из разных классов? но как их в таком случае соединить?

Добавлено через 2 минуты
connect(reply,&QNetworkReply::uploadProg ress,this,&MainWindow:rogressChanged);//процесс загрузки
вот здесь должен быть не this естественно.

Добавлено через 10 минут
но что...
предстоит разобраться!
0
09.10.2025, 20:02

Не по теме:

Цитата Сообщение от MVDmitrii Посмотреть сообщение
но что... предстоит
визит в раздел "с++ для начинающих", а затем в книжки/документацию/примеры по Qt

0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
27.10.2025, 16:03  [ТС]
и так вернулся я к коду и вот что у меня получилось, а точнее не получилось.
C++ (Qt)
1
connect(reply,&QNetworkReply::uploadProgress,progressBar,&MainWindow::progressChanged);
есть reply который дает сигнал uploadProgress вот перевод: "
Этот сигнал отправляется для индикации хода выполнения загрузки в рамках данного сетевого запроса, если таковая имеется."
есть progressBar который принимает сигнал и выполняет progressChanged. НО progressBar создается программно и находится в mainwindow.cpp, а reply находится в httprequest.cpp и такая запись говорит что progressBar необъявленный идентификатор.
начитался я уже много чего но понять видимо не смог.
ПОМОГИТЕЕЕЕЕЕ!!!!!!!!!!!
0
Заблокирован
27.10.2025, 19:52
Цитата Сообщение от MVDmitrii Посмотреть сообщение
progressBar
Это что тут делает? тут должен быть указатель на MainWindow
0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
27.10.2025, 20:23  [ТС]
Цитата Сообщение от SmallEvil Посмотреть сообщение
тут должен быть указатель на MainWindow
это почему? там ведь объект должен быть!?
0
Заблокирован
27.10.2025, 20:30
Цитата Сообщение от MVDmitrii Посмотреть сообщение
это почему? там ведь объект должен быть!?
Да указатель на объект, объект получателя сигнала и владельца слота.

Добавлено через 3 минуты
https://doc.qt.io/qt-6/qobject... onnection)
template <typename PointerToMemberFunction> QMetaObject::Connection QObject::connect(const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method, Qt::ConnectionType type = Qt::AutoConnection)
0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
27.10.2025, 20:52  [ТС]
я что то не понимаю?
connect(reply ----------- объект дающий сигнал
,&QNetworkReply::uploadProgress,------------сигнал
progressBar,----------------объект приема сигнала
&MainWindow:rogressChanged);-------------слот
0
Заблокирован
27.10.2025, 21:20
Цитата Сообщение от MVDmitrii Посмотреть сообщение
я что то не понимаю?
Да. Слот должен принадлежать классу получателя.
А сигнал, классу отправителя.

Иначе как он их вызовет?

Добавлено через 48 секунд
То что не видно переменной progressbar это цветочки.
0
1131 / 727 / 194
Регистрация: 30.03.2021
Сообщений: 2,378
27.10.2025, 21:26
Цитата Сообщение от MVDmitrii Посмотреть сообщение
ПОМОГИТЕЕЕЕЕЕ!!!!!!!!!!!
ничему ты не учишься, Джон Сноу

По феншую HttpFetcher не должен знать о существовании каких-либо окон (а так же выпячивать наружу свои приватные сущности), поэтому можно сделать в этом классе сигналы, дублирующие сигналы от классов, работающих с вэбом.
например:
Кликните здесь для просмотра всего текста

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
class HttpFetcher 
{
...
signals:
     void fetcherUploadProgress(qint64, qint64 );
     void fetcherDownloadProgress(qint64, qint64);
     void fetcherFinished();
};
 
// там где создается запрос в классе HttpFetcher - переконнектить эти сигналы,  например:
void HttpFetcher::setURL(const QUrl &url){
       auto reply = manager->get(QNetworkRequest(QUrl(url)));
       connect(reply, &QNetworkReply::downloadProgress, this, &HttpFetcher::fetcherDownloadProgress);
       connect(reply, &QNetworkReply::uploadProgress, this, &HttpFetcher::fetcherUploadProgress);
       connect(reply, &QNetworkReply::finished, this, &HttpFetcher::fetcherFinished);
}
 
// а где-то в окне уже создаешь прогрессбар и фетчер к нему:
void MainWindow:: там_где_создаются_запросы_в_окне(){
    auto fetcher = new HttpFetcher(this);
    auto progressBar = new QProgressBar;
    layout->addWidget(progressBar);
    progressBar->setMinimum(0);
    connect(fetcher, &HttpFetcher::fetcherUploadProgress, [progressBar](qint64 bytesSent, qint64 bytesTotal){
         if(progressBar->maximum() != bytesTotal)
               progressBar->setMaximum(bytesTotal);
         progressBar->setValue(bytesSent);
    });
    fetcher->setURL(...);
    // по аналогии коннект на download, и коннект на finished(в котором например, удалять уже не нужный fetcher ) и тд.
}


Не по теме:


Прыгаешь через ступеньки и поэтому нихрена не можешь понять. Разберись с сабжем на простых примерах.

0
Заблокирован
27.10.2025, 21:52
Цитата Сообщение от sdf45 Посмотреть сообщение
Разберись с сабжем на простых примерах.
Qt с задержкой реагирует на клавиатуру и мышь
=)
1
1131 / 727 / 194
Регистрация: 30.03.2021
Сообщений: 2,378
27.10.2025, 23:09

Не по теме:

SmallEvil, ахахах, ну да :)



Добавлено через 1 час 5 минут
MVDmitrii, вот вроде бы не особо сложное и работающее нечто, с прогресбарами.
со слабой надеждой, что ты его попробуешь и разберешся

Кликните здесь для просмотра всего текста

Класс, имитирующий твой фетчер, из него приходят какие-то данные в сигнале progress()

myprocess.h
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include <QObject>
#include <QTimer>
#include <QDebug>
 
//MyProcess = HttpFetcher
class MyProcess : public QObject
{
    Q_OBJECT
 
private:
    static inline int count{};
    int id{};
    int total{1000}, step{10}, current{};
    QTimer *timer;
 
public:
    using QObject::QObject;
 
    MyProcess(QObject *parent=nullptr):QObject(parent){
 
        id= ++count;
        qDebug()<<QString("process %1 created").arg(id);
 
        timer=new QTimer(this);
        timer->setInterval(100);
 
        // по таймеру имитируем прогресс каких-то данных
        connect(timer, &QTimer::timeout, this , [this]{
            current += step;
            if(current > total){
                timer->stop();
                emit finish();  // фетчер всё
            }
            else{
                emit progress(current, total); //фетчер передает данные
                //имитация QNetworkReply::uploadProgress / downloadProgress
            }
        });
    }
 
    ~MyProcess(){ qDebug()<<QString("process %1 deleted").arg(id); }
    void start(){ timer->start(); }
    int getId()const{ return id; }
 
signals:
    void progress(int, int);
    void finish();
};

mainwindow.cpp
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "mainwindow.h"
#include <QVBoxLayout>
#include <QHBoxLayout>
#include <QProgressBar>
#include <QLabel>
#include <QPushButton>
 
#include "myprocess.h"
 
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
{
    auto form=new QWidget;
    auto layout=new QVBoxLayout;
    form->setLayout(layout);
    setCentralWidget(form);
 
    auto btn=new QPushButton("add process");
    layout->addWidget(btn);
 
    // функция, которая создает фетчер и прогрессбар, который будет отображать
    // ход процесса "загрузки данных" в фетчере
    auto addProcess=[layout, this]{
        auto myProcess=new MyProcess(this); //созд. фетчер
 
        //метка и прогрессбар в компоновку окна
        auto lbl=new QLabel(QString("process %1").arg(myProcess->getId()));
        auto progressBar=new QProgressBar;
        progressBar->setMinimum(0);
 
        auto hlayout=new QHBoxLayout;
        hlayout->addWidget(lbl);
        hlayout->addWidget(progressBar);
        layout->addLayout(hlayout);
 
        //когда "фетчер" закончил работу - удаляем его 
        //(предполагается, что повторных запросов не предусмотрено)
        connect(myProcess, &MyProcess::finish, myProcess, &MyProcess::deleteLater);
 
        //связываем прогрессбар и фетчер, для отображения на окне хода "загрузки" в фетчере
        connect(myProcess, &MyProcess::progress, this,
                [progressBar](int progress, int total){
            if(progressBar->maximum() != total)
                progressBar->setMaximum(total);
            progressBar->setValue(progress);
        });
 
        myProcess->start();
    };
 
    // по нажатию кнопки выполняем функцию выше, добавляя новый прогресс в окно
    connect(btn, &QPushButton::clicked, addProcess);
}
 
MainWindow::~MainWindow() {}
0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
28.10.2025, 18:24  [ТС]
не понятно. в одном классе пишите что fetcher.... сигнал но используется как слот.
но спасибо за подсказку закинуть коннект в то место где создается progressBar, ошибок нет.
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
fetcher = new HttpFetcher();//Создаем новый запрос
            fetcher->setURL(url);//Принимаем новый адрес
 
            progressBar = new QProgressBar(caseWidget);//создаем прогрессбар
            progressBar->setFormat("%p");//текст в процентах
            progressBar->setMinimumWidth(70);
            progressBar->isTextVisible();//показывать проценты
            newlayout->addWidget(progressBar);//помещаем прогрессбар на свой слой
 
            newlayout->addStretch();
 
            delet = new QPushButton(caseWidget);
            delet->setText("Удалить");
            newlayout->addWidget(delet);
 
            connect(reply,&QNetworkReply::uploadProgress,this,&MainWindow::progressChanged);//процесс загрузки
но закинул его как reply потому что у него есть uploadProgress, но отладка показала что этот сигнал он не выдает.
Миниатюры
Сигналы и слоты  
0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
28.10.2025, 18:35  [ТС]
хотя значение в ответе reply уже есть
0
1131 / 727 / 194
Регистрация: 30.03.2021
Сообщений: 2,378
28.10.2025, 19:08
MVDmitrii, этот код выше выполняется в MainWindow?
Если да, то откуда там взялся reply в коннекте? Ведь он "зашит" в HttpFetcher.

В том то и смысл, что в классе HttpFetcher, (который, как я понимаю - обертка над QNetworkAccessManager), выполняются некие манипуляции с вэбом, и вот результаты таких манипуляций класс HttpFetcher должен выдавать наружу.

Для этого создаются свои сигналы в HttpFetcher, которые, так сказать, перенаправляют сигналы от закрытых, внутренних сущностей класса HttpFetcher, таких как QNetworkReply и прочего.

Затем создается фетчер в окне, и используются сигналы/слоты, сеттеры/геттеры именно класса HttpFetcher, никаких reply.

По поводу сигналов:
К сигналам в Qt можно подключать как слоты в виде функций(методов или лямбд), так и другие сигналы.
Если к сигналу А подключен сигнал Б - то если срабатывает сигнал А - вызывается сигнал Б, с передачей параметров, если указано.

(В профиле у тебя написано, что любишь заниматься всякими платами - так вот представь, что ты делаешь отдельную плату HttpFetcher. У нее есть какие-то входы, потом ток преобразуется платой и поступает на выходы. Вот кто-то использует твою плату - он же не впаивает проводки куда попало, но строго ко входу и выходу. Так и в классе HttpFetcher могут быть входы (сеттеры, слоты) и выходы(геттеры, сигналы))

fetcher = new HttpFetcher(this); иначе может быть утечка памяти.
0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
28.10.2025, 19:18  [ТС]
Цитата Сообщение от sdf45 Посмотреть сообщение
Если да, то откуда там взялся reply в коннекте? Ведь он "зашит" в HttpFetcher.
я его сделал как глобальную переменную.
Цитата Сообщение от sdf45 Посмотреть сообщение
Так и в классе HttpFetcher могут быть входы (сеттеры, слоты) и выходы(геттеры, сигналы))
ну так по логике reply - ответ - выход.
0
1131 / 727 / 194
Регистрация: 30.03.2021
Сообщений: 2,378
28.10.2025, 19:33
Лучший ответ Сообщение было отмечено MVDmitrii как решение

Решение

А по поводу того, что прогрессбар не изменяется - весь контекс не видно, но я подозреваю, что progressChanged() работает не с тем прогрессбаром или не видит его вообще.
Попробуй заменить коннект на такой, как я выше в примере показывал:
C++ (Qt)
1
2
3
4
5
connect(reply, &QNetworkReply::uploadProgress, this, [progressBar](qint64 bytesSent, qint64 bytesTotal){
     if(progressBar->maximum() != bytesTotal)
               progressBar->setMaximum(bytesTotal);
     progressBar->setValue(bytesSent);
});
Но я хз откуда там reply, там должен быть экземпляр класса HttpFetcher, у которого добавлены и подключены сигналы как я показывал выше.

Добавлено через 1 минуту
Цитата Сообщение от MVDmitrii Посмотреть сообщение
я его сделал как глобальную переменную.
етить
Не делай так.

Добавлено через 12 минут
reply должен жить в HttpFetcher своей жизнью, и к нему не должно быть доступа извне класса HttpFetcher. А что бы видеть результаты запросов QNetworkReply, которые выполняются внутри класса HttpFetcher - и создаются свои, "кастомные" сигналы в классе HttpFetcher, и они, эти кастомные сигналы, подключаются к "заводским" сигналам QNetworkReply.
Как если бы на твоей плате есть мелкосхема QNetworkReply, и есть какое-то гнездо "выход", и вот ты подключаешь ножку мелкосхемы к разьиму гнезда (соединяешь свой сигнал класса HttpFetcher с сигналом QNetworkReply)
А если обьявляешь reply глобально - это все равно что какой-то проводок к лапе подпаял и он болтается снаружи коробки - попробуй угадай зачем он.
Фух, забайтил ты меня на мемуары, я курить и чилить
А твое вот это вот всё из-за того, что не научился на простых примерах и мучишься теперь.
0
2 / 2 / 0
Регистрация: 04.07.2021
Сообщений: 97
28.10.2025, 21:30  [ТС]
Цитата Сообщение от sdf45 Посмотреть сообщение
А твое вот это вот всё из-за того, что не научился на простых примерах и мучишься теперь.
да пересмотрел я этих простых примеров вагон и маленькую тележку, только они на столько банально простые что шаг в лево - шаг в право не один ни сделал. и чат гпт банальщину показывает.

Добавлено через 3 минуты
Цитата Сообщение от sdf45 Посмотреть сообщение
Не делай так.
вернул reply внутрь класса.

Добавлено через 9 минут
все я спать , ни чего не понимаю
0
28.10.2025, 22:52

Не по теме:


Цитата Сообщение от MVDmitrii Посмотреть сообщение
ни чего не понимаю
MVDmitrii, ну тут одно из трех- я хреново обьясняю (сорян тогда, идей больше нет), либо ты не готов понимать (нужна практика), либо и первое, и второе.

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.10.2025, 22:52
Помогаю со студенческими работами здесь

QT4\массив динамических виджетов\сигналы и слоты ...?
Здравствуйте! Вот опять не выходит... Прошу на маленьком примере помощи и разЪяснений... Есть...

Не работают слоты и сигналы при наследовании QGraphicsObject
Здравствуйте уважаемые форумчане. Есть класс который будет размещён в сцене: my_fishka.h...

Сигналы и слоты между ui и QGLwiget
Добрый день, не могу разобраться с сигналами с слотами. Как передать текст, который записанный в...

Сигналы и слоты в Qt многопоточны?
Тоесть если есть класс со слотами и из разных потоков к нему отправляются сигналы, собственно как...

Слоты и сигналы, работа с QLineEdit
Имеется следующий код: Файл dialog.h #ifndef DIALOG_H #define DIALOG_H #include &lt;QDialog&gt;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Музыка, написанная Искусственным Интеллектом
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\ А в самом низу файла-профиля. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru