М
Миша29 ноября 2017 г. 5:07

Сигнал от кнопки

Qt, сигналы, слоты

Здравствуйте.

Добавил кнопку  PushButton1 на интерфейс.
Нажал перейти к слоту->clicked()
Создал в хедере
private slots:
    void on_PushButton1_clicked();
В срр:
void MainWindow::on_PushButton1_clicked()
{
    makePlot();
}
Скажите пожалуйста как в конструкторе класса прописать connect(), чтобы при нажатии кнопки PushButton1 вызывался слот on_PushButton1_clicked() ?
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

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

12
Evgenii Legotckoi
  • 29 ноября 2017 г. 5:11

Здравствуйте!
Этот слот должен был создаться автоматически, если я вас правильно понял (то есть вы создали его через контекстное меню в графическом дизайнере)

А это значит, что вам не нужно делать в данном конкретном случае какой-либо коннект. Все эти коннекты будут созданы в автоматически генерируемом хедере.
    М
    • 29 ноября 2017 г. 5:15

    Но при нажатии на кнопку ничего не происходит. А мне нужно выполнить makePlot();

      Evgenii Legotckoi
      • 29 ноября 2017 г. 5:20
      • (ред.)

      А вот это уже странно. Должно было работать. Но по факту коннект должен выглядеть примерно так:

      connect(ui->PushButton1, &QPushButton::clicked, this, &MainWindow::on_PushButton1_clicked);
      Вместо MainWindow соответственно название вашего класса, в котором создана кнопка.

      На всякий случай, закиньте вывод qDebug() в этот слот, чтобы проверить, вызывается ли этот слот в принципе.
      void MainWindow::on_PushButton1_clicked()
      {
          qDebug() << "Этот слот был вызван";
          makePlot();
      }
      Если в консоли будет вывод этого qDebug(), то ищите ошибку в makePlot();
        М
        • 29 ноября 2017 г. 5:26

        Сделал. Но не работает, qDebug () ничего не выдает.

          Evgenii Legotckoi
          • 29 ноября 2017 г. 5:29

          Сделали коннект, как я написал?
          хм.. удалите билд и пересоберите проект. Такое ощущение, что у вас битый сгенерированный заголовочник или ещё что-то в этом духе.

          Либо Вы что-то недоговариваете.
          Задача слишком уже тривиальная, чтобы там можно было допустить ошибку.
            М
            • 29 ноября 2017 г. 5:37

            Все так. Но не работает. Сначала сделал 3 кнопки и продублировал Ваше решение для 3-х.

            Сейчас оставил только одну, затер 2 коннекта, остальное оставил.
            При выполнении программы выдало
            QMetaObject::connectSlotsByName: No matching signal for on_PushButton2_clicked()

            QMetaObject::connectSlotsByName: No matching signal for on_PushButton3_clicked()

            Следовательно сигнал все же идет от кнопки. Но видимо ошибка в его приеме.


              М
              • 29 ноября 2017 г. 5:39

              Может быть нужно что то в файл проект дописать?


                М
                • 29 ноября 2017 г. 5:59

                Хотя в другом проекте работает, странно, буду искать ошибку.

                  Evgenii Legotckoi
                  • 29 ноября 2017 г. 6:00

                  Ничего не нужно дописывать в pro-файл. Нужно удалить через дизайнер второй и третий слоты.
                  В данном случае недостаточно просто затереть в хедере слоты кнопок.

                    М
                    • 29 ноября 2017 г. 6:11

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

                    void MainWindow::MakeEquiti()
                    {
                        //qDebug()<<Equity1.size()<<NBar;
                        int NTikers=10;
                        long long FirstVisibleBar=0;//возвращает видимый левый край
                        long long LastVisibleBar=Equity1.size() -1; //возвращает видимый правый край
                        double YLow;  //видимый лой по оси у
                        double YHigh; //видимый хай по оси у
                        long long NGraph=0;   //номер графика при добавлении графиков и точек
                        QVector<double>bar(Equity1.size());
                        for (long long i=0; i<Equity1.size(); i++)
                        {
                    
                            bar[i]=i;
                        }
                        // --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
                    
                        //  тут описание виджета пошло
                        ui->customPlot->close();//закрывает виджет
                        ui->setupUi(this);  //открывает виджет
                    
                        ui->customPlot->legend->setVisible(true);
                    
                        // создание свечей // create candlestick chart:
                        QCPGraph *EquitiGraphic=new QCPGraph(ui->customPlot->xAxis, ui->customPlot->yAxis);
                        EquitiGraphic->setName("Equiti");
                        EquitiGraphic->setLineStyle(QCPGraph::lsImpulse);
                        EquitiGraphic->setData ( bar, Equity1 ); // Устанавливаем данные
                        QPen PenE;
                        PenE.setColor(QColor(Qt::green));//цвет QPen
                        EquitiGraphic->setPen(PenE);
                    
                    
                    
                        // тикеры оси х -----------------------------------------------------------------------------------------
                        QSharedPointer <QCPAxisTickerText> textTicker ( new  QCPAxisTickerText );
                        ui->customPlot-> xAxis-> setTicker (textTicker);
                        textTicker->clear();//удаляет тикеры
                        ui->customPlot->xAxis->setBasePen(Qt::NoPen);
                        // ui->customPlot->xAxis->setTickLabels(false); //Устанавливает, отображаются ли метки метки. Тик-метки - это числа, набранные рядом с отметками.
                        ui->customPlot->xAxis->setTicks(true); //только для вертикальную сетку в основной прямоугольник по оси, чтобы скрыть основу абсцисс, засечки и надписи  // only want vertical grid in main axis rect, so hide xAxis backbone, ticks, and labels
                        //ui->customPlot->xAxis->setRange(FirstVisibleBar,LastVisibleBar); //задается отражаемая часть графика
                        if (NTikers>Equity1.size()){NTikers=Equity1.size();}
                        int StepTickers=(LastVisibleBar - FirstVisibleBar)/NTikers;//шаг тикероа
                        for  (int i=0; i<=NTikers; i++) //задает тики
                        {
                            if (FirstVisibleBar +i*StepTickers<Equity1.size()){   textTicker->addTick(FirstVisibleBar +i*StepTickers, TimeEquiti1[FirstVisibleBar +i*StepTickers].toString("HH:mm")+'\n'+DateEquiti1[FirstVisibleBar +i*StepTickers].toString("dd.MM.yyyy"));}
                        }
                        //сделать ось выпрямляет левую сторону линии вверх: // make axis rects' left side line up:
                        QCPMarginGroup *group = new QCPMarginGroup(ui->customPlot);
                        ui->customPlot->axisRect()->setMarginGroup(QCP::msLeft|QCP::msRight, group);
                        // //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
                        // ниже мой код относительно графика
                        ui->customPlot->setInteraction(QCP::iRangeZoom,true);   // Включаем взаимодействие удаления/приближения
                        ui->customPlot->setInteraction(QCP::iRangeDrag, true);  // Включаем взаимодействие перетаскивания графика
                        ui->customPlot->axisRect()->setRangeDrag(Qt::Horizontal);   // Включаем перетаскивание только по горизонтальной оси
                        ui->customPlot->axisRect()->setRangeZoom(Qt::Horizontal);   // Включаем удаление/приближение только по горизонтальной оси
                        ui->customPlot->xAxis->setTickLabels(true);  //Устанавливает, отображаются ли метки метки. Тик-метки - это числа, набранные рядом с отметками.
                        ui->customPlot->legend->setVisible(true);   //Включаем Легенду графика
                        // Устанавливаем Легенду в левый верхний угол графика
                        ui->customPlot->axisRect()->insetLayout()->setInsetAlignment(0, Qt::AlignLeft|Qt::AlignTop);
                    
                    
                        // -------------------------------------------------------------------------------------------------------------------------------------------------------------------
                        // Добавление линии
                        if (BuyAndHold1.size()>0)
                        {
                            NGraph=NGraph+1;
                            ui->customPlot->addGraph(ui->customPlot->xAxis, ui->customPlot->yAxis);  //Создает новый график внутри сюжета
                            ui->customPlot->graph(NGraph)->setName("BuyAndHold");
                            QPen Pen1;
                            Pen1.setColor(QColor(Qt::blue));
                            Pen1.setWidthF(1);//ширина линии
                            ui->customPlot->graph(NGraph)->setPen(Pen1);
                           // ui->customPlot->graph(NGraph)->setPen(QPen(Qt::red)); // Возвращает граф с индексом . Если индекс недействителен, он возвращает 0. -> line color blue for first graph
                            ui->customPlot->graph(NGraph)->setData(bar, BuyAndHold1);//сообщает данные графику
                        // Определяю Макс и мин видимый
                            for (long long i=FirstVisibleBar; i<LastVisibleBar; i++)
                            {
                                if (BuyAndHold1[i]<YLow )   {YLow=BuyAndHold1[i];}
                                if (BuyAndHold1[i]>YHigh )  {YHigh=BuyAndHold1[i];}
                            }
                        }
                    
                        if (BuyEquiti1.size()>0)
                        {
                            NGraph=NGraph+1;
                            ui->customPlot->addGraph(ui->customPlot->xAxis, ui->customPlot->yAxis);  //Создает новый график внутри сюжета
                            ui->customPlot->graph(NGraph)->setName("BuyEquiti");
                            QPen Pen1;
                            Pen1.setColor(QColor(Qt::red));
                            Pen1.setWidthF(1);//ширина линии
                            ui->customPlot->graph(NGraph)->setPen(Pen1);
                           // ui->customPlot->graph(NGraph)->setPen(QPen(Qt::red)); // Возвращает граф с индексом . Если индекс недействителен, он возвращает 0. -> line color blue for first graph
                            ui->customPlot->graph(NGraph)->setData(bar, BuyEquiti1);//сообщает данные графику
                        // Определяю Макс и мин видимый
                            for (long long i=FirstVisibleBar; i<LastVisibleBar; i++)
                            {
                                if (BuyEquiti1[i]<YLow )   {YLow=BuyEquiti1[i];}
                                if (BuyEquiti1[i]>YHigh )  {YHigh=BuyEquiti1[i];}
                            }
                        }
                        if (ShortEquiti1.size()>0)
                        {
                            NGraph=NGraph+1;
                            ui->customPlot->addGraph(ui->customPlot->xAxis, ui->customPlot->yAxis);  //Создает новый график внутри сюжета
                            ui->customPlot->graph(NGraph)->setName("ShortEquiti");
                            QPen Pen1;
                            Pen1.setColor(QColor(Qt::magenta));
                            Pen1.setWidthF(1);//ширина линии
                            ui->customPlot->graph(NGraph)->setPen(Pen1);
                           // ui->customPlot->graph(NGraph)->setPen(QPen(Qt::red)); // Возвращает граф с индексом . Если индекс недействителен, он возвращает 0. -> line color blue for first graph
                            ui->customPlot->graph(NGraph)->setData(bar, ShortEquiti1);//сообщает данные графику
                        // Определяю Макс и мин видимый
                            for (long long i=FirstVisibleBar; i<LastVisibleBar; i++)
                            {
                                if (ShortEquiti1[i]<YLow )   {YLow=ShortEquiti1[i];}
                                if (ShortEquiti1[i]>YHigh )  {YHigh=ShortEquiti1[i];}
                            }
                        }
                    
                        ui->customPlot->rescaleAxes();
                    
                        // -------------------------------------------------------------------------------------------------------------------------------------------------------------------
                        // -------------------------------------------------------------------------------------------------------------------------------------------------------------------------
                        //авто масштабирует по оси Y
                    
                        FirstVisibleBar=ui->customPlot->xAxis->range().lower/1 ; //возвращает видимый левый край
                        LastVisibleBar=ui->customPlot->xAxis->range().upper/1 ; //возвращает видимый правый край
                        //ui->customPlot->yAxis->setRange(YLow-(ui->customPlot->yAxis->range().size()*0.05),YHigh+(ui->customPlot->yAxis->range().size()*0.05)); //задает размеры окна по оси У
                        ui->customPlot->QCustomPlot::axisRects ();
                    
                        QObject::connect(ui->customPlot->xAxis,static_cast<void(QCPAxis::*)(const QCPRange&)> (&QCPAxis::rangeChanged), [=]()  //сигнал изменения видимого диапазона
                        {
                            //ось yAxis, для основного графика
                            long long  FirstVisibleBar=ui->customPlot->xAxis->range().lower/1 ; //возвращает видимый левый край
                            long long  LastVisibleBar=ui->customPlot->xAxis->range().upper/1 ; //возвращает видимый правый край
                            if (LastVisibleBar>=Equity1.size()) {ui->customPlot->xAxis->setRangeUpper(Equity1.size());}  //граница графика справа
                            if (FirstVisibleBar<=0) {ui->customPlot->xAxis->setRangeLower(-1);}  //граница графика слева
                            if (FirstVisibleBar>=Equity1.size()) {FirstVisibleBar=(Equity1.size()-1);}  //если превышен диамазон массивов
                            if (FirstVisibleBar<0) {FirstVisibleBar=0;}         //если превышен диамазон массивов
                            if (LastVisibleBar>Equity1.size()) {LastVisibleBar=Equity1.size();}         //если превышен диамазон массивов
                            if (LastVisibleBar<=0) {LastVisibleBar=1;}          //если превышен диамазон массивов
                            double YLow=Equity1[FirstVisibleBar];       //локальный минимум
                            double YHigh=Equity1[FirstVisibleBar];     //локальный максимум
                            for (long long i=FirstVisibleBar; i<LastVisibleBar; i++)
                            {
                                if (Equity1[i]<YLow)   {YLow=Equity1[i];}
                                if (Equity1[i]>YHigh) { YHigh=Equity1[i];}
                                if (BuyAndHold1.size()>0)
                                {
                                    if (BuyAndHold1[i]<YLow&&BuyAndHold1[i]!=0)   {YLow=BuyAndHold1[i];}
                                    if (BuyAndHold1[i]>YHigh)  {YHigh=BuyAndHold1[i];}
                                }
                                if (BuyEquiti1.size()>0)
                                {
                                    if (BuyEquiti1[i]<YLow&&BuyEquiti1[i]!=0)   {YLow=BuyEquiti1[i];}
                                    if (BuyEquiti1[i]>YHigh)  {YHigh=BuyEquiti1[i];}
                                }
                                if (ShortEquiti1.size()>0)
                                {
                                    if (ShortEquiti1[i]<YLow&&ShortEquiti1[i]!=0)   {YLow=ShortEquiti1[i];}
                                    if (ShortEquiti1[i]>YHigh)  {YHigh=ShortEquiti1[i];}
                                }
                            }
                            ui->customPlot->yAxis->setRange(YLow-((YHigh-YLow)*0.05),YHigh+((YHigh-YLow)*0.05)); //задает размеры окна по оси У
                            //тикеры
                            textTicker->clear();//удаляет тикеры
                            //if (NTikers>Equity1.size()){NTikers=Equity1.size();}
                            int StepTickers=(LastVisibleBar - FirstVisibleBar)/NTikers;//шаг тикероа
                            for  (int i=0; i<=NTikers; i++) //задает тики
                            {
                                if (FirstVisibleBar +i*StepTickers<Equity1.size()){ textTicker->addTick(FirstVisibleBar +i*StepTickers, TimeEquiti1[FirstVisibleBar +i*StepTickers].toString("HH:mm")+'\n'+DateEquiti1[FirstVisibleBar +i*StepTickers].toString("dd.MM.yyyy"));}
                            }
                    
                        });
                    
                    }

                     

                      Evgenii Legotckoi
                      • 29 ноября 2017 г. 6:28
                      • (ред.)

                      А я вам уже говорил, что Вы делаете грубые костыли, которые даже зелёные новички не пишут.
                      Скорее всего причина в этих строчках.

                      //  тут описание виджета пошло
                      ui->customPlot->close();//закрывает виджет
                      ui->setupUi(this);  //открывает виджет
                      Вы в курсе что делает метод setupUi() ? Он создаёт новые объекты, создаёт новый интерфейс, но не удаляет старые объекты!!!!!
                      Появляются утечки памяти. Неправильное поведение сигналов и слотов, многократное перекопирование интерфейса... Но вы меня не послушали... Теперь разгребаете новые проблемы.
                      Исправьте эту проблему и скорее всего ваша текущая проблема разрешится сама собой. Без созданного графика же всё работает. А как только таким грубым костылём перерисовываете весь интерфейс, то у вас уже кнопки не знают куда цепляться, к каким слотам.
                        М
                        • 29 ноября 2017 г. 7:35

                        Спасибо. Затер эти строчки и кнопка заработал.

                          Комментарии

                          Только авторизованные пользователи могут публиковать комментарии.
                          Пожалуйста, авторизуйтесь или зарегистрируйтесь
                          г
                          • ги
                          • 24 апреля 2024 г. 1:51

                          C++ - Тест 005. Структуры и Классы

                          • Результат:41баллов,
                          • Очки рейтинга-8
                          l
                          • laei
                          • 23 апреля 2024 г. 19:19

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

                          • Результат:10баллов,
                          • Очки рейтинга-10
                          l
                          • laei
                          • 23 апреля 2024 г. 19:17

                          C++ - Тест 003. Условия и циклы

                          • Результат:50баллов,
                          • Очки рейтинга-4
                          Последние комментарии
                          k
                          kmssr9 февраля 2024 г. 5:43
                          Qt Linux - Урок 001. Автозапуск Qt приложения под Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                          АК
                          Анатолий Кононенко5 февраля 2024 г. 12:50
                          Qt WinAPI - Урок 007. Работаем с ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                          EVA
                          EVA25 декабря 2023 г. 21:30
                          Boost - статическая линковка в CMake проекте под Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                          J
                          JonnyJo25 декабря 2023 г. 19:38
                          Boost - статическая линковка в CMake проекте под Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
                          G
                          Gvozdik19 декабря 2023 г. 8:01
                          Qt/C++ - Урок 056. Подключение библиотеки Boost в Qt для компиляторов MinGW и MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
                          Сейчас обсуждают на форуме
                          G
                          Gar22 апреля 2024 г. 15:46
                          Clipboard Как скопировать окно целиком в clipb?
                          DA
                          Dr Gangil Academics20 апреля 2024 г. 17:45
                          Unlock Your Aesthetic Potential: Explore MSC in Facial Aesthetics and Cosmetology in India Embark on a transformative journey with an msc in facial aesthetics and cosmetology in india . Delve into the intricate world of beauty and rejuvenation, guided by expert faculty and …
                          a
                          a_vlasov14 апреля 2024 г. 16:41
                          Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
                          Павел Дорофеев
                          Павел Дорофеев14 апреля 2024 г. 12:35
                          QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
                          f
                          fastrex4 апреля 2024 г. 14:47
                          Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…

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