]> git.saurik.com Git - wxWidgets.git/blobdiff - src/os2/toolbar.cpp
Applied patch [ 573644 ] wxDisplay for Mac (again)
[wxWidgets.git] / src / os2 / toolbar.cpp
index 0d2812a206cb67c7246330d07fe8283a192e4908..7975660d483d50b2e6c5ce56db86121dbc9270a1 100644 (file)
@@ -928,11 +928,6 @@ void wxToolBar::OnMouseEvent(
     if (!pTool)
     {
         m_vToolTimer.Stop();
     if (!pTool)
     {
         m_vToolTimer.Stop();
-        if (m_pToolTip)
-        {
-            delete m_pToolTip;
-            m_pToolTip = NULL;
-        }
         if (m_nCurrentTool > -1)
         {
             if (rEvent.LeftIsDown())
         if (m_nCurrentTool > -1)
         {
             if (rEvent.LeftIsDown())
@@ -976,10 +971,12 @@ void wxToolBar::OnMouseEvent(
             OnMouseEnter(m_nCurrentTool);
             if (!pTool->GetShortHelp().IsEmpty())
             {
             OnMouseEnter(m_nCurrentTool);
             if (!pTool->GetShortHelp().IsEmpty())
             {
+                if (m_pToolTip)
+                    delete m_pToolTip;
                 m_pToolTip = new wxToolTip(pTool->GetShortHelp());
                 m_vXMouse = (wxCoord)vPoint.x;
                 m_vYMouse = (wxCoord)vPoint.y;
                 m_pToolTip = new wxToolTip(pTool->GetShortHelp());
                 m_vXMouse = (wxCoord)vPoint.x;
                 m_vYMouse = (wxCoord)vPoint.y;
-                m_vToolTimer.Start(3000L, TRUE);
+                m_vToolTimer.Start(1000L, TRUE);
             }
             if (!pTool->IsToggled())
                 RaiseTool(pTool);
             }
             if (!pTool->IsToggled())
                 RaiseTool(pTool);
@@ -1442,18 +1439,21 @@ void wxToolBar::OnTimer (
   wxTimerEvent&                     rEvent
 )
 {
   wxTimerEvent&                     rEvent
 )
 {
-    if (rEvent.GetId() == (int)m_vToolTimer.GetTimerId())
+    if (rEvent.GetId() == m_vToolTimer.GetTimerId())
     {
         wxPoint                     vPos( m_vXMouse
                                          ,m_vYMouse
                                         );
 
         m_pToolTip->DisplayToolTipWindow(vPos);
     {
         wxPoint                     vPos( m_vXMouse
                                          ,m_vYMouse
                                         );
 
         m_pToolTip->DisplayToolTipWindow(vPos);
-        m_vToolExpTimer.Start(3000L, TRUE);
+        m_vToolTimer.Stop();
+        m_vToolExpTimer.Start(4000L, TRUE);
     }
     }
-    else if (rEvent.GetId() == (int)m_vToolExpTimer.GetTimerId())
+    else if (rEvent.GetId() == m_vToolExpTimer.GetTimerId())
     {
         m_pToolTip->HideToolTipWindow();
     {
         m_pToolTip->HideToolTipWindow();
+        GetParent()->Refresh();
+        m_vToolExpTimer.Stop();
     }
 } // end of wxToolBar::OnTimer
 
     }
 } // end of wxToolBar::OnTimer