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. Qt Creator WYSIWYG isn't giving a true representation
Forum Updated to NodeBB v4.3 + New Features

Qt Creator WYSIWYG isn't giving a true representation

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

    @Pl45m4 , in fact every thing I've tried still results in the label showing everything except the first letter "S".

    Pl45m4P Offline
    Pl45m4P Offline
    Pl45m4
    wrote on last edited by
    #24

    @SPlatten

    I believe there's still something wrong. Show your layout please (the layout / widget setup and the result you get)


    If debugging is the process of removing software bugs, then programming must be the process of putting them in.

    ~E. W. Dijkstra

    1 Reply Last reply
    1
    • SPlattenS SPlatten

      This is part of the form whilst editing in Qt Creator:
      creator.png

      This is the same form when running as application on desktop:
      IMG_0355.jpg

      In both cases I've screen printed and cropped the area. Why is the final presentation in the compiled application when running on the desktop so different from the view in Qt Creator?

      Also notice the controls used in Qt Creator are not quite the same as those when running in the application, note that the rectangles for the buttons and combo are sharp when running in the application and very slightly rounded when running in Qt Creator.

      I'm using Qt 4.4.1, Based on Qt 5.9.2 (MSVC 2015, 32 bit).

      Thank YouT Offline
      Thank YouT Offline
      Thank You
      wrote on last edited by Thank You
      #25

      @SPlatten
      I think it is layout issue.
      In QT Creator You see it
      But while compiling it may show some or none of things

      Try applying horizontal layout label and QComboBox as discussed by @Pl45m4
      Then I am sure It will work
      It may not work if the window size is small Try resizing it

      Why you can't expect the output from QT Creator
      The height and width in QT Creator just for there unless layout is applied to it?
      If the design in QT Creator fills the screen properly Then would you expect it fill to all screens in the same behaviour "NO"
      So It's specific to that size only So I guess layouts are
      EASY
      RESPONSIVE
      ATTRACTIVE

      I hope it helps

      Let's make QT free or It will go forever

      TRUE AND FALSE <3

      SPlattenS 1 Reply Last reply
      0
      • Thank YouT Thank You

        @SPlatten
        I think it is layout issue.
        In QT Creator You see it
        But while compiling it may show some or none of things

        Try applying horizontal layout label and QComboBox as discussed by @Pl45m4
        Then I am sure It will work
        It may not work if the window size is small Try resizing it

        Why you can't expect the output from QT Creator
        The height and width in QT Creator just for there unless layout is applied to it?
        If the design in QT Creator fills the screen properly Then would you expect it fill to all screens in the same behaviour "NO"
        So It's specific to that size only So I guess layouts are
        EASY
        RESPONSIVE
        ATTRACTIVE

        I hope it helps

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

        This is now resolved, I redid the main window ui, the top line buttons and widgets are now in a horizontal layout with the main window content in a grid layout. As a WYSIWYG editor Qt Creator is rubbish because the presentation of what you see is not what you get.

        Kind Regards,
        Sy

        jsulmJ 1 Reply Last reply
        0
        • Christian EhrlicherC Online
          Christian EhrlicherC Online
          Christian Ehrlicher
          Lifetime Qt Champion
          wrote on last edited by
          #27

          @SPlatten said in Qt Creator WYSIWYG isn't giving a true representation:

          As a WYSIWYG editor Qt Creator is rubbish because the presentation of what you see is not what you get.

          I don't see how this should work - first you've styles which slightly modifies the items and then you can set the sizes and others by code - so what do you expect that this should work out?
          That's why you have to use layouts - they arrange the widgets the way you want without killing the layout when another style is used or similar.

          Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
          Visit the Qt Academy at https://academy.qt.io/catalog

          1 Reply Last reply
          2
          • SPlattenS SPlatten

            This is now resolved, I redid the main window ui, the top line buttons and widgets are now in a horizontal layout with the main window content in a grid layout. As a WYSIWYG editor Qt Creator is rubbish because the presentation of what you see is not what you get.

            jsulmJ Offline
            jsulmJ Offline
            jsulm
            Lifetime Qt Champion
            wrote on last edited by jsulm
            #28

            @SPlatten said in Qt Creator WYSIWYG isn't giving a true representation:

            As a WYSIWYG editor Qt Creator is rubbish

            I think the mistake you were doing was that you were designing your UI manually (positions and sizes of the widgets) for a specific theme. This is a very bad idea in my opinion because your UI is going to break as soon as the theme changes.
            Lets assume QtDesigner would use the system theme, you are on Windows 10 and design your UI manually, everything is fine. One day Microsoft changes the theme (this will for sure happen one day) - your UI breaks, you have to adjust the UI and rebuild your app for the new Windows version. And there is one more thing to consider: if you're working on a cross platform app then your UI will only behave properly on the platform were you created it...

            I use QtDesigner a lot and don't see how it is rubbish as long as you use layouts. So, instead of blaming the tool use it properly.

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

            1 Reply Last reply
            3
            • SPlattenS Offline
              SPlattenS Offline
              SPlatten
              wrote on last edited by
              #29

              Perhaps rubbish is too harsh, but I've used various GUI tools and IDE's and generally when designing a GUI in a front end, what you end up with in your application is exactly how you left it in the designer. This isn't always the case in Qt Creator.

              I'm not sure what you mean by themes, I drag and drop widgets from the palette onto the form and edit properties if required, in code I didn't modify anything, however now its fixed.

              Kind Regards,
              Sy

              jsulmJ 1 Reply Last reply
              0
              • SPlattenS SPlatten

                Perhaps rubbish is too harsh, but I've used various GUI tools and IDE's and generally when designing a GUI in a front end, what you end up with in your application is exactly how you left it in the designer. This isn't always the case in Qt Creator.

                I'm not sure what you mean by themes, I drag and drop widgets from the palette onto the form and edit properties if required, in code I didn't modify anything, however now its fixed.

                jsulmJ Offline
                jsulmJ Offline
                jsulm
                Lifetime Qt Champion
                wrote on last edited by jsulm
                #30

                @SPlatten said in Qt Creator WYSIWYG isn't giving a true representation:

                I'm not sure what you mean by themes

                This thread started with you saying that QtDesigner does not use system theme (which is correct observation).

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

                SPlattenS 1 Reply Last reply
                1
                • jsulmJ jsulm

                  @SPlatten said in Qt Creator WYSIWYG isn't giving a true representation:

                  I'm not sure what you mean by themes

                  This thread started with you saying that QtDesigner does not use system theme (which is correct observation).

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

                  @jsulm , I don't follow at all.

                  Kind Regards,
                  Sy

                  jsulmJ 1 Reply Last reply
                  0
                  • SPlattenS SPlatten

                    @jsulm , I don't follow at all.

                    jsulmJ Offline
                    jsulmJ Offline
                    jsulm
                    Lifetime Qt Champion
                    wrote on last edited by
                    #32

                    @SPlatten "Also notice the controls used in Qt Creator are not quite the same as those when running in the application, note that the rectangles for the buttons and combo are sharp when running in the application and very slightly rounded when running in Qt Creator." - you wrote this, right?
                    Also: "Qt Creator should present the forms in the way they will look when running on the host, which currently is very different"

                    So, what I mean is: QtDesigner does not use the system theme (the one used in the OS it is running on).

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

                    SPlattenS 1 Reply Last reply
                    0
                    • jsulmJ jsulm

                      @SPlatten "Also notice the controls used in Qt Creator are not quite the same as those when running in the application, note that the rectangles for the buttons and combo are sharp when running in the application and very slightly rounded when running in Qt Creator." - you wrote this, right?
                      Also: "Qt Creator should present the forms in the way they will look when running on the host, which currently is very different"

                      So, what I mean is: QtDesigner does not use the system theme (the one used in the OS it is running on).

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

                      @jsulm , ok, thank you, and why is that? Surely thats either a design fault?

                      Is it a setting I can change?

                      Kind Regards,
                      Sy

                      jsulmJ 1 Reply Last reply
                      0
                      • Christian EhrlicherC Online
                        Christian EhrlicherC Online
                        Christian Ehrlicher
                        Lifetime Qt Champion
                        wrote on last edited by
                        #34

                        @SPlatten said in Qt Creator WYSIWYG isn't giving a true representation:

                        ok, thank you, and why is that? Surely thats either a design fault?

                        No design fault - it's a design feature that your app uses the style of the OS so it looks native.

                        Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                        Visit the Qt Academy at https://academy.qt.io/catalog

                        SPlattenS 1 Reply Last reply
                        0
                        • SPlattenS SPlatten

                          @jsulm , ok, thank you, and why is that? Surely thats either a design fault?

                          Is it a setting I can change?

                          jsulmJ Offline
                          jsulmJ Offline
                          jsulm
                          Lifetime Qt Champion
                          wrote on last edited by
                          #35

                          @SPlatten I don't know why QtDesigner does not use the system theme and I'm not aware of any settings for that. Qt developers on Qt Mailing List could provide more information about this issue.

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

                          1 Reply Last reply
                          0
                          • Christian EhrlicherC Christian Ehrlicher

                            @SPlatten said in Qt Creator WYSIWYG isn't giving a true representation:

                            ok, thank you, and why is that? Surely thats either a design fault?

                            No design fault - it's a design feature that your app uses the style of the OS so it looks native.

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

                            @Christian-Ehrlicher , thats exactly what I want as the default behaviour, but thats not what I'm seeing. What I'm getting is a slightly different look in the designer to the end product.

                            Kind Regards,
                            Sy

                            Christian EhrlicherC 1 Reply Last reply
                            0
                            • S Offline
                              S Offline
                              SimonSchroeder
                              wrote on last edited by
                              #37

                              I agree that the Qt Designer is not very good. I had a harder time learning the designer instead of writing C++ code. Especially handling layouts is quite cumbersome in the designer. Most of the time I would be much faster writing things down in C++. But our project uses ui-files.

                              You can have a look how things would look like in the native style by using the menu: Tools -> Form Editor -> Preview. It is not entirely WYSIWYG, but you don't have to compile and run your application first to see how it looks. It will not know about your stylesheets, though (maybe there is a way to let it know about them). Also, showing a dialog in your application might actually resize the widget (especially when it contains layouts) whereas the preview shows you the same size as the designer.

                              The designer was done for designers who don't know how to code. If you know how to code, I personally prefer to write things down in C++. This gives me much better control over everything and even shifting around things inside the layout is much faster. Sometimes to add something to a complex grid layout you have to break the layout first, then reposition everything in the designer so that when you reapply the grid layout it will pick up on everything correctly. That is way faster in C++ code.

                              I don't expect any improvements for the Qt Designer. Designers (the people) are now targeted with QML instead (and also Qt Studio and the like with the commercial licenses).

                              1 Reply Last reply
                              2
                              • SPlattenS SPlatten

                                @Christian-Ehrlicher , thats exactly what I want as the default behaviour, but thats not what I'm seeing. What I'm getting is a slightly different look in the designer to the end product.

                                Christian EhrlicherC Online
                                Christian EhrlicherC Online
                                Christian Ehrlicher
                                Lifetime Qt Champion
                                wrote on last edited by
                                #38

                                @SPlatten I don't see what's wrong that there is another style used in designer - your layout should look good with all styles.
                                You can select the style for the preview in QtCreator -> extra -> layout editor -> preview in -> <your desired style>

                                Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                                Visit the Qt Academy at https://academy.qt.io/catalog

                                1 Reply Last reply
                                2
                                • C Offline
                                  C Offline
                                  ChrisW67
                                  wrote on last edited by ChrisW67
                                  #39

                                  As previously noted, Qt GUI programs generally default to a style that matches the runtime environment to a reasonable degree. Designer on my Linux box defaults to the Fusion style. The program can force the style but a quick look at the Designer source does not immediately suggest it does.

                                  Designer, like any idiomatic Qt GUI program, accepts the command line option "-style stylename". As far as I can tell the common option (depending on platform) are: Windows, WindowsXP, WindowsVista, Android, Fusion, Macintosh. On my Linux box I also have a Breeze and Oxygen style. If, on the platform you are running, it is possible to display in that style it will, or it will report to the console the allowable options and fall back to something that can work. I think Fusion is available and consistent for all platforms.

                                  Within Designer you can preview your UI in any of the styles that can be rendered in your development environment. It's on one of the menus.

                                  QtCreator also accepts the flag, but the main UI is so heavily customized the only difference seems to be in the menu look-and-feel.

                                  Your program can force a style (QApplication::setStyle()) and accept that your program looks different to the other native apps. The Windows style emulation on Linux is Windows95-ish and truly awful ;)

                                  You can develop your own style to plug in, but that's a lot of work.

                                  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