Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. [SOLVED] QLabel won't update pixmap from inside function
Forum Updated to NodeBB v4.3 + New Features

[SOLVED] QLabel won't update pixmap from inside function

Scheduled Pinned Locked Moved General and Desktop
pixmapqt4qpixmap
36 Posts 3 Posters 27.9k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • SGaistS Offline
    SGaistS Offline
    SGaist
    Lifetime Qt Champion
    wrote on last edited by
    #20

    The fact that the button is inside another widget should not have any impact here. Can you reproduce your bug using may sample as base ?

    Interested in AI ? www.idiap.ch
    Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

    1 Reply Last reply
    0
    • T Offline
      T Offline
      Tymer
      wrote on last edited by
      #21

      I'll post the full code, just to be thorough. The error is exactly the same. When I debugged, it showed that my signal had reached the slot...But there was no change to the image.

      widget1.h

      #ifndef WIDGET1_H
      #define WIDGET1_H
      
      #include <QWidget>
      #include "/absolute/path/to/widget.h"
      
      namespace Ui {
      class widget1;
      }
      
      class widget1 : public QWidget
      {
          Q_OBJECT
      
          Widget* widget;
      
      public:
          explicit widget1(QWidget *parent = 0);
          ~widget1();
      
      signals:
          void clicked();
          void buttonPush();
      
      private slots:
          void on_pushButton_clicked();
      
      private:
          Ui::widget1 *ui;
      };
      
      #endif // WIDGET1_H
      
      

      widget1.cpp

      #include "widget1.h"
      #include "ui_widget1.h"
      
      widget1::widget1(QWidget *parent) :
          QWidget(parent),
          ui(new Ui::widget1)
      {
          ui->setupUi(this);
      
          widget = new Widget;
      
          connect(this, SIGNAL(buttonPush()),widget,SLOT(onClicked()));
      }
      
      widget1::~widget1()
      {
          delete ui;
      }
      
      void widget1::on_pushButton_clicked()
      {
          emit buttonPush();
      }
      
      

      An instance of widget1 was created in main, then shown. I created a ui file in designer, with all default values.

      1 Reply Last reply
      0
      • SGaistS Offline
        SGaistS Offline
        SGaist
        Lifetime Qt Champion
        wrote on last edited by
        #22

        Is it me or are you not showing widget at all ?

        Interested in AI ? www.idiap.ch
        Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

        1 Reply Last reply
        0
        • T Offline
          T Offline
          Tymer
          wrote on last edited by
          #23

          My main.cpp:

          #include "widget.h"
          #include "widget1.h"
          #include <QApplication>
          
          int main(int argc, char *argv[])
          {
              QApplication a(argc, argv);
          
              Widget w;
              widget1 w1;
              w1.show();
              w.show();
          
          
              return a.exec();
          }
          
          1 Reply Last reply
          0
          • SGaistS Offline
            SGaistS Offline
            SGaist
            Lifetime Qt Champion
            wrote on last edited by
            #24

            Ok, you are not showing the widget you have connected. Your Widget w in your main.cpp is not the same as the one you have instantiated in your widgte1 constructor.

            Interested in AI ? www.idiap.ch
            Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

            1 Reply Last reply
            1
            • T Offline
              T Offline
              Tymer
              wrote on last edited by
              #25

              So I should make my widget a singleton, more or less? How would I go about that?

              1 Reply Last reply
              0
              • SGaistS Offline
                SGaistS Offline
                SGaist
                Lifetime Qt Champion
                wrote on last edited by
                #26

                No, not at all. Either:

                1. Remove the widget from MainWindow and connect the one in main.cpp
                2. Remove the one from main.cpp and show the one from MainWindow

                Interested in AI ? www.idiap.ch
                Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                1 Reply Last reply
                0
                • T Offline
                  T Offline
                  Tymer
                  wrote on last edited by
                  #27

                  How would I connect to the instance in main?

                  1 Reply Last reply
                  0
                  • SGaistS Offline
                    SGaistS Offline
                    SGaist
                    Lifetime Qt Champion
                    wrote on last edited by
                    #28

                    By using the static version of QObject::connect

                    Interested in AI ? www.idiap.ch
                    Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                    1 Reply Last reply
                    0
                    • T Offline
                      T Offline
                      Tymer
                      wrote on last edited by
                      #29

                      I know this is really basic, but I'm having a bit of a brain fart. I want to make a pointer to the instance I create in main, but I don't want my class to know too much about what's going on in main. How do I do this so that I can create a connection to the object in main from a different widget?

                      1 Reply Last reply
                      0
                      • T Offline
                        T Offline
                        Tymer
                        wrote on last edited by
                        #30

                        Right now I have:

                        main.cpp

                        
                        myWidget* w = new myWidget;
                        actionTestWindow* t = new actionTestWindow(w, new QWidget);
                        

                        actionTestWindow.cpp

                        actionTestWindow::actionTestWindow(myWidget* Widget, QWidget *parent) :
                            QWidget(parent),
                            ui(new Ui::actionTestWindow)
                            {
                                ui->setupUi(this);
                        
                                Widget = new myWidget;
                        

                        The actionTestWindow is no longer showing, and I think it has something to do with how I insert the QWidget parameter.

                        1 Reply Last reply
                        0
                        • SGaistS Offline
                          SGaistS Offline
                          SGaist
                          Lifetime Qt Champion
                          wrote on last edited by
                          #31

                          Roll back to before you modified that constructor. Just call '''Widget->show();'''

                          Interested in AI ? www.idiap.ch
                          Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                          1 Reply Last reply
                          0
                          • T Offline
                            T Offline
                            Tymer
                            wrote on last edited by
                            #32

                            Alright, finally got this problem SOLVED!

                            I pass in an instance of myWidget as a parameter of actionTestWindow in main. It's important to note that you need to specify the QWidget as parent = 0 or it will not show. The relevant code looks something like this:

                            main.cpp

                            QWidget* parent = new QWidget;
                            parent = 0;
                            myWidget* w = new myWidget;
                            actionTestWindow* a = new actionTestWindow(w,parent);
                            
                            w->show();
                            a->show();
                            

                            actionTestWindow.h

                            class actionTestWindow : public QWidget {
                            myWidget* m;
                            
                            public:
                            actionTestWindow(myWidget* mW, QWidget* parent = 0);
                            

                            actionTestWindow.cpp

                            actionTestWindow::actionTestWindow(myWidget* mW, QWidget* parent)
                            {
                            this->m = mW;
                            /*use this->m to reference myWidget*/
                            }
                            

                            **note: irrelevant or standard code was mostly emitted.

                            1 Reply Last reply
                            0
                            • SGaistS Offline
                              SGaistS Offline
                              SGaist
                              Lifetime Qt Champion
                              wrote on last edited by
                              #33

                              And there you have a memory leak.

                              Why don't you just show the myWidget you had originally created in Widget ?

                              Interested in AI ? www.idiap.ch
                              Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                              T 1 Reply Last reply
                              0
                              • SGaistS SGaist

                                And there you have a memory leak.

                                Why don't you just show the myWidget you had originally created in Widget ?

                                T Offline
                                T Offline
                                Tymer
                                wrote on last edited by Tymer
                                #34

                                @SGaist It's a pretty complicated project. The actionTestWindow is pretty much just what it sounds like...A test window. The point is to make sure that I can successfully pass the signals I need and get the reactions I need for when I connect it to a more complicated process. myWidget needs to be shown from main as soon as the program starts running. Having it wait to show until the process that it displays info from runs would be a problem. The code will be passed around to many other people to be changed for future projects, and we're trying to avoid making them dig through code to find things as much as possible. It needs to be easy to just change a class slightly and change the instantiation slightly in order to make a change.

                                Can you point out the exact memory leak? I was under the impression that you can pass in instances of classes as parameters. It's a pretty common thing to do in Java, and I've at least heard of it being done in C++. There is a lot of code omitted. Destructors, importantly.

                                1 Reply Last reply
                                0
                                • SGaistS Offline
                                  SGaistS Offline
                                  SGaist
                                  Lifetime Qt Champion
                                  wrote on last edited by
                                  #35

                                  You have

                                  QWidget* parent = new QWidget;
                                  parent = 0; << the original parent is now lost and not destroyed
                                  myWidget* w = new myWidget;
                                  

                                  Since it needs to be the first widget, then create it in main. Connect your MainWindow to it also in main.

                                  You should rather avoid making that test widget known to any and every widget of your software. Doing so you'll avoid tight coupling and maintenance hell.

                                  Interested in AI ? www.idiap.ch
                                  Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                                  1 Reply Last reply
                                  0
                                  • T Offline
                                    T Offline
                                    Tymer
                                    wrote on last edited by
                                    #36

                                    Changed it to QWidget* parent = 0;. No more memory leak, everything works as expected.

                                    1 Reply Last reply
                                    0

                                    • Login

                                    • Login or register to search.
                                    • First post
                                      Last post
                                    0
                                    • Categories
                                    • Recent
                                    • Tags
                                    • Popular
                                    • Users
                                    • Groups
                                    • Search
                                    • Get Qt Extensions
                                    • Unsolved