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. Anchoring the widgets for resizing with the form
Qt 6.11 is out! See what's new in the release blog

Anchoring the widgets for resizing with the form

Scheduled Pinned Locked Moved Unsolved General and Desktop
layoutresize
22 Posts 5 Posters 13.9k Views 3 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.
  • jsulmJ Offline
    jsulmJ Offline
    jsulm
    Lifetime Qt Champion
    wrote on last edited by
    #2

    I don't understand your question.
    What anchors do you need?
    Layouts in Qt typically resize automatically if the form is resized.

    https://forum.qt.io/topic/113070/qt-code-of-conduct

    1 Reply Last reply
    0
    • mrjjM Offline
      mrjjM Offline
      mrjj
      Lifetime Qt Champion
      wrote on last edited by
      #3

      hi
      If you place something widget on a from in Designer
      and then right click the form, the last menu allows you to
      add a layout.
      This way you can add layout to most Widgets, not just forms.
      But place other widget first inside the widget/form then right click.

      http://doc.qt.io/qt-5/layout.html

      1 Reply Last reply
      0
      • nulluseN Offline
        nulluseN Offline
        nulluse
        wrote on last edited by nulluse
        #4

        I think I misunderstood the correlation between the layouts in Qt Designer and the layouts mentioned in the tutorials. I thought that by layout they meant dropping one of the very top 3 components from the Qt Designer toolbox onto a form and adding all widgets to the layout, as I did not know that layout was something different and had to be accessed through a pop up menu instead.

        mrjjM kshegunovK 2 Replies Last reply
        0
        • nulluseN nulluse

          I think I misunderstood the correlation between the layouts in Qt Designer and the layouts mentioned in the tutorials. I thought that by layout they meant dropping one of the very top 3 components from the Qt Designer toolbox onto a form and adding all widgets to the layout, as I did not know that layout was something different and had to be accessed through a pop up menu instead.

          mrjjM Offline
          mrjjM Offline
          mrjj
          Lifetime Qt Champion
          wrote on last edited by
          #5

          @nulluse
          Hi the layouts in the list with widgets is also just layouts.
          U can drag to widget to apply it.
          Should work the same, but never tested it,
          Always used right click. :)

          1 Reply Last reply
          0
          • mrjjM Offline
            mrjjM Offline
            mrjj
            Lifetime Qt Champion
            wrote on last edited by
            #6

            Ok
            tested it.
            They do not work the same. Sort like floating layouts or for layout in layout i guess.
            Using right click will work better.

            1 Reply Last reply
            0
            • nulluseN Offline
              nulluseN Offline
              nulluse
              wrote on last edited by
              #7

              Pardon my straight attitude, but this is sooooo counter intuitive!
              The anchor approach is ways more straightforward and adds ways less overhead.

              mrjjM 1 Reply Last reply
              0
              • nulluseN nulluse

                Pardon my straight attitude, but this is sooooo counter intuitive!
                The anchor approach is ways more straightforward and adds ways less overhead.

                mrjjM Offline
                mrjjM Offline
                mrjj
                Lifetime Qt Champion
                wrote on last edited by
                #8

                @nulluse said:

                anchor approach

                well I used anchors in other frameworks and so far
                Qt layouts are far better :)

                Very easy to use and setup. even for complex layout once u get the hang of it.

                1 Reply Last reply
                0
                • mrjjM Offline
                  mrjjM Offline
                  mrjj
                  Lifetime Qt Champion
                  wrote on last edited by
                  #9

                  oh, just as a note.
                  Minimum and maximum size property is often useful with layouts.
                  Also on the layout layoutRow/colStretch if u want to change how much
                  each get. normal is 50/50
                  so if u write 2,1 the first get twice as much.
                  That was not intuitive and I still miss the ability to use %
                  But over all it works good.

                  1 Reply Last reply
                  0
                  • nulluseN nulluse

                    I think I misunderstood the correlation between the layouts in Qt Designer and the layouts mentioned in the tutorials. I thought that by layout they meant dropping one of the very top 3 components from the Qt Designer toolbox onto a form and adding all widgets to the layout, as I did not know that layout was something different and had to be accessed through a pop up menu instead.

                    kshegunovK Offline
                    kshegunovK Offline
                    kshegunov
                    Moderators
                    wrote on last edited by
                    #10

                    @nulluse said:

                    I think I misunderstood the correlation between the layouts in Qt Designer and the layouts mentioned in the tutorials. I thought that by layout they meant dropping one of the very top 3 components from the Qt Designer toolbox onto a form and adding all widgets to the layout, as I did not know that layout was something different and had to be accessed through a pop up menu instead.

                    It's basically the same thing, only the way the code is generated is a bit different. When you drop a layout from the toolbox, it's inserted as a child layout (layouts can be nested) to the widget's layout. If your widget doesn't have a layout (which is the default) it floats around. When you use the context menu, you set the layout of the widget, hence your elements are not floating. In code this'd look like this:

                    QWidget * widget; //< The widget initialized from the form
                    
                    // This is approximately what's generated when you drag a layout from the toolbox
                    QLayout * droppedFromToolbox; //< The layout that's generated when you drag it from the toolbox
                    QLayout * widgetLayout = widget->layout();
                    if (widgetLayout)
                       widgetLayout ->addItem(droppedFromToolbox);
                    
                    // This is what's generated (again approximately) when you use the context menu.
                    QLayout * fromContextMenu; //< The layout selected from the context menu
                    widget->setLayout(fromContextMenu);
                    

                    You can see those are a bit different, but work on the same principle.

                    Kind regards.

                    Read and abide by the Qt Code of Conduct

                    1 Reply Last reply
                    1
                    • nulluseN Offline
                      nulluseN Offline
                      nulluse
                      wrote on last edited by
                      #11

                      After reading more on this I realize that the concept of layouts (also used in Android etc) is horrible comparing with straightforward, flexible and easy to set up system of anchors.
                      With the layouts you have to

                      1. set up your form for a layout before adding any widgets

                      if you missed #1 you are summarily screwed.

                      1. choose by way of trial and error the layout that least mucks up the intended design
                      2. freeze many widgets by entering min and max sizes (typing tons of numbers)

                      all instead of flipping the yes/no anchors of the widgets.

                      Looks like Qt came to their senses in Qt Quick (whatever it is) which now supports the anchors, but not in the regular .ui files.

                      To sum it up, this is a very counter-intuitive niche concept where the UI developer is totally at the mercy of the pre-defined layouts and once that is chosen, QtDesigner does not even support full undo function. If you want to support nothing but devices and smartphones, this is probably Okay, but for a normal desktop layouts are very counter-intuitive and counter-productive.

                      1 Reply Last reply
                      0
                      • jsulmJ Offline
                        jsulmJ Offline
                        jsulm
                        Lifetime Qt Champion
                        wrote on last edited by
                        #12

                        "niche concept"?
                        Are you sure layouts are a niche concept?
                        As far as I know Java GUI for example uses layouts as well (see https://docs.oracle.com/javase/tutorial/uiswing/layout/visual.html). I like layouts - they are very flexible and powerful.

                        https://forum.qt.io/topic/113070/qt-code-of-conduct

                        1 Reply Last reply
                        1
                        • nulluseN Offline
                          nulluseN Offline
                          nulluse
                          wrote on last edited by
                          #13

                          Adding a layout to the UI elements on a form resizes and rearranges them all and it is not possible to change their sizes once they are in a layout. How's that powerful and flexible?

                          mrjjM 1 Reply Last reply
                          0
                          • nulluseN nulluse

                            Adding a layout to the UI elements on a form resizes and rearranges them all and it is not possible to change their sizes once they are in a layout. How's that powerful and flexible?

                            mrjjM Offline
                            mrjjM Offline
                            mrjj
                            Lifetime Qt Champion
                            wrote on last edited by
                            #14

                            @nulluse
                            The layout define the size.Not reversed.
                            If you dont want the layout size for all widgets ,
                            u can then adjust with min/max sizes on individual widgets.
                            You can also instruct layout if u want to be greedy and use all space/and or other options.

                            nulluseN 1 Reply Last reply
                            0
                            • mrjjM mrjj

                              @nulluse
                              The layout define the size.Not reversed.
                              If you dont want the layout size for all widgets ,
                              u can then adjust with min/max sizes on individual widgets.
                              You can also instruct layout if u want to be greedy and use all space/and or other options.

                              nulluseN Offline
                              nulluseN Offline
                              nulluse
                              wrote on last edited by
                              #15

                              @mrjj said:

                              @nulluse
                              If you dont want the layout size for all widgets ,
                              u can then adjust with min/max sizes on individual widgets.
                              You can also instruct layout if u want to be greedy and use all space/and or other options.

                              Exactly! This is double work, and very tedious one, versus defining the anchors.
                              The anchors do not require defining fixed sizes.

                              mrjjM kshegunovK 2 Replies Last reply
                              0
                              • nulluseN nulluse

                                @mrjj said:

                                @nulluse
                                If you dont want the layout size for all widgets ,
                                u can then adjust with min/max sizes on individual widgets.
                                You can also instruct layout if u want to be greedy and use all space/and or other options.

                                Exactly! This is double work, and very tedious one, versus defining the anchors.
                                The anchors do not require defining fixed sizes.

                                mrjjM Offline
                                mrjjM Offline
                                mrjj
                                Lifetime Qt Champion
                                wrote on last edited by
                                #16

                                @nulluse
                                Yeah but layouts dont either.
                                Its assumed u want same size for all.
                                So only if u dont , u set it.
                                Its not double work as often NOT needed.
                                I want same size for all anyway.
                                and u can have margins if u want and many other nice tweaks.

                                nulluseN 1 Reply Last reply
                                0
                                • nulluseN nulluse

                                  @mrjj said:

                                  @nulluse
                                  If you dont want the layout size for all widgets ,
                                  u can then adjust with min/max sizes on individual widgets.
                                  You can also instruct layout if u want to be greedy and use all space/and or other options.

                                  Exactly! This is double work, and very tedious one, versus defining the anchors.
                                  The anchors do not require defining fixed sizes.

                                  kshegunovK Offline
                                  kshegunovK Offline
                                  kshegunov
                                  Moderators
                                  wrote on last edited by
                                  #17

                                  @nulluse said:

                                  Exactly! This is double work, and very tedious one, versus defining the anchors.
                                  The anchors do not require defining fixed sizes.

                                  Neither do layouts. There are things called resize policies and stretch factors, which I suppose you should take a look at. Also how do you anchor two elements back to back such that one of them takes 2/3 of the space and one 1/3, ain't it necessary to go and set that manually?

                                  Read and abide by the Qt Code of Conduct

                                  1 Reply Last reply
                                  0
                                  • nulluseN Offline
                                    nulluseN Offline
                                    nulluse
                                    wrote on last edited by
                                    #18

                                    And that's even more work vs flipping yes/no anchors and not having to worry about anything else.

                                    1 Reply Last reply
                                    0
                                    • mrjjM mrjj

                                      @nulluse
                                      Yeah but layouts dont either.
                                      Its assumed u want same size for all.
                                      So only if u dont , u set it.
                                      Its not double work as often NOT needed.
                                      I want same size for all anyway.
                                      and u can have margins if u want and many other nice tweaks.

                                      nulluseN Offline
                                      nulluseN Offline
                                      nulluse
                                      wrote on last edited by
                                      #19

                                      @mrjj said:

                                      @nulluse
                                      Yeah but layouts dont either.
                                      Its assumed u want same size for all.
                                      So only if u dont , u set it.
                                      Its not double work as often NOT needed.
                                      I want same size for all anyway.
                                      and u can have margins if u want and many other nice tweaks.

                                      You probably need to look at a system that uses anchors to realize how much more productive they allow the developers to be.

                                      1 Reply Last reply
                                      0
                                      • nulluseN Offline
                                        nulluseN Offline
                                        nulluse
                                        wrote on last edited by
                                        #20

                                        If the layouts are so wonderful, can anyone explain why specifying a horizontal layout for a form with 3 panels adds 9 pixel margin on all sides of the form? How can that margin be eliminated?

                                        ? 1 Reply Last reply
                                        0
                                        • nulluseN nulluse

                                          If the layouts are so wonderful, can anyone explain why specifying a horizontal layout for a form with 3 panels adds 9 pixel margin on all sides of the form? How can that margin be eliminated?

                                          ? Offline
                                          ? Offline
                                          A Former User
                                          wrote on last edited by
                                          #21

                                          @nulluse said:

                                          How can that margin be eliminated?

                                          Simple: For centralWidget set layoutLeftMargin, layoutRightMargin, layoutTopMargin, layoutBottomMargin, and layoutSpacing all to 0. Default is 9, resp. 6.

                                          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