Fortschritt.h 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. #ifndef Fortschritt_H
  2. #define Fortschritt_H
  3. #include "Zeichnung.h"
  4. namespace Framework
  5. {
  6. class LRahmen; // Rahmen.h
  7. class AlphaFeld; // AlphaFeld.h
  8. class Bild; // Bild.h
  9. class Schrift; // Schrift.h
  10. class FBalken; // aus dieser Datei
  11. // Eine Zeichnung des 2D GuI Frameworks, die einen Fortschrittsbalken zeichnet
  12. class FBalken : public ZeichnungHintergrund
  13. {
  14. public:
  15. class Style : public ZeichnungHintergrund::Style
  16. {
  17. public:
  18. const static __int64 Prozent = 0x001000; // Legt fest, ob eine Prozentangebe gezechnet wird
  19. const static __int64 FRahmen = 0x002000; // Legt fest, ob der vom fortschritt erfasste Teil des Balkens einen eigenen Rahmen hat
  20. const static __int64 FFarbe = 0x004000; // Legt fest, ob der vom fortschritt erfasste Teil des Balkens eine eigene Hintergrund Farbe hat
  21. const static __int64 FBild = 0x008000; // Legt fest, ob der vom fortschritt erfasste Teil des Balkens ein eigenes Hintergrund Bild hat
  22. const static __int64 FAlpha = 0x10000; // Legt fest, ob der vom fortschritt erfasste Teil des Balkens zum zeichnen seines Hintergrundes alpha blending verwendet
  23. const static __int64 FBuffered = 0x20000; // Legt fest, ob der vom fortschritt erfasste Teil des Balkens einen eigenen Frbübergang hat
  24. const static __int64 L_R = 0x0100000; // Legt fest, ob sich der Fortschritt von lenks nach rechts ausbreitet
  25. const static __int64 R_L = 0x0200000; // Legt fest, ob sich der Fortschritt von rechts nach links ausbreitet
  26. const static __int64 U_O = 0x0400000; // Legt fest, ob sich der Fortschritt von unten nach oben ausbreitet
  27. const static __int64 O_U = 0x0800000; // Legt fest, ob sich der Fortschritt von oben nach unten ausbreitet
  28. const static __int64 normal = Sichtbar | Rahmen | Hintergrund | HBild | FRahmen | FBild | L_R | Prozent; // Vereint die Flags Sichtbar, Rahmen, Hintergrund, HBild, FRahmen, FBild, L_R, Prozent
  29. };
  30. private:
  31. __int64 maxAk;
  32. __int64 ak;
  33. LRahmen *fRahmen;
  34. AlphaFeld *fBuffer;
  35. int fBgF;
  36. Bild *fBgBild;
  37. Schrift *schrift;
  38. int schriftFarbe;
  39. unsigned char schriftSize;
  40. int ref;
  41. public:
  42. // Konstruktor
  43. __declspec( dllexport ) FBalken();
  44. // Destructor
  45. __declspec( dllexport ) virtual ~FBalken();
  46. // Setzt die Anzahl an benötigten Operationen um 100% Fortschritt zu erreichen
  47. // ak: Die Anzahl an Operationen
  48. __declspec( dllexport ) void setAktionAnzahl( __int64 ak );
  49. // Legt fest, dass eine bestimmte Anzahl an Operationen seit dem letzten Aufruf der Funktion durchgeführt wurden
  50. // aktionen: Die durchgeführten Operationen. Standartmäßig auf 1
  51. __declspec( dllexport ) void aktionPlus( __int64 aktionen = 1 );
  52. // Setzt alle fertigen Operationen zurück, so dass der Fortschritt wieder von 0% beginnt
  53. __declspec( dllexport ) void reset();
  54. // Setzt einen Zeiger auf den Rahmen, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  55. // ram: Der Rahmen
  56. __declspec( dllexport ) void setFRahmenZ( LRahmen *ram );
  57. // Setzt die Farbe des Rahmens, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  58. // f: Die Farbe im A8R8G8B8 Format
  59. __declspec( dllexport ) void setFRFarbe( int f );
  60. // Setzt die Breite des Rahmens, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  61. // br: Die Breite in Pixeln
  62. __declspec( dllexport ) void setFRBreite( int br );
  63. // Setzt einen Zeiger auf den Farbverlauf, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  64. // af: Der Farbverlauf
  65. __declspec( dllexport ) void setFAlphaFeldZ( AlphaFeld *af );
  66. // Setzt die Farbe des Farbverlaufs, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  67. // f: Die Farbe im A8R8G8B8 Format
  68. __declspec( dllexport ) void setFAFFarbe( int f );
  69. // Setzt die Stärke des Farbverlaufs, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  70. // st: Die Stärke
  71. __declspec( dllexport ) void setFAFStrength( int st );
  72. // Setzt die Hintergrund Farbe, die in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  73. // f: Die Farbe im A8R8G8B8 Format
  74. __declspec( dllexport ) void setFBgFarbe( int f );
  75. // Setzt einen Zeiger auf das Hintergrund Bild, das in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  76. // b: Das Bild
  77. __declspec( dllexport ) void setFBgBildZ( Bild *b );
  78. // Setzt das Hintergrund Bild durch kopieren, das in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  79. // b: Das Bild, das kopiert werden soll
  80. __declspec( dllexport ) void setFBgBild( Bild *b );
  81. // Setzt die Schrift, die verwendet wird, um die Prozentanzeige zu zeichnen
  82. __declspec( dllexport ) void setSchriftZ( Schrift *b );
  83. // Setzt die Farbe der Prozentanzeige
  84. // f: Die Farbe im A8R8G8B8 Format
  85. __declspec( dllexport ) void setSFarbe( int f );
  86. // Setzt die Schriftgröße der Prozentanzeige
  87. // gr: Die Größe einer Zeile in Pixeln
  88. __declspec( dllexport ) void setSSize( unsigned char gr );
  89. // Zeichnet das Objekt nach zRObj, falls es sichtbar ist
  90. // zRObj: Das Bild, in welches gezeichnet werden soll
  91. __declspec( dllexport ) void render( Bild &zRObj ) override;
  92. // Gibt die Anzahl an benötigten Operationen zurück, die für 100% benötigt werden
  93. __declspec( dllexport ) __int64 getAktionAnzahl() const;
  94. // Gibt die momentan erreichte Prozentzahl des Fortschritts zurück
  95. __declspec( dllexport ) double getProzent() const;
  96. // Gibt die Anzahl an fertigen Operationen zurück
  97. __declspec( dllexport ) __int64 getAktion() const;
  98. // Gibt den Rahmen zurück, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  99. __declspec( dllexport ) LRahmen *getFRahmen() const;
  100. // Gibt den Rahmen ohne erhöhten Reference Counter zurück, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  101. __declspec( dllexport ) LRahmen *zFRahmen() const;
  102. // Gibt den Farbübergang zurück, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  103. __declspec( dllexport ) AlphaFeld *getFAlphaFeld() const;
  104. // Gibt den Farbübergang ohne erhöhten Reference Counter zurück, der in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  105. __declspec( dllexport ) AlphaFeld *zFAlphaFeld() const;
  106. // Gibt die Hintergrund Farbe im A8R8G8B8 Format zurück, die in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  107. __declspec( dllexport ) int getFBgFarbe() const;
  108. // Gibt das Hintergrund Bild zurück, das in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  109. __declspec( dllexport ) Bild *getFBgBild() const;
  110. // Gibt das Hintergrund Bild ohne erhöhten Reference COunter zurück, das in dem Teil des Balkens gezeichnet wird, der vom Fortschritt erfasst wurde
  111. __declspec( dllexport ) Bild *zFBgBild() const;
  112. // Gibt die Schrift zurück, die für die Prozentanzeige verwendet wird
  113. __declspec( dllexport ) Schrift *getSchrift() const;
  114. // Gibt die Schrift ohne erhöhten Reference Counter zurück, die für die Prozentanzeige verwendet wird
  115. __declspec( dllexport ) Schrift *zSchrift() const;
  116. // Gibt die Farbe der Prozentanzeige im A8R8G8B8 Format zurück
  117. __declspec( dllexport ) int getSFarbe() const;
  118. // Erhöht den Reference Counting Zähler.
  119. // return: this.
  120. __declspec( dllexport ) FBalken *getThis();
  121. // Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Objekt automatisch gelöscht.
  122. // return: 0.
  123. __declspec( dllexport ) FBalken *release();
  124. };
  125. }
  126. #endif