Author Topic: [solved] wxSmith is awfully slow  (Read 2488 times)

Offline tigerbeard

  • Almost regular
  • **
  • Posts: 196
[solved] wxSmith is awfully slow
« on: December 07, 2023, 04:14:00 pm »
I was using wxSmith to extend a quite complex dialog with >100 control items. One day I notices that suddenly the *.wxs Tab with the Dialog layout because awfully slow. So slow that i was almost unusable. One click took min 5sec, somtimes it would re-create the dialog 2-3 times before event allowing a selection of an item. This also happened when I only changed parameters on the tree.

The workaround I found was to switch to another tab with some source code. The gui tree with the widget properties was still visible and I could normally work there.

Now I found the cause of the problem and wanted to just document it here, in case anyone has the same problem .

The cause was the graphics drivers. I am working on Linux with nvidia drivers. Somehow my graphics driver got corrupted and the system fell back to the "nouveau" driver which is basically a software emulation for all grahics accelerations. So it seems that the wxSmith dialog display is using OpenGL for rendering. I was using wxSmith for some years but did not know I am looking to a graphics windows all that time :-).
My guess is that its using the fixed-pipeline apporach wich is known to be not very performant on modern GPUS and thus even worse on software emulation.

After switching back to an nvidia driver, I note that very large dialogs are still lagging a bit and refreshs are clearly visible, but its really very usable again.


« Last Edit: December 09, 2023, 02:00:16 pm by tigerbeard »

Offline Miguel Gimenez

  • Developer
  • Lives here!
  • *****
  • Posts: 1617
Re: wxSmith is awfully slow
« Reply #1 on: December 07, 2023, 04:52:11 pm »
wxSmith uses whatever driver is configured in wxWidgets, what you see are real wxWidgets components.

The main problem with speed is that all the dialog code and the GUI is regenerated every time you change something. For dialogs with few widgets this is not noticeable, but for 30+ it is.

Offline tigerbeard

  • Almost regular
  • **
  • Posts: 196
Re: wxSmith is awfully slow
« Reply #2 on: December 07, 2023, 05:16:55 pm »
So you say its not using OpenGL? 
Then I have no explanation why the speed change was so drastic.

But according to what you say, I should not have seen a massive improvement when hiding the wxs tab. That did not remove the rebuild of code, just the rebuild of the dialog window. An the difference was not milliseconds, it was really drastic.

Offline Miguel Gimenez

  • Developer
  • Lives here!
  • *****
  • Posts: 1617
Re: wxSmith is awfully slow
« Reply #3 on: December 07, 2023, 05:51:56 pm »
Quote
So you say its not using OpenGL?
I said that it uses whatever driver wxWidgets use, see the docs of wxWidgets. setup.h on GTK has this by default:
Code
#define wxUSE_GLCANVAS       1
#define wxUSE_GLCANVAS_EGL   0

Offline tigerbeard

  • Almost regular
  • **
  • Posts: 196
Re: wxSmith is awfully slow
« Reply #4 on: December 07, 2023, 06:16:03 pm »
#define wxUSE_GLCANVAS       1

Are you sure? Maybe I am wrong, but I think this flag only says wx should include the OpenGL capability into the library. Without that there is no OpenGL available at all. But imho this does not say the rendering of its widgets uses openGL. I am just thinking about the effort it takes to setup wxGLCanvas for user rendering and wonder if that could be happening behind the scenes for an odinary wxDialog. 

Offline Miguel Gimenez

  • Developer
  • Lives here!
  • *****
  • Posts: 1617
Re: wxSmith is awfully slow
« Reply #5 on: December 07, 2023, 06:24:58 pm »
Here you have the full settings with comments.
Code
// Setting wxUSE_GLCANVAS to 1 enables OpenGL support. You need to have OpenGL
// headers and libraries to be able to compile the library with wxUSE_GLCANVAS
// set to 1 and, under Windows, also to add opengl32.lib and glu32.lib to the
// list of libraries used to link your application when linking to wxWidgets
// statically (although this is done implicitly for Microsoft Visual C++ users).
//
// Default is 1.
//
// Recommended setting: 1 if you intend to use OpenGL, can be safely set to 0
// otherwise.
#define wxUSE_GLCANVAS       1

// Setting wxUSE_GLCANVAS_EGL to 1 enables OpenGL EGL backend. This will be
// automatically enabled if EGL support is detected.  EGL support is only
// available under Unix platforms.
//
// Default is 0.
//
#define wxUSE_GLCANVAS_EGL   0

Offline tigerbeard

  • Almost regular
  • **
  • Posts: 196
Re: wxSmith is awfully slow
« Reply #6 on: December 07, 2023, 06:35:48 pm »
Here you have the full settings with comments.
...

OK..., what part do you think refers to controls rendering?

Offline Miguel Gimenez

  • Developer
  • Lives here!
  • *****
  • Posts: 1617
Re: wxSmith is awfully slow
« Reply #7 on: December 07, 2023, 06:41:13 pm »
From wxwidgets docs:
Quote
Usually wxWidgets uses the underlying low level GUI system to draw all the controls - this is what we mean when we say that it is a "native" framework. However not all controls exist under all (or even any) platforms and in this case wxWidgets provides a default, generic, implementation of them written in wxWidgets itself.
For more details refer to wxWidgets documentation, this is OT here.

Offline tigerbeard

  • Almost regular
  • **
  • Posts: 196
Re: wxSmith is awfully slow
« Reply #8 on: December 07, 2023, 06:58:28 pm »
From wxwidgets docs:
Quote
Usually wxWidgets uses the underlying low level GUI system to draw all the controls - this is what we mean when we say that it is a "native" framework. However not all controls exist under all (or even any) platforms and in this case wxWidgets provides a default, generic, implementation of them written in wxWidgets itself.
For more details refer to wxWidgets documentation, this is OT here.
Right, sorry did not want to get OT. The OpenGL confused me a bit.

I know that wxWigets in Linux mostly uses gtk native controls,  Unfortunately I might add, because I ran into that when trying to match the screen density of the class browser in Linux to its Windows sibling. I utterly failed exactly because it was not rendered by wxWidgets, but just uses a native gkt2/3 control. Which incidently is lacking a working parameter to get rid of all this useless space around the single tree items. At least vertically. I fought a while with gtk theme parameters and finally gave in. But this is OT as well... :-)