[Solved] First menu on menubar not activating when moused over
- 
Just for kicks you could see if you can justify all widgets in the tree of children of your main window: @QList<QWidget *> children = mainWindow->findChildren<QWidget *>();@ The description you give sounds very much like an empty widget being placed over your menu. 
- 
[quote author="Franzk" date="1314044196"]Just for kicks you could see if you can justify all widgets in the tree of children of your main window: @QList<QWidget *> children = mainWindow->findChildren<QWidget *>();@ The description you give sounds very much like an empty widget being placed over your menu.[/quote] 
 These are the widgets that I see in the list. The first two are not owns I know of and the last set all have blank names. Is there some way I can look more closely at them?
 a widget called _layout
 a widget called qt_rubberband
 all of the QActions corresponding to my menu actions
 a widget called centralWidget
 a series of widgets with named "".
- 
"QObject::dumpObjectInfo()":http://doc.trolltech.com/latest/qobject.html#dumpObjectInfo could help. 
- 
I've looked through the dump as you have suggested and see nothing that looks unsual as far as I can see. I don't know Qt well enough to be able to explain all of the objects. I can see all that I expect to see, but there are a number that I can't. Here's the ones that I can't explain. 
 QRubberBand::qt_rubberband
 QWidget::centralWidget
 OBJECT QWidget::layoutWidget
 QToolButton::qt_menubar_ext_button
 I am using a QTableView and it seems to create a few more scroll bar and header view objects than I would expect.
 I can send the full dump, but that might be a bit much.
- 
I was working on getting you a copy with just the menu problem and not all of the application guts when I found one of my objects that was making the main window a parent. When I removed the relationship the menu starting working. My object was not a widget and does not need the window to own it. Problem solved. Thanx for leading me into the solution. I guess I need to read up on parent/child relationships in Qt. 
- 
I was very happy to find this discussion on the menubar issue. I too had the same problem and I was able to track down the QWidget that was causing the problem. However, unlike the above, my widget did need to know its parent. My solution was not not pass in the parent on the constructor, but to create a variable to hold the parent and set it separately. Thanks for your help. 
- 
Saved my life...ops .. I mean saved lots of my time thank you [quote author="blane245" date="1314113867"]I was working on getting you a copy with just the menu problem and not all of the application guts when I found one of my objects that was making the main window a parent. When I removed the relationship the menu starting working. My object was not a widget and does not need the window to own it. Problem solved. Thanx for leading me into the solution. I guess I need to read up on parent/child relationships in Qt.[/quote] 
- 
This is the gift that keeps on giving. Ran into this problem today and would have never solved it without this thread. Thanks!!! 
- 
This thread helped me to get to the problem. I would like to propose a quick way to find the solution that worked for me since I had such a big project and many children widgets. If you know how to subclass an event filter it's pretty simple... PART 1) in EventFilter.h #define EVENTFILTER_H #include <QWidget> #include <QDebug> #include <QEvent> class EventFilter : public QWidget { Q_OBJECT public: explicit EventFilter(QWidget *parent = 0); signals: protected: bool eventFilter(QObject *target, QEvent *event); }; #endif // EVENTFILTER_HPART 2) in EventFilter.cpp EventFilter::EventFilter(QWidget *parent): QWidget(parent) { } bool EventFilter::eventFilter(QObject *target, QEvent *event) { if (event->type() == QEvent::KeyPress) { QPoint p = QCursor::pos(); QWidget *w = QApplication::widgetAt(p); qDebug() << w; } }PART 3) in your mainwindow constructor or w/e you load up settings #include "EventFilter.h" EventFilter* myFilter = new EventFilter(); this->installEventFilter(myFilter);PART 4) go hunting with your new invisible widget detector! Just hover your mouse over the defective file menu items and press your spacebar, it should output the topmost offending widget to the console for you to know what you are looking for. In my case it was ANOTHER eventfilter that I had parented mistakenly way back when. Happy hunting! If you have a small project just use previous methods should be simple enough. 
- 
This thread helped me to get to the problem. I would like to propose a quick way to find the solution that worked for me since I had such a big project and many children widgets. If you know how to subclass an event filter it's pretty simple... PART 1) in EventFilter.h #define EVENTFILTER_H #include <QWidget> #include <QDebug> #include <QEvent> class EventFilter : public QWidget { Q_OBJECT public: explicit EventFilter(QWidget *parent = 0); signals: protected: bool eventFilter(QObject *target, QEvent *event); }; #endif // EVENTFILTER_HPART 2) in EventFilter.cpp EventFilter::EventFilter(QWidget *parent): QWidget(parent) { } bool EventFilter::eventFilter(QObject *target, QEvent *event) { if (event->type() == QEvent::KeyPress) { QPoint p = QCursor::pos(); QWidget *w = QApplication::widgetAt(p); qDebug() << w; } }PART 3) in your mainwindow constructor or w/e you load up settings #include "EventFilter.h" EventFilter* myFilter = new EventFilter(); this->installEventFilter(myFilter);PART 4) go hunting with your new invisible widget detector! Just hover your mouse over the defective file menu items and press your spacebar, it should output the topmost offending widget to the console for you to know what you are looking for. In my case it was ANOTHER eventfilter that I had parented mistakenly way back when. Happy hunting! If you have a small project just use previous methods should be simple enough. 
- 
I was working on getting you a copy with just the menu problem and not all of the application guts when I found one of my objects that was making the main window a parent. When I removed the relationship the menu starting working. My object was not a widget and does not need the window to own it. Problem solved. Thanx for leading me into the solution. I guess I need to read up on parent/child relationships in Qt. 
- 
I was working on getting you a copy with just the menu problem and not all of the application guts when I found one of my objects that was making the main window a parent. When I removed the relationship the menu starting working. My object was not a widget and does not need the window to own it. Problem solved. Thanx for leading me into the solution. I guess I need to read up on parent/child relationships in Qt. 
 
