ソースを参照

Merge branch 'popup-widget'

* popup-widget:
  Don't hide popup widget if the active window is a tooltip/popup
  Activate tooltips in ctkPopupWidgets even if not active
Julien Finet 14 年 前
コミット
30ddce3805
共有1 個のファイルを変更した11 個の追加2 個の削除を含む
  1. 11 2
      Libs/Widgets/ctkPopupWidget.cpp

+ 11 - 2
Libs/Widgets/ctkPopupWidget.cpp

@@ -470,12 +470,18 @@ void ctkPopupWidgetPrivate::updateVisibility()
   Q_Q(ctkPopupWidget);
   // If the BaseWidget window is active, then there is no reason to cover the
   // popup.
-  if (!this->BaseWidget  || !this->BaseWidget->window()->isActiveWindow())
+  if (!this->BaseWidget  ||
+      (!this->BaseWidget->window()->isActiveWindow() &&
+       !qApp->activeWindow() ||
+       (qApp->activeWindow()->windowType() != Qt::ToolTip &&
+        qApp->activeWindow()->windowType() != Qt::Popup)))
     {
     foreach(QWidget* topLevelWidget, qApp->topLevelWidgets())
       {
       // If there is at least 1 window (active or not) that covers the popup,
       // then we ensure the popup is hidden.
+      // We have no way of knowing which toplevel is over (z-order) which one,
+      // it is an OS specific information.
       // Of course, tooltips and popups don't count as covering windows.
       if (topLevelWidget->isVisible() &&
           !(topLevelWidget->windowState() & Qt::WindowMinimized) &&
@@ -485,7 +491,10 @@ void ctkPopupWidgetPrivate::updateVisibility()
           topLevelWidget->frameGeometry().intersects(q->geometry()))
         {
         //qDebug() << "hide" << q << "because of: " << topLevelWidget
-        //         << " with windowType: " << topLevelWidget->windowType();
+        //         << " with windowType: " << topLevelWidget->windowType()
+        //         << topLevelWidget->isVisible()
+        //         << (this->BaseWidget ? this->BaseWidget->window() : 0)
+        //         << topLevelWidget->frameGeometry();
         this->temporarilyHiddenOn();
         return;
         }