ToolTip.h 3.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #ifndef ToolTip_H
  2. #define ToolTip_H
  3. #include "Array.h"
  4. #include "Zeichnung.h"
  5. #include <functional>
  6. namespace Framework
  7. {
  8. class Schrift; // Schrift.h
  9. class Bild; // Bild.h
  10. class AlphaFeld; // AlphaFeld.h
  11. class Text; // Text.h
  12. class Rahmen; // Rahmen.h
  13. struct MausEreignis; // MausEreignis.h
  14. class Bildschirm; // Bildschirm.h
  15. class ToolTip : public ZeichnungHintergrund
  16. {
  17. private:
  18. RCArray< Zeichnung > *members;
  19. Punkt size;
  20. double animationSpeed;
  21. double warten;
  22. double wartenCount;
  23. double tval;
  24. bool mausIn;
  25. unsigned char alpha;
  26. bool sichtbar;
  27. bool zeichnen;
  28. bool mausIn2;
  29. Bildschirm *bildschirm;
  30. std::function< void( ToolTip * ) > onShow;
  31. std::function< void( ToolTip * ) > onHide;
  32. public:
  33. // Konstruktor
  34. __declspec( dllexport ) ToolTip( Bildschirm *zSceen );
  35. // Destruktor
  36. __declspec( dllexport ) ~ToolTip();
  37. // Fügt eine Zeichnung zum Tooltip hinzu
  38. // m: die neue Zeichnung
  39. __declspec( dllexport ) void addMember( Zeichnung *m );
  40. // setzt eine Funktion, die aufgerufen wird, sobald der Tooltip angezeigt wird
  41. // onShow: Die Funktion
  42. __declspec( dllexport ) void setShowEvent( std::function< void( ToolTip * ) > onShow );
  43. // setzt eine Funktion, die aufgerufen wird, sobald der Tooltip nicht mehr angezeigt wird
  44. // onShow: Die Funktion
  45. __declspec( dllexport ) void setHideEvent( std::function< void( ToolTip * ) > onHide );
  46. // Setzt die anzahl an Seunden, de gewartet wird bis der Tipp erscheint
  47. // warten: Die Anzahl an Sekunden
  48. __declspec( dllexport ) void setWarten( double warten );
  49. // Legt fest, wie schnell der Tipp erscheint
  50. // speed: Anzahl der Pixel, die pro Sekunde eingeblendet werden. (Standart: 250)
  51. __declspec( dllexport ) void setAnimationSpeed( double speed );
  52. // Legt Fest, ob die Maus in dem Zeichnung ist, zu dem der Tip gehört
  53. // mausIn: 1, wenn die Maus in dem Zeichnung ist. 0 sonst
  54. __declspec( dllexport ) void setMausIn( bool mausIn );
  55. // Setzt den Counter zurück, der zählt, wann der Tipp eingeblendet wird.
  56. __declspec( dllexport ) void wartenReset();
  57. // Legt fest, das das Zeichnung, zu dem der Tip gehört gezeichnet wurde, so dass der Tip auch gezeichnet werden könnte
  58. __declspec( dllexport ) void setZeichnen();
  59. // Aktualisiert den Tip. Wird vom Framework aufgerufen
  60. // tickVal: Die Zeit in sekunden, die seit dem lezten Aufruf dieser Funktion vergangen ist
  61. // return: 1, wenn sich etwas verändert hat und das Bild neu gezeichnet werden muss. 0 sonst
  62. __declspec( dllexport ) bool tick( double tickVal ) override;
  63. // Verarbeitet Maus Nachrichten
  64. // me: Das Ereignis, was durch die Mauseingabe ausgelößt wurde
  65. __declspec( dllexport ) void doMausEreignis( MausEreignis &me ) override;
  66. // Zeichnet den Tip nach zRObj, falls er sichtbar ist und das zugehörige Zeichnung ebenfalls gezeichnet wurde
  67. // zRObj: Das Bild, in welches gezeichnet werden soll
  68. __declspec( dllexport ) void render( Bild &zRObj ) override;
  69. // Gibt einen Zeiger auf den Bildschirm ohne erhöhten Reference Counter zurück, so dem der Tooltip gehört.
  70. __declspec( dllexport ) Bildschirm *zBildschirm() const;
  71. // Erzeugt eine komplette kopie eines tooltips
  72. __declspec( dllexport ) Zeichnung *dublizieren() const override;
  73. // Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  74. // return: 0.
  75. __declspec( dllexport ) Zeichnung *release() override;
  76. };
  77. }
  78. #endif