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. Layout, widgets not inside ???

Layout, widgets not inside ???

Scheduled Pinned Locked Moved Unsolved General and Desktop
87 Posts 9 Posters 9.7k Views
  • 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.
  • SPlattenS SPlatten

    @JonB , I can get it to work easy enough in Qt Creator, but for some reason unknown to me, trying to replicate the same in code doesn't do the same.

    1. I create a QGroupBox
    2. I add two instances of QRadioButton to the QGroupBox by setting the QGroupBox as the parent of the QRadioButton's.
    3. There is no option to select a layout in code so I set the layout using setLayout passing an instance of QVBoxLayout.

    Doing this just ends up with the exact same results, the QGroupBox appears above the radio buttons and the Radio buttons are not inside the QGroupBox. I change the layout to QHBoxLayout no difference in appearance, the radio buttons still appear above each other and outside the QGroupBox.

    JonBJ Offline
    JonBJ Offline
    JonB
    wrote on last edited by JonB
    #74

    @SPlatten said in Layout, widgets not inside ???:

    I create a QGroupBox
    I add two instances of QRadioButton to the QGroupBox by setting the QGroupBox as the parent of the QRadioButton's.
    There is no option to select a layout in code so I set the layout using setLayout passing an instance of QVBoxLayout.

    I referred you to copy from https://doc.qt.io/qt-5/qgroupbox.html#details, all you have to do is copy the code example there. Obviously you have to add buttons onto the layout with QVBoxLayout::addWidget();, else you're not putting them on a layout. Yet you do not mention that in your steps.....??

    SPlattenS 1 Reply Last reply
    0
    • JonBJ JonB

      @SPlatten said in Layout, widgets not inside ???:

      I create a QGroupBox
      I add two instances of QRadioButton to the QGroupBox by setting the QGroupBox as the parent of the QRadioButton's.
      There is no option to select a layout in code so I set the layout using setLayout passing an instance of QVBoxLayout.

      I referred you to copy from https://doc.qt.io/qt-5/qgroupbox.html#details, all you have to do is copy the code example there. Obviously you have to add buttons onto the layout with QVBoxLayout::addWidget();, else you're not putting them on a layout. Yet you do not mention that in your steps.....??

      SPlattenS Offline
      SPlattenS Offline
      SPlatten
      wrote on last edited by
      #75

      @JonB , I have tried adding the widgets to the layout and also tried using the layout as the parent for the widgets, neither have worked.

      Kind Regards,
      Sy

      JonBJ 1 Reply Last reply
      0
      • SPlattenS SPlatten

        @JonB , I have tried adding the widgets to the layout and also tried using the layout as the parent for the widgets, neither have worked.

        JonBJ Offline
        JonBJ Offline
        JonB
        wrote on last edited by
        #76

        @SPlatten
        So, if you just copy the example on the doc page, nothing else, into a standalone program, could you screenshot the result so that we can understand what is wrong?

        SPlattenS 1 Reply Last reply
        0
        • JonBJ JonB

          @SPlatten
          So, if you just copy the example on the doc page, nothing else, into a standalone program, could you screenshot the result so that we can understand what is wrong?

          SPlattenS Offline
          SPlattenS Offline
          SPlatten
          wrote on last edited by
          #77

          @JonB , just to be clear, is this what you are asking me to try out?

              QGroupBox *groupBox = new QGroupBox(tr("Exclusive Radio Buttons"));
          
              QRadioButton *radio1 = new QRadioButton(tr("&Radio button 1"));
              QRadioButton *radio2 = new QRadioButton(tr("R&adio button 2"));
              QRadioButton *radio3 = new QRadioButton(tr("Ra&dio button 3"));
          
              radio1->setChecked(true);
          
              QVBoxLayout *vbox = new QVBoxLayout;
              vbox->addWidget(radio1);
              vbox->addWidget(radio2);
              vbox->addWidget(radio3);
              vbox->addStretch(1);
              groupBox->setLayout(vbox);
          

          Kind Regards,
          Sy

          JonBJ 1 Reply Last reply
          0
          • SPlattenS SPlatten

            @JonB , just to be clear, is this what you are asking me to try out?

                QGroupBox *groupBox = new QGroupBox(tr("Exclusive Radio Buttons"));
            
                QRadioButton *radio1 = new QRadioButton(tr("&Radio button 1"));
                QRadioButton *radio2 = new QRadioButton(tr("R&adio button 2"));
                QRadioButton *radio3 = new QRadioButton(tr("Ra&dio button 3"));
            
                radio1->setChecked(true);
            
                QVBoxLayout *vbox = new QVBoxLayout;
                vbox->addWidget(radio1);
                vbox->addWidget(radio2);
                vbox->addWidget(radio3);
                vbox->addStretch(1);
                groupBox->setLayout(vbox);
            
            JonBJ Offline
            JonBJ Offline
            JonB
            wrote on last edited by
            #78

            @SPlatten Yep!

            SPlattenS 1 Reply Last reply
            0
            • JonBJ JonB

              @SPlatten Yep!

              SPlattenS Offline
              SPlattenS Offline
              SPlatten
              wrote on last edited by
              #79

              @JonB , will do.

              Kind Regards,
              Sy

              JonBJ 1 Reply Last reply
              0
              • SPlattenS SPlatten

                @JonB , will do.

                JonBJ Offline
                JonBJ Offline
                JonB
                wrote on last edited by JonB
                #80

                @SPlatten
                :)

                And I see there is a bigger example at https://doc.qt.io/qt-5/qtwidgets-widgets-groupbox-example.html, but just the standalone one should do.

                On a separate note, and not wanting to distract you from the task at hand. You seem to have said that you can get what you want from Designer? But not from your own code. And you're not sure what Designer way has done it? But when you build you run uic on the .ui file and (IIRC) it generates ui_yourfile.h. In that is setupUi(). And that is all the code implementing whatever you have designed, there isn't anything else to it. So that code must show you how they produce what you say works?

                SPlattenS 1 Reply Last reply
                0
                • JonBJ JonB

                  @SPlatten
                  :)

                  And I see there is a bigger example at https://doc.qt.io/qt-5/qtwidgets-widgets-groupbox-example.html, but just the standalone one should do.

                  On a separate note, and not wanting to distract you from the task at hand. You seem to have said that you can get what you want from Designer? But not from your own code. And you're not sure what Designer way has done it? But when you build you run uic on the .ui file and (IIRC) it generates ui_yourfile.h. In that is setupUi(). And that is all the code implementing whatever you have designed, there isn't anything else to it. So that code must show you how they produce what you say works?

                  SPlattenS Offline
                  SPlattenS Offline
                  SPlatten
                  wrote on last edited by
                  #81

                  @JonB , I've used Qt Creator to create a mock layout, adding a Group Box, 3 x Radio Buttons then selected Lay Out Vertically from the Lay Out context submenu. Closed UI, clicked on Run qmake then opened up ui_clsMainWnd.h and searched for groupBox, this I the code:

                  groupBox = new QGroupBox(centralWidget);
                  groupBox->setObjectName(QString::fromUtf8("groupBox"));
                  groupBox->setGeometry(QRect(340, 210, 127, 101));
                  verticalLayout = new QVBoxLayout(groupBox);
                  verticalLayout->setSpacing(6);
                  verticalLayout->setContentsMargins(11, 11, 11, 11);
                  verticalLayout->setObjectName(QString::fromUtf8("verticalLayout"));
                  radioButton = new QRadioButton(groupBox);
                  radioButton->setObjectName(QString::fromUtf8("radioButton"));
                  
                  verticalLayout->addWidget(radioButton);
                  
                  radioButton_2 = new QRadioButton(groupBox);
                  radioButton_2->setObjectName(QString::fromUtf8("radioButton_2"));
                  
                  verticalLayout->addWidget(radioButton_2);
                  
                  radioButton_3 = new QRadioButton(groupBox);
                  radioButton_3->setObjectName(QString::fromUtf8("radioButton_3"));
                  
                  verticalLayout->addWidget(radioButton_3);
                  

                  This all looks good, I assume that 6 used or spacing is just a default along with the margins 11. I may have to experiment with the geometry 340, 210, 127, 101.

                  Kind Regards,
                  Sy

                  JonBJ 1 Reply Last reply
                  0
                  • SPlattenS SPlatten

                    @JonB , I've used Qt Creator to create a mock layout, adding a Group Box, 3 x Radio Buttons then selected Lay Out Vertically from the Lay Out context submenu. Closed UI, clicked on Run qmake then opened up ui_clsMainWnd.h and searched for groupBox, this I the code:

                    groupBox = new QGroupBox(centralWidget);
                    groupBox->setObjectName(QString::fromUtf8("groupBox"));
                    groupBox->setGeometry(QRect(340, 210, 127, 101));
                    verticalLayout = new QVBoxLayout(groupBox);
                    verticalLayout->setSpacing(6);
                    verticalLayout->setContentsMargins(11, 11, 11, 11);
                    verticalLayout->setObjectName(QString::fromUtf8("verticalLayout"));
                    radioButton = new QRadioButton(groupBox);
                    radioButton->setObjectName(QString::fromUtf8("radioButton"));
                    
                    verticalLayout->addWidget(radioButton);
                    
                    radioButton_2 = new QRadioButton(groupBox);
                    radioButton_2->setObjectName(QString::fromUtf8("radioButton_2"));
                    
                    verticalLayout->addWidget(radioButton_2);
                    
                    radioButton_3 = new QRadioButton(groupBox);
                    radioButton_3->setObjectName(QString::fromUtf8("radioButton_3"));
                    
                    verticalLayout->addWidget(radioButton_3);
                    

                    This all looks good, I assume that 6 used or spacing is just a default along with the margins 11. I may have to experiment with the geometry 340, 210, 127, 101.

                    JonBJ Offline
                    JonBJ Offline
                    JonB
                    wrote on last edited by
                    #82

                    @SPlatten
                    Not sure what the question is here. Does "This all looks good" mean that when run it does indeed draw the radiobuttons correctly within their layout, as you have been trying to do in code but unsuccessfully?

                    You can see the code is exactly what I said and in the code example in the docs for QGroupBox. Create a QGroupBox, put a QVBoxLayout on it, add QRadioButtons onto the layout. That is all you should ever do.

                    The setGeometry() just corresponds to the position & size of the groupbox you have on your design canvas. I would not have thought you would need to do that, the QGroupBox should resize to correctly enclose its content. The spacing and margins are just defaults used by Designer, you can alter them.

                    You can play with this code in the ui_clsMainWnd.h file by editing, it will not get overwritten unless you alter the .ui file. And/or you can copy it to your own code and play with it there.

                    Whatever the difference from your own code which has not been working, you should be in a good position to discover that from here.

                    SPlattenS 1 Reply Last reply
                    0
                    • JonBJ JonB

                      @SPlatten
                      Not sure what the question is here. Does "This all looks good" mean that when run it does indeed draw the radiobuttons correctly within their layout, as you have been trying to do in code but unsuccessfully?

                      You can see the code is exactly what I said and in the code example in the docs for QGroupBox. Create a QGroupBox, put a QVBoxLayout on it, add QRadioButtons onto the layout. That is all you should ever do.

                      The setGeometry() just corresponds to the position & size of the groupbox you have on your design canvas. I would not have thought you would need to do that, the QGroupBox should resize to correctly enclose its content. The spacing and margins are just defaults used by Designer, you can alter them.

                      You can play with this code in the ui_clsMainWnd.h file by editing, it will not get overwritten unless you alter the .ui file. And/or you can copy it to your own code and play with it there.

                      Whatever the difference from your own code which has not been working, you should be in a good position to discover that from here.

                      SPlattenS Offline
                      SPlattenS Offline
                      SPlatten
                      wrote on last edited by
                      #83

                      @JonB , sorry, yes, what I should have said, is that everything in my last post renders the correct solution and looks good, which I am now trying to replicate in my code, given that the XML is dynamic.

                      Kind Regards,
                      Sy

                      JonBJ 1 Reply Last reply
                      0
                      • SPlattenS SPlatten

                        @JonB , sorry, yes, what I should have said, is that everything in my last post renders the correct solution and looks good, which I am now trying to replicate in my code, given that the XML is dynamic.

                        JonBJ Offline
                        JonBJ Offline
                        JonB
                        wrote on last edited by
                        #84

                        @SPlatten
                        Indeed, you must just make sure that what you come up from your parsing-creating-dynamically matches the static pattern you know works.

                        Everything has always felt like the radiobuttons are being added onto the QGroupBox directly where they need to be added onto the QVBoxLayout (and of course that must be set as the group box's layout).

                        SPlattenS 1 Reply Last reply
                        0
                        • JonBJ JonB

                          @SPlatten
                          Indeed, you must just make sure that what you come up from your parsing-creating-dynamically matches the static pattern you know works.

                          Everything has always felt like the radiobuttons are being added onto the QGroupBox directly where they need to be added onto the QVBoxLayout (and of course that must be set as the group box's layout).

                          SPlattenS Offline
                          SPlattenS Offline
                          SPlatten
                          wrote on last edited by SPlatten
                          #85

                          @JonB , been out all day, just got back to trying out the stand along demo and no problems, it works:

                          #include "mainwindow.h"
                          
                          #include <QApplication>
                          #include <QGroupBox>
                          #include <QRadioButton>
                          #include <QVBoxLayout>
                          
                          int main(int argc, char *argv[])
                          {
                              QApplication a(argc, argv);
                              MainWindow w;
                          
                              QGroupBox* groupBox = new QGroupBox(w.centralWidget());
                              groupBox->setTitle("Demo");
                              groupBox->setObjectName(QString::fromUtf8("groupBox"));
                              groupBox->setGeometry(QRect(20, 110, 127, 101));
                              QVBoxLayout* verticalLayout = new QVBoxLayout(groupBox);
                              verticalLayout->setSpacing(6);
                              verticalLayout->setContentsMargins(11, 11, 11, 11);
                              verticalLayout->setObjectName(QString::fromUtf8("verticalLayout"));
                              QRadioButton* radioButton = new QRadioButton(groupBox);
                              radioButton->setObjectName(QString::fromUtf8("radioButton"));
                              radioButton->setText("Radio 1");
                              verticalLayout->addWidget(radioButton);
                          
                              QRadioButton* radioButton_2 = new QRadioButton(groupBox);
                              radioButton_2->setObjectName(QString::fromUtf8("radioButton_2"));
                              radioButton_2->setText("Radio 2");
                              verticalLayout->addWidget(radioButton_2);
                          
                              QRadioButton* radioButton_3 = new QRadioButton(groupBox);
                              radioButton_3->setObjectName(QString::fromUtf8("radioButton_3"));
                              radioButton_3->setText("Radio 3");
                              verticalLayout->addWidget(radioButton_3);
                          
                              w.show();
                              return a.exec();
                          }
                          

                          Screenshot 2021-10-24 at 16.32.43.png

                          Which means I need to did around in my engine and find out why the same doesn't work when I repeat in my engine.

                          Debugger, watch window:
                          Screenshot 2021-10-24 at 16.36.13.png

                          Kind Regards,
                          Sy

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

                            As suggested before, you should simplify your code and approach the interface building in a simpler manner.

                            For your xml, you should pass it through a validator to ensure that what you parse is what your application expects. With that you can remove quite a lot of manual verifications.

                            Split your widget generation in smaller functions. It's harder to reason in one mega function that does everything.

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

                            SPlattenS 1 Reply Last reply
                            1
                            • SGaistS SGaist

                              As suggested before, you should simplify your code and approach the interface building in a simpler manner.

                              For your xml, you should pass it through a validator to ensure that what you parse is what your application expects. With that you can remove quite a lot of manual verifications.

                              Split your widget generation in smaller functions. It's harder to reason in one mega function that does everything.

                              SPlattenS Offline
                              SPlattenS Offline
                              SPlatten
                              wrote on last edited by
                              #87

                              @SGaist , the engine is quite simple, I just need to identify what is different, I will start by comparing the tree structure.

                              Kind Regards,
                              Sy

                              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