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. Hand code GUI completely
Forum Updated to NodeBB v4.3 + New Features

Hand code GUI completely

Scheduled Pinned Locked Moved General and Desktop
29 Posts 9 Posters 18.4k Views 1 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.
  • G Offline
    G Offline
    GroundZero
    wrote on last edited by
    #19

    [quote author="Gerolf" date="1327498560"]
    [quote author="Volker" date="1327494502"]Looking at my forms, with tons of widgets, I would drive nuts if I had to hand code them all in C++ :)[/quote]

    Spit it up to sub forms? :-)
    I know there are cases, where it really makes sense, but I try to avoid forms with hundreds of widgets.[/quote]

    True, but you can Copy & Paste a lot to though ;)
    And I also use the clicking on the numbers on the left side to "fold" code. This way my screen stays pritty clean, and when I need something I can just "unfold" it, edit it or look at it, and fold it back up lol :)

    Anyways, I posted my code and question on page 2 (top). I am doing something wrong with the Group option :(

    1 Reply Last reply
    0
    • G Offline
      G Offline
      giesbert
      wrote on last edited by
      #20

      Hi,

      I could boiler plate you, and give you a working version :-)
      But it would be complete.

      First your bugs:

      a group box is a widget --> addWidget not addlayout

      pibLayout is the layout of the group box, add it there, not on the main window

      Full source for the sollution, only read it if you don't want to learn by building it on your own :-)

      @
      #include <QApplication>
      #include <QWidget>
      #include <QGroupBox>
      #include <QGridLayout>
      #include <QHBoxLayout>
      #include <QVBoxLayout>
      #include <QLabel>
      #include <QLineEdit>
      #include <QSlider>
      #include <QSpinBox>
      #include <QSpacerItem>
      #include <QPushButton>

      int main(int argc, char *argv[])
      {
      QApplication app(argc, argv);

      // create a main widget
      QWidget *mainAppWindow = new QWidget;
      mainAppWindow->setWindowTitle("Custom made GUI - Test 0.1");
      mainAppWindow->setFixedSize(500, 600);
      
      // main vertical layout
      QVBoxLayout* pMainLayout = new QVBoxLayout(mainAppWindow);
      mainAppWindow->setLayout(pMainLayout);
      
      // ------------------------------------------------------
      // first sub layouts
      QHBoxLayout* pTopHBox  = new QHBoxLayout;
      pMainLayout->addLayout(pTopHBox);
      
      QGridLayout* pLabelGrid  = new QGridLayout;
      pMainLayout->addLayout(pLabelGrid);
      
      pMainLayout->addItem(new QSpacerItem(0,0,QSizePolicy::Minimum, QSizePolicy::Expanding));
      
      QHBoxLayout* pBtnHBox  = new QHBoxLayout;
      pMainLayout->addLayout(pBtnHBox);
      
      // ------------------------------------------------------
      // create the group box
      QGroupBox *personalInfoBox = new QGroupBox(mainAppWindow);
      personalInfoBox->setTitle("Personal Info");
      
      QLabel *nameLabel = new QLabel(QObject::tr("name"), personalInfoBox);
      QLineEdit *nameText = new QLineEdit(personalInfoBox);
      QLabel *surnameLabel = new QLabel(QObject::tr("surname"), personalInfoBox);
      QLineEdit *surnameText = new QLineEdit(personalInfoBox);
      QLabel *ageLabel = new QLabel(QObject::tr("age"), personalInfoBox);
      QLineEdit *ageText = new QLineEdit(personalInfoBox);
      QLabel *genderLabel = new QLabel(QObject::tr("gender"), personalInfoBox);
      QLineEdit *genderText = new QLineEdit(personalInfoBox);
      
      // create the layout for the personalInfoBox
      QGridLayout *pibLayout = new QGridLayout;
      pibLayout->addWidget(nameLabel, 0, 0);
      pibLayout->addWidget(nameText, 0, 1);
      pibLayout->addWidget(surnameLabel, 1, 0);
      pibLayout->addWidget(surnameText, 1, 1);
      pibLayout->addWidget(ageLabel, 2, 0);
      pibLayout->addWidget(ageText, 2, 1);
      pibLayout->addWidget(genderLabel, 3, 0);
      pibLayout->addWidget(genderText, 3, 1);
      personalInfoBox->setLayout(pibLayout);
      pTopHBox->addWidget(personalInfoBox);
      
      // ------------------------------------------------------
      // create the slider area
      QVBoxLayout* pSlidersLayout = new QVBoxLayout;
      pTopHBox->addLayout(pSlidersLayout);
      QSlider *aAmount = new QSlider(Qt::Horizontal, mainAppWindow);
      aAmount->setRange(0, 100);
      aAmount->setValue(25);
      QSlider *bAmount = new QSlider(Qt::Horizontal, mainAppWindow);
      bAmount->setRange(0, 100);
      bAmount->setValue(25);
      QSlider *cAmount = new QSlider(Qt::Horizontal, mainAppWindow);
      cAmount->setRange(0, 100);
      cAmount->setValue(25);
      
      pSlidersLayout->addWidget(new QLabel(QObject::tr("a - amount"), mainAppWindow));
      pSlidersLayout->addWidget(aAmount);
      pSlidersLayout->addWidget(new QLabel(QObject::tr("b - amount"), mainAppWindow));
      pSlidersLayout->addWidget(bAmount);
      pSlidersLayout->addWidget(new QLabel(QObject::tr("c - amount"), mainAppWindow));
      pSlidersLayout->addWidget(cAmount);
      
      // ------------------------------------------------------
      // create the info area
      pLabelGrid->addWidget(new QLabel(QObject::tr("a - statistic display"), mainAppWindow), 0, 0);
      pLabelGrid->addWidget(new QLabel(QObject::tr("a - runtime statistic display"), mainAppWindow), 0, 1);
      pLabelGrid->addItem(new QSpacerItem(0,0, QSizePolicy::Expanding,QSizePolicy::Minimum), 0, 2);
      pLabelGrid->addWidget(new QLabel(QObject::tr("b - statistic display"), mainAppWindow), 1, 0);
      pLabelGrid->addWidget(new QLabel(QObject::tr("b - runtime statistic display"), mainAppWindow), 1, 1);
      pLabelGrid->addWidget(new QLabel(QObject::tr("c - statistic display"), mainAppWindow), 2, 0);
      pLabelGrid->addWidget(new QLabel(QObject::tr("c - runtime statistic display"), mainAppWindow), 2, 1);
      
      // ------------------------------------------------------
      // create the button area
      QPushButton* pBtn = new QPushButton(QObject::tr("Push me"), mainAppWindow);
      pBtnHBox->addWidget(pBtn);
      pBtnHBox->addItem(new QSpacerItem(0,0, QSizePolicy::Expanding,QSizePolicy::Minimum));
      
      // display the window
      mainAppWindow->show();
      
      return app.exec();
      

      }
      @

      Nokia Certified Qt Specialist.
      Programming Is Like Sex: One mistake and you have to support it for the rest of your life. (Michael Sinz)

      1 Reply Last reply
      0
      • G Offline
        G Offline
        GroundZero
        wrote on last edited by
        #21

        Gerolf, thank you very much. I will try to fix my code first before copy pasting yours lol, need to learn it anyways haha. Thank you so much once again ;)

        P.S. I see you do a LOT of stuff totally different i.e.
        @pLabelGrid->addWidget(new QLabel(QObject::tr("c - runtime statistic display"), mainAppWindow), 2, 1);@
        @pibLayout->addWidget(nameText, 0, 1);@

        you use tr (translate?) and a 2nd attribute. After that you give the QLabel object a 2nd and 3rd attribute (2 and 1).
        Never seen that / done that but... ill try to fix my code and try to find out what this all means :)

        Also in the 2nd example the INT for a row and so on, thats pritty cool! this will surely help me out a LOT!

        1 Reply Last reply
        0
        • G Offline
          G Offline
          goetz
          wrote on last edited by
          #22

          [quote author="Gerolf" date="1327498560"]
          Spit it up to sub forms? :-)
          I know there are cases, where it really makes sense, but I try to avoid forms with hundreds of widgets.[/quote]

          It's already subforms :-)
          Collecting data isn't always doable with two line edits and a combo box ;-)

          http://www.catb.org/~esr/faqs/smart-questions.html

          1 Reply Last reply
          0
          • G Offline
            G Offline
            giesbert
            wrote on last edited by
            #23

            [quote author="GroundZero" date="1327501166"]P.S. I see you do a LOT of stuff totally different i.e.
            @pLabelGrid->addWidget(new QLabel(QObject::tr("c - runtime statistic display"), mainAppWindow), 2, 1);@
            @pibLayout->addWidget(nameText, 0, 1);@

            you use tr (translate?) and a 2nd attribute. After that you give the QLabel object a 2nd and 3rd attribute (2 and 1).
            Never seen that / done that but... ill try to fix my code and try to find out what this all means :)

            Also in the 2nd example the INT for a row and so on, thats pritty cool! this will surely help me out a LOT![/quote]

            All widgets have parameters in the constructor, one is the parent, which I ALWAYS set. It also works without, then the layout sets them.

            the integers in the addWidget is for the grid layout.

            Nokia Certified Qt Specialist.
            Programming Is Like Sex: One mistake and you have to support it for the rest of your life. (Michael Sinz)

            1 Reply Last reply
            0
            • G Offline
              G Offline
              GroundZero
              wrote on last edited by
              #24

              yeah awesome, I never knew this does help me out a lot :)
              trying to code it now my self, hope I can figure this stuff out lol pritty hard to understand all the boxes and stuff.

              Webdevelopment is so much easier lol lol :-)

              EDIT:
              Figured I would but... I made a much simpler layout. Problem is that it is displayed right under each other instead of next
              to each other. How can I fix this? my code:

              @int main(int argc, char *argv[])
              {
              QApplication app(argc, argv);

              // -------------------------------------------------------
              // create the main widget
              QWidget *mainApplication = new QWidget;
              mainApplication->setWindowTitle("Hand coded GUI");
              mainApplication->setFixedSize(500, 600);
              
              // -------------------------------------------------------
              // main box
              QVBoxLayout *mainLayout = new QVBoxLayout;
              mainApplication->setLayout(mainLayout);
              
              // -------------------------------------------------------
              // sub boxes
              QHBoxLayout *pLeftSide = new QHBoxLayout;
              QVBoxLayout *pRightSide = new QVBoxLayout;
              
              mainLayout->addLayout(pLeftSide);
              mainLayout->addLayout(pRightSide);
              
              // -------------------------------------------------------
              // create the group box
              QGroupBox *userinfoGroupBox = new QGroupBox;
              userinfoGroupBox->setTitle("Personal Info");
              
              // -------------------------------------------------------
              // create the content of the group box
              QLabel *nameLabel = new QLabel(QObject::tr("name"));
              QLineEdit *nameEdit = new QLineEdit;
              QLabel *surnameLabel = new QLabel(QObject::tr("surname"));
              QLineEdit *surnameEdit = new QLineEdit;
              
              // -------------------------------------------------------
              // create the layout for the userinfoGroupBox
              QGridLayout *gridView = new QGridLayout;
              gridView->addWidget(nameLabel, 0, 0);
              gridView->addWidget(nameEdit, 0, 1);
              gridView->addWidget(surnameLabel, 1, 0);
              gridView->addWidget(surnameEdit, 1, 1);
              
              // -------------------------------------------------------
              // add the layout to the group box
              userinfoGroupBox->setLayout(gridView);
              
              // -------------------------------------------------------
              // add the groupbox to the leftside box
              pLeftSide->addWidget(userinfoGroupBox);
              
              // -------------------------------------------------------
              // create some sliders
              QLabel *aSliderLabel = new QLabel(QObject::tr("a value"));
              QSlider *aSlider = new QSlider(Qt::Horizontal);
              aSlider->setRange(0, 100);
              aSlider->setValue(88);
              QLabel *bSliderLabel = new QLabel(QObject::tr("b value"));
              QSlider *bSlider = new QSlider(Qt::Horizontal);
              bSlider->setRange(0, 300);
              bSlider->setValue(142);
              
              // -------------------------------------------------------
              // add the widgets to the right window
              pRightSide->addWidget(aSliderLabel);
              pRightSide->addWidget(aSlider);
              pRightSide->addWidget(bSliderLabel);
              pRightSide->addWidget(bSlider);
              
              // display the window
              mainApplication->show();
              
              return app.exec&#40;&#41;;
              

              }@

              So what I want is:

              1. mainLayout = my main wrapper / container / box, or what ever you want to call it.
              2. pLeftSide and pRightSide are two boxes which should be displayed NEXT to each other.
              3. pLeftSide should display stuff by pairs of two next to each other (this is working)
              4. pRightSize should display stuff under each other (this is working)

              Also, my sliders get stretched out... so they are extremely width :-(

              EDIT:
              I have another question if I may so...

              I was reading the book. I made a GUI by using Qt Designer. Works flawless BUT... the book tells me the following:
              bq. Now run qmake to create a .pro file and a makefile (qmake -project;qmake gotocell.pro). The qmake tool is smart enough to detect the user interface file gotocell-dialog.ui and to generate the appropriate makefule rules to invoke uic, Qt's user interface compiler.

              Now... I have no clue what they mean with qmake this and qmake that lol. I want to see the source, how the GUI I made was build up in plain C++ and not a (no offence) stupid XML file look a like markup lol.

              Could someone walk me through the process of turning this XML look-a-like thingy to a C++ type.

              1 Reply Last reply
              0
              • G Offline
                G Offline
                giesbert
                wrote on last edited by
                #25

                If you only use box layouts, you will never create grids :-)
                Try using QGridLayout, it helps much in the UI you have.

                Another thing, what I typically do is, put creation of sub parts in a method. E.g. create the group box in a method and return the group box pointer. Using this, you can test it independently and just use it later.

                Do you use QtCreator? Or all tools by hand?

                Regarding your last question:

                call qmake to create a qt project file (qmake -project) and then create a make file (qmake xxx.pro). When you now compile the makefile (nmake, make, mingw-make, what ever tool chain you use), you get a ui_xxx.h file (or is it xxx_ui.h?). This is the C++ code of the ui file.

                Nokia Certified Qt Specialist.
                Programming Is Like Sex: One mistake and you have to support it for the rest of your life. (Michael Sinz)

                1 Reply Last reply
                0
                • B Offline
                  B Offline
                  briggie
                  wrote on last edited by
                  #26

                  bq. In MFC, it was not possible to code UI’s by hand, as you had no layouters, only coordinates, but with layout classes, it’s fairly easy to code the UI by hand.

                  I am a pretty big stickler when it comes to making guis. I don't really like using forms either. I am an engineer by trade, so when I tried C++/CLI, .NET, and sometimes straight winapi it was extremely hard for me to code without relying on forms. Finally discovered qt and all my problems were solved :)

                  1 Reply Last reply
                  0
                  • G Offline
                    G Offline
                    GroundZero
                    wrote on last edited by
                    #27

                    @ Gerolf;

                    I use Qt Creator to do everything. I will change my code and use some GridLayouts and hopefully that will make things look better haha.

                    I am a bit confused though, but I will give it another try and hopefully get it done right this time ;)

                    Thanks for your answer guys!

                    1 Reply Last reply
                    0
                    • M Offline
                      M Offline
                      miroslav
                      wrote on last edited by
                      #28

                      It is a mystery to me why even experienced Qt coders prefer hand-coding UIs over using designer. Sure, there are situations where manual layouting is needed to achieve some special results, but those should be exceptions.

                      It is a good approach to learn about layouting by looking at the code generated by designer. I suggest to use that insight to learn enough about designer to use it. Since layout initialization code is usually not executed repeatedly, hand-crafting layouts will not result is significant performance gains, and makes UIs much harder to maintain.

                      Mirko Boehm | mirko@kde.org | KDE e.V.
                      FSFE Fellow
                      Qt Certified Specialist

                      1 Reply Last reply
                      0
                      • A Offline
                        A Offline
                        andre
                        wrote on last edited by
                        #29

                        I agree: Designer-based UI's when possible, and hand-crafted when needed. However, I must say that at time, I also find that I fight with Designer more than I like.

                        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