Browse Source

ToolTip sichtbarkeit und mausereignis verarbeitungsreihenfolge angepasst

Kolja Strohm 6 years ago
parent
commit
277c4e8254
3 changed files with 9 additions and 7 deletions
  1. 4 4
      Bildschirm.cpp
  2. 1 1
      ToolTip.cpp
  3. 4 2
      Zeichnung.cpp

+ 4 - 4
Bildschirm.cpp

@@ -210,7 +210,7 @@ void Bildschirm::doMausEreignis( MausEreignis &me ) // sendet maus Ereignis
     lock();
     lock();
     if( !renderOnTop )
     if( !renderOnTop )
     {
     {
-        for( int i = 0; i < tipAnzahl; ++i )
+        for( int i = tipAnzahl - 1; i >= 0; i-- )
             tips->z( i )->doMausEreignis( me );
             tips->z( i )->doMausEreignis( me );
         for( int i = members->getEintragAnzahl() - 1; i >= 0; i-- )
         for( int i = members->getEintragAnzahl() - 1; i >= 0; i-- )
             members->z( i )->doMausEreignis( me );
             members->z( i )->doMausEreignis( me );
@@ -218,7 +218,7 @@ void Bildschirm::doMausEreignis( MausEreignis &me ) // sendet maus Ereignis
     else if( onTop )
     else if( onTop )
     {
     {
         onTop->doMausEreignis( me );
         onTop->doMausEreignis( me );
-        for( int i = 0; i < tipAnzahl; ++i )
+        for( int i = tipAnzahl - 1; i >= 0; i-- )
             tips->z( i )->doMausEreignis( me );
             tips->z( i )->doMausEreignis( me );
     }
     }
     unlock();
     unlock();
@@ -232,8 +232,8 @@ void Bildschirm::doTastaturEreignis( TastaturEreignis &te ) // sendet tastatur E
         for( int i = members->getEintragAnzahl() - 1; i >= 0; i-- )
         for( int i = members->getEintragAnzahl() - 1; i >= 0; i-- )
             members->z( i )->doTastaturEreignis( te );
             members->z( i )->doTastaturEreignis( te );
     }
     }
-    else if( onTop )
-        onTop->doTastaturEreignis( te );
+    for( int i = tipAnzahl - 1; i >= 0; i-- )
+        tips->z( i )->doTastaturEreignis( te );
     unlock();
     unlock();
 }
 }
 
 

+ 1 - 1
ToolTip.cpp

@@ -177,7 +177,7 @@ void ToolTip::doMausEreignis( MausEreignis &me )
 
 
 void ToolTip::render( Bild &zRObj )
 void ToolTip::render( Bild &zRObj )
 {
 {
-    if( alpha && zeichnen )
+    if( alpha && ( zeichnen || mausIn2 ) )
     {
     {
         zRObj.setAlpha( alpha );
         zRObj.setAlpha( alpha );
         setPosition( pos );
         setPosition( pos );

+ 4 - 2
Zeichnung.cpp

@@ -177,6 +177,8 @@ void Zeichnung::doMausEreignis( MausEreignis &me ) // ruft Mak auf
         me2.verarbeitet = 0;
         me2.verarbeitet = 0;
         doMausEreignis( me2 );
         doMausEreignis( me2 );
     }
     }
+    if( mausIn && toolTip )
+        toolTip->setMausIn( 1 );
     me.mx -= pos.x, me.my -= pos.y;
     me.mx -= pos.x, me.my -= pos.y;
     if( mak )
     if( mak )
         me.verarbeitet |= mak( makParam, this, me );
         me.verarbeitet |= mak( makParam, this, me );
@@ -249,7 +251,7 @@ bool Zeichnung::tick( double tickval )
 {
 {
     while( !actions.empty() )
     while( !actions.empty() )
     {
     {
-        actions.front()();
+        actions.front()( );
         actions.pop();
         actions.pop();
     }
     }
     bool r = rend;
     bool r = rend;
@@ -363,7 +365,7 @@ int Zeichnung::getY() const // gibt Y zur
 
 
 ToolTip *Zeichnung::getToolTip() const // gibt den ToolTip Text
 ToolTip *Zeichnung::getToolTip() const // gibt den ToolTip Text
 {
 {
-    return ( ToolTip*)toolTip->getThis();
+    return (ToolTip*)toolTip->getThis();
 }
 }
 
 
 ToolTip *Zeichnung::zToolTip() const
 ToolTip *Zeichnung::zToolTip() const