DateiSystem.h 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637
  1. #ifndef DateiSystem_H
  2. #define DateiSystem_H
  3. #include <fstream>
  4. #include "Array.h"
  5. #include "Punkt.h"
  6. namespace Framework
  7. {
  8. class Bild; //! Bild.h
  9. class Text; //! Text.h
  10. class FBalken; //! Fortschritt.h
  11. #ifdef WIN32
  12. class Buchstabe; //! Schrift.h
  13. class Alphabet; //! Schrift.h
  14. class Schrift; //! Schrift.h
  15. #endif
  16. class LTDBPixel; //! aus dieser Datei
  17. class LTDBKopf; //! aus dieser Datei
  18. class LTDBBody; //! aus dieser Datei
  19. class LTDBDatei; //! aus dieser Datei
  20. class LTDSPixel; //! aus dieser Datei
  21. #ifdef WIN32
  22. class LTDSDateiKopf; //! aus dieser Datei
  23. class LTDSSchriftKopf; //! aus dieser Datei
  24. class LTDSBuchstabenKopf; //! aus dieser Datei
  25. class LTDSBuchstabenKörper; //! aus dieser Datei
  26. class LTDSDatei; //! aus dieser Datei
  27. #endif
  28. //! LTDB Dateivormat --- Dient zum speichern von mehreren Bildern in einer Datei.
  29. //! Dient zum Speichern und Laden eines einzelnen Pixels aus einem Bild im LTDB Dateiformat
  30. class LTDBPixel //! Pixel einer LTDB Datei
  31. {
  32. private:
  33. LTDBPixel *davor; //! Letzter Pixel
  34. char index; //! Bitlänge des Pixels
  35. char iR, iG, iB, iA;
  36. char miR, miG, miB, miA;
  37. char maxIndex; //! Länge des Pixels
  38. bool change : 1; //! Verändert sich etwas an den volgenden 5 Variablen
  39. bool changeR : 1; //! Ändert sich Rot
  40. bool changeG : 1; //! Ändert sich Grün
  41. bool changeB : 1; //! Ändert sich Blau
  42. bool changeA : 1; //! Ändert sich Alpha
  43. unsigned char komp : 3; //! Komprimierung der Farbwerte
  44. unsigned char R; //! Rot
  45. unsigned char G; //! Grün
  46. unsigned char B; //! Blau
  47. unsigned char A; //! Alpha
  48. bool addBitZuFarbe( unsigned char bit ); //! Fügt den Farbwerten ein Bit hinzu
  49. bool getNextFarbeBit( char &byte, int i ); //! Speichert das nächste Farbbit in byte
  50. int ref;
  51. public:
  52. //! Konstruktor
  53. //! \param davor Der Pixel, der Vorher geladen wurde. 0, falls dieß der Erste Pixel ist
  54. __declspec( dllexport ) LTDBPixel( LTDBPixel *davor );
  55. //! Destruktor
  56. __declspec( dllexport ) ~LTDBPixel();
  57. //! zum Laden gedacht. Fügt dem Pixel einiege bits hinzu
  58. //! \param byte Das zuletzt aus der Datei gelesene Byte
  59. //! \param begin Der Index des ersten Bits im byte, wo der Pixel beginnt
  60. //! \return Der Index des Bits im Byte, wo der Pixel aufgehöhrt hat. -1, falls der Pixel am ende Des Bytes noch nicht zuende ist
  61. __declspec( dllexport ) char addByte( char byte, char begin );
  62. //! zum speichern gedacht. Setzt die Farbe, die im Pixel gespeichert werden soll
  63. //! \param f Die zu speichernde Farbe
  64. __declspec( dllexport ) void setFarbe( int f );
  65. //! Komprimiert den Pixel. Muss vor dem Speichern aufgerufen werden.
  66. __declspec( dllexport ) void komprimieren();
  67. //! Gibt ein Teil der Bits zurück, die den Pixel representieren
  68. //! \param byte Eine Referens auf das Byte, dass als nächstes gespeichert werden soll
  69. //! \param begin Der Index des ersten Bits im zu speichernden Byte, wo der Pixel gespeichert werden soll
  70. //! \return Der Index des Bits im zu speichernden Byte, wo der Pixel aufhöhrt. -1, falls der Pixel im nächsten Byte fortgesetzt werden muss
  71. __declspec( dllexport ) char getNextByte( char &byte, int begin );
  72. //! Gibt den Farbwert des Pixels zurück
  73. __declspec( dllexport ) int zuFarbe() const;
  74. //! Gibt zurück, ob sich der Anteil an Rot in der Farbe im Vergleich zum Pixel davor geändert hat
  75. __declspec( dllexport ) bool getChangeR() const;
  76. //! Gibt zurück, ob sich der Anteil an Grün in der Farbe im Vergleich zum Pixel davor geändert hat
  77. __declspec( dllexport ) bool getChangeG() const;
  78. //! Gibt zurück, ob sich der Anteil an Blau in der Farbe im Vergleich zum Pixel davor geändert hat
  79. __declspec( dllexport ) bool getChangeB() const;
  80. //! Gibt zurück, ob sich der Anteil an Alpha in der Farbe im Vergleich zum Pixel davor geändert hat
  81. __declspec( dllexport ) bool getChangeA() const;
  82. //! Gibt die Komprimierung des Pixels zurück
  83. __declspec( dllexport ) unsigned char getKomp() const;
  84. //! Gibt den Anteil an Rot in der Farbe des Pixels zurück
  85. __declspec( dllexport ) unsigned char getR() const;
  86. //! Gibt den Anteil an Grün in der Farbe des Pixels zurück
  87. __declspec( dllexport ) unsigned char getG() const;
  88. //! Gibt den Anteil an Blau in der Farbe des Pixels zurück
  89. __declspec( dllexport ) unsigned char getB() const;
  90. //! Gibt den Anteil an Alpha in der Farbe des Pixels zurück
  91. __declspec( dllexport ) unsigned char getA() const;
  92. //! Erhöht den Reference Counting Zähler.
  93. //! \return this.
  94. __declspec( dllexport ) LTDBPixel *getThis();
  95. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  96. //! \return 0.
  97. __declspec( dllexport ) LTDBPixel *release();
  98. };
  99. //! Der Kopf des LTDB Dateiformates. Hier werden informationen über alle Abgespeicherten Bilder verwaltet
  100. class LTDBDateiKopf
  101. {
  102. private:
  103. RCArray< Text > *bilder;
  104. Array< __int64 > *pos;
  105. int bAnzahl;
  106. int ref;
  107. public:
  108. //! konstructor
  109. __declspec( dllexport ) LTDBDateiKopf();
  110. //! destructor
  111. __declspec( dllexport ) ~LTDBDateiKopf();
  112. //! Entfernt ein Bild aus dem Dateikopf
  113. //! \param i Der Index des Bildes, welches entfernt werden soll
  114. __declspec( dllexport ) void removeBild( int i );
  115. //! Entfernt ein Bild aus dem Dateikopf
  116. //! \param txt Der Name des Bildes, welches entfernt werden soll
  117. __declspec( dllexport ) void removeBild( Text *txt );
  118. //! Fügt dem Dateikopf ein Bild hinzu
  119. //! \param txt Der Name des Bildes.
  120. __declspec( dllexport ) void addBild( Text *txt );
  121. //! Legt den Index des Bytes aus der Datei fest, wo das Bild anfängt
  122. //! \param i Der index Des Bildes
  123. //! \param pos Die Position des Bildes in der Datei
  124. __declspec( dllexport ) void setBildPos( int i, __int64 pos );
  125. //! Legt den Index des Bytes aus der Datei fest, wo das Bild anfängt
  126. //! \param txt Der Name Des Bildes
  127. //! \param pos Die Position des Bildes in der Datei
  128. __declspec( dllexport ) void setBildPos( Text *txt, __int64 pos );
  129. //! Lädt den Dateikopf einer LTDB Datei
  130. //! \param f Ein Zeiger auf einen Fortschrittsbalken, der zum Laden verwendet werden soll. Kann 0 sein.
  131. //! \param inF Der geöffnete ifstream der LTDB Datei, bei dem die Leseposition bereits auf das erste Byte des Dateiopfes zeigt.
  132. __declspec( dllexport ) void laden( FBalken *f, std::ifstream *inF );
  133. //! Speichert den Dateikopf in einer LTDB Datei
  134. //! \param outF Der geöffnete ofstream der LTDB Datei, bei dem die Schreibposition bereits auf das erste Byte des Dateikopfes zeigt.
  135. __declspec( dllexport ) void speichern( std::ofstream *outF ) const;
  136. //! Gibt den Namen eines bestimmten Bildes zurück
  137. //! \param i Der Index des Bildes, dessen Namen zurückgegeben werden soll
  138. //! \return Der Name des bildes
  139. __declspec( dllexport ) Text *getBild( int i ) const;
  140. //! Gibt den Namen eines bestimmten Bildes zurück
  141. //! \param i Der Index des Bildes, dessen Namen zurückgegeben werden soll
  142. //! \return Der Name des bildes ohne erhöhten Reference Counter
  143. __declspec( dllexport ) Text *zBild( int i ) const;
  144. //! Gibt den Index des Ersten Bytes eines Bildes in der Datei zurück
  145. //! \param txt Der Name des Bildes, dessen Beginn gefunden werden soll
  146. //! \return -1, falls das Bild nicht gefunden wurde.
  147. __declspec( dllexport ) __int64 getBildPosition( Text *txt ) const;
  148. //! Gibt den Index des Ersten Bytes eines Bildes in der Datei zurück
  149. //! Fals der Index nicht existiert wird die Exception std::out_of_range geworfen.
  150. //! \param indes Der Indes des Bildes, dessen Beginn gefunden werden soll
  151. __declspec( dllexport ) __int64 getBildPosition( int index ) const;
  152. //! Gibt den Index eines Bestimmten Bildes zurück
  153. //! \param txt Der Name des Bildes
  154. //! \return -1, falls das Bild nicht gefunden wurde
  155. __declspec( dllexport ) int getBildIndex( Text *txt ) const;
  156. //! Gibt die Anzahl der Bilder in der Datei zurück
  157. __declspec( dllexport ) int getbAnzahl() const;
  158. //! Gibt eine Liste mit Bildern in der Datei ohne erhöhten Reference Counter zurück.
  159. //! Die Liste sollte nicht verändert werden
  160. __declspec( dllexport ) RCArray< Text > *zBildListe() const;
  161. //! Erhöht den Reference Counting Zähler.
  162. //! \return this.
  163. __declspec( dllexport ) LTDBDateiKopf *getThis();
  164. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  165. //! \return 0.
  166. __declspec( dllexport ) LTDBDateiKopf *release();
  167. };
  168. //! Die im LTDB Dateikopf gespeicherten Informationen für ein einzelnes Bild
  169. class LTDBKopf
  170. {
  171. private:
  172. __int64 a; //! Det LTDB Dateikopf ist maximal 104 Bits lang
  173. __int32 b; //! - bis zu 75 Bits für den Titel
  174. __int8 c; //! - 12 Bits für breite
  175. int ref; //! - 12 Bits för höhe
  176. public:
  177. //! Konstruktor
  178. __declspec( dllexport ) LTDBKopf();
  179. //! Lähdt die Informationen über ein Bild
  180. //! \param f Der geöffnette und an die richtiege Stelle zeigende ifstream der LTDB Datei
  181. __declspec( dllexport ) void laden( std::ifstream *f );
  182. //! Setzt die Informationen die gespeichert werden sollen
  183. //! \param titel Der Titel des Bildes
  184. //! \param size Die Größe des Bildes
  185. //! \return Die Anzahl der Buchstaben aus dem Titel, die im LTDB Dateiformat nicht gespeichert werden können. Erlaubt ist nur a-z und A-Z und ä ü ö ß und Ä Ü Ö und .
  186. //! Alle großbuchstaben im Titel werden in Kleinbuchstaben umgewandelt
  187. __declspec( dllexport ) int Init( Text *titel, const Punkt &size );
  188. //! Lähd informationen aus geladenen Bits. Wird von der laden( std::ifstream ) Funktion verwendet.
  189. //! \param BeginBit Der Index des ersten Bits, welches ausgewertet werden soll
  190. //! \param EndBit Der Index des letzten Bits, welches nichtmehr ausgewertet werden soll
  191. //! \param bits Die Bits, von denen alle von BeginBit bis EndBit ausgewertet werden sollen
  192. //! Insgesamt müssen 104 Bits gesetzt werden. Hierauf bezihen sich BeginBit und EndBit
  193. __declspec( dllexport ) void setBits( int BeginBit, int EndBit, __int16 bits );
  194. //! Speichert die Informationen in eine Datei
  195. //! \param f Der geöffnete und an die richtiege Stelle zeigende ofstream der LTDB Datei
  196. __declspec( dllexport ) void speichern( std::ofstream *f ) const;
  197. //! Gibt die Länge des Titels zurück
  198. __declspec( dllexport ) int getTitelLength() const;
  199. //! Gibt den Titel des Bildes zurück
  200. __declspec( dllexport ) Text *getTitel() const;
  201. //! Gibt die Größe des Bildes zurück
  202. __declspec( dllexport ) Punkt getSize() const;
  203. //! Gibt die nächsten zu speichernden Bits zurück
  204. //! \param begin Der Index des ersten Bits, in das gespeichert werden soll
  205. //! \param end Der Index des letzten Bits, in das gespeichert werden soll
  206. //! \return 16 Bits, in denen die Informationen zwischen begin und end stehen
  207. //! Insgesamt müssen 104 Bits gelesen werden. Hierauf bezihen sich BeginBit und EndBit
  208. __declspec( dllexport ) __int16 getBits( int begin, int end )const;
  209. //! Erhöht den Reference Counting Zähler.
  210. //! \return this.
  211. __declspec( dllexport ) LTDBKopf *getThis();
  212. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  213. //! \return 0.
  214. __declspec( dllexport ) LTDBKopf *release();
  215. };
  216. //! Verwaltet die Pixeldaten eines einzelnen Bildes einer LTDB Datei
  217. class LTDBBody
  218. {
  219. private:
  220. Punkt gr;
  221. Bild *b;
  222. int dateiSize;
  223. int ref;
  224. public:
  225. //! Konstruktor
  226. __declspec( dllexport ) LTDBBody();
  227. //! Konstruktor
  228. //! \param k Der LTDB Kopf des Bildes, der Informationen über die Größe des Bildes enthält
  229. __declspec( dllexport ) LTDBBody( LTDBKopf *k );
  230. //! Destruktor
  231. __declspec( dllexport ) ~LTDBBody();
  232. //! Setzt die Informationen über die Größe des Bildes. Wird zum Laden benötigt.
  233. //! \param k Der LTDB Kopf des Bildes
  234. __declspec( dllexport ) void init( LTDBKopf k );
  235. //! Setzt die Informationen über die Größe des Bildes. Wird zum Laden benötigt.
  236. //! \param k Der LTDB Kopf des Bildes
  237. __declspec( dllexport ) void init( LTDBKopf *k );
  238. //! Lädt die Pixeldaten aus der Datei
  239. //! \param zF Ein Fortschrittsbalken, der 0 sein kann
  240. //! \param inF Der geöffnete und an die richtiege Stelle zeigende ifstream der LTDB Datei
  241. __declspec( dllexport ) void laden( FBalken *zF, std::ifstream *inF );
  242. //! Setzt das Bild, welches gespeichert werden soll
  243. //! \param b Das zu speichernde Bild
  244. __declspec( dllexport ) void setBild( Bild *b );
  245. //! Speichert die Pixeldaten des Bildes in einer LTDB Datei
  246. //! \param zF Ein Fortschrittsbalken, der 0 sein kann
  247. //! \param outF Der geöffnete und an die richtiege Stelle zeigende ofstream der LTDB Datei
  248. __declspec( dllexport ) void speichern( FBalken *zF, std::ofstream *outF ) const;
  249. //! Gibt das geladene Bild zurück
  250. __declspec( dllexport ) Bild *getBild() const;
  251. //! Gibt die Größe des Bildes zurück
  252. __declspec( dllexport ) const Punkt &getSize() const;
  253. //! Erhöht den Reference Counting Zähler.
  254. //! \return this.
  255. __declspec( dllexport ) LTDBBody *getThis();
  256. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  257. //! \return 0.
  258. __declspec( dllexport ) LTDBBody *release();
  259. };
  260. //! Verwaltet eine LTDB Datei
  261. class LTDBDatei
  262. {
  263. private:
  264. Text *pfad;
  265. LTDBDateiKopf *datKpf;
  266. int ref;
  267. public:
  268. //! Konstruktor
  269. __declspec( dllexport ) LTDBDatei();
  270. //! Destruktor
  271. __declspec( dllexport ) ~LTDBDatei();
  272. //! Setzt den Pfad zu Datei
  273. //! \param pfad Der Pfad
  274. __declspec( dllexport ) void setDatei( Text *pfad );
  275. //! Erstellt eine neue LTDB Datei
  276. __declspec( dllexport ) void erstellen();
  277. //! Ließt grundlegende Informationen aus der Datei.
  278. //! Wird benötigt, bevor mit der Datei gearbeitet wird
  279. //! \param zF Ein Fortschrittsbalken, der 0 sein kann
  280. __declspec( dllexport ) void leseDaten( FBalken *zF );
  281. //! Löscht die LTDB Datei
  282. __declspec( dllexport ) void remove();
  283. //! Löscht ein Bild aus der LTDB Datei
  284. //! \param zF Ein Fortschrittsbalken der 0 sein kann
  285. //! \param name Der Name des zu löschenden Bildes
  286. __declspec( dllexport ) void remove( FBalken *zF, Text *name );
  287. //! Lädt ein Bild aus der LTDB Datei
  288. //! \param zF Ein Fortschrittsbalken, der 0 sein kann
  289. //! \param name Der Name des Bildes, welches geladen werden soll
  290. //! \return Das geladene Bild. 0, falls das Bild nicht gefunden wurde
  291. __declspec( dllexport ) Bild *laden( FBalken *zF, Text *name );
  292. //! Speichert ein neues Bild in der LTDB Datei
  293. //! \param zF Ein Fortscrittsbalken, der 0 sein kann
  294. //! \param bild Das Bild, welches gelöscht werden soll
  295. //! \param name Der Name, unter dem das Bild gespeichert werden soll
  296. //! \return Anzahl der Warnungen, die beim Konvertieren des Namens in einen gültigen Namen aufgetreten sind. -1, falls bereis ein Bild mit dem selben Namen existiert
  297. __declspec( dllexport ) int speichern( FBalken *zF, Bild *bild, Text *name );
  298. //! Gibt eine Liste mit gespeicherten Bildern zurück
  299. //! Die Liste sollte nicht verändert werden
  300. __declspec( dllexport ) RCArray< Text > *zBildListe();
  301. //! Gibt den Pfad zur LTDB Datei zurück
  302. __declspec( dllexport ) Text *getPfad() const;
  303. //! Gibt die Anzahl der Bilder in der LTDB Datei zurück
  304. __declspec( dllexport ) int getBildAnzahl() const;
  305. //! Prüft, ob die LTDB Datei existiert
  306. __declspec( dllexport ) bool istOffen() const;
  307. //! Erhöht den Reference Counting Zähler.
  308. //! \return this.
  309. __declspec( dllexport ) LTDBDatei *getThis();
  310. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  311. //! \return 0.
  312. __declspec( dllexport ) LTDBDatei *release();
  313. };
  314. #ifdef WIN32
  315. //! LTDS Dateivormat --- Dient zum speichern von Schriftarten
  316. //! Verwaltet einen einzelnen Pixel von einem Buchstaben
  317. class LTDSPixel
  318. {
  319. private:
  320. int ref;
  321. char index;
  322. char iA;
  323. char miA;
  324. char maxIndex; //! Länge des Pixels
  325. bool änder;
  326. bool änderA;
  327. unsigned char komp : 3; //! Komprimierung der Farbwerte
  328. unsigned char alpha;
  329. LTDSPixel *davor;
  330. bool addBitZuFarbe( unsigned char bit ); //! Fügt den Farbwerten ein Bit hinzu
  331. bool getNextFarbeBit( char &byte, int i ); //! Speichert das nächste Farbbit in byte
  332. public:
  333. //! Konstruktor
  334. //! \param davor Der Pixel, der vor diesem geladen wurde. 0, fals dieß der erste Pixel ist
  335. __declspec( dllexport ) LTDSPixel( LTDSPixel *davor );
  336. //! Destruktor
  337. __declspec( dllexport ) ~LTDSPixel();
  338. //! Fügt dem Pixel einiege geladene Bits hinzu. Zum Laden gedacht.
  339. //! \param byte Das letzte aus der Datei geladene Byte.
  340. //! \param begin Der Index des ersten Bits im Byte, wo der Pixel beginnt
  341. //! \return Der Index des Letzten Bits in Byte, wo der Pixel aufhöhrt. -1, falls der Pixel im nächsten Byte weitergeht
  342. __declspec( dllexport ) char addByte( char byte, char begin );
  343. //! Setzt den Alpha Wert des Pixels. Zum speichern gedacht.
  344. //! \param alpha Der Alpha Wert des Pixels.
  345. __declspec( dllexport ) void setAlpha( unsigned char alpha );
  346. //! Komprimiert den Pixel. Muss vor dem Speichern aufgerufen werden.
  347. __declspec( dllexport ) void Komp();
  348. //! Gibt ein Teil der Bits zurück, die den Pixel representieren
  349. //! \param byte Eine Referens auf das Byte, dass als nächstes gespeichert werden soll
  350. //! \param begin Der Index des ersten Bits im zu speichernden Byte, wo der Pixel gespeichert werden soll
  351. //! \return Der Index des Bits im zu speichernden Byte, wo der Pixel aufhöhrt. -1, falls der Pixel im nächsten Byte fortgesetzt werden muss
  352. __declspec( dllexport ) char getNextByte( char &byte, int bbegin );
  353. //! Gibt die Komprimierung des Pixels zurück
  354. __declspec( dllexport ) unsigned char getKomp() const;
  355. //! Gibt zurück, ob sich der Alpha Wert im Vergleich zu dem Pixel davor geändert hat
  356. __declspec( dllexport ) bool getÄnderA() const;
  357. //! Gibt den Alpha Wert des Pixels zurück
  358. __declspec( dllexport ) unsigned char getA() const;
  359. //! Erhöht den Reference Counting Zähler.
  360. //! \return this.
  361. __declspec( dllexport ) LTDSPixel *getThis();
  362. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  363. //! \return 0.
  364. __declspec( dllexport ) LTDSPixel *release();
  365. };
  366. //! Verwaltet den Kopf einer LTDS Datei. Er enthält Informationen über die in der Datei gespeicherten Schriftgrößen
  367. class LTDSDateiKopf
  368. {
  369. private:
  370. int ref;
  371. unsigned char sganzahl;
  372. unsigned char *gr;
  373. int *pos;
  374. public:
  375. //! Konstruktor
  376. __declspec( dllexport ) LTDSDateiKopf();
  377. //! Destruktor
  378. __declspec( dllexport ) ~LTDSDateiKopf();
  379. //! Lädt den Kopf aus der LTDS Datei
  380. //! \param inF Der geöffnete und an die richtige Stelle zeigende ifstream der LTDS Datei
  381. __declspec( dllexport ) void laden( std::ifstream *inF );
  382. //! Fügt eine Schriftgröße hinzu
  383. //! \param sg Die Schriftgröße, die hinzugefügt werden soll
  384. __declspec( dllexport ) void addSG( char sg );
  385. //! Löscht eine Schriftgröße
  386. //! \param sg Die Schriftgröße, die gelöscht werden soll
  387. __declspec( dllexport ) void removeSG( char sg );
  388. //! Speichert den LTDS Kopf in der Datei
  389. //! \param outF Der geöffnete und an die richtiege Stelle zeigende ofstream der LTDS Datei
  390. __declspec( dllexport ) void speichern( std::ofstream *outF ) const;
  391. //! Gibt einen Array von gespeicherten Schriftgrößen zurück
  392. //! Der Array sollte nicht verädert werden
  393. __declspec( dllexport ) unsigned char *getSchriftGrößeList() const;
  394. //! Gibt einen Array mit positionen der ersten Bytes für jede Schriftgröße aus der Datei zurück
  395. __declspec( dllexport ) int *getPositionList() const;
  396. //! Gibt die Anzahl der gespeicherten Schriftgrößen zurück
  397. __declspec( dllexport ) int getSchriftGrößeAnzahl() const;
  398. //! Erhöht den Reference Counting Zähler.
  399. //! \return this.
  400. __declspec( dllexport ) LTDSDateiKopf *getThis();
  401. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  402. //! \return 0.
  403. __declspec( dllexport ) LTDSDateiKopf *release();
  404. };
  405. //! Der Kopf einer Schriftgröße. Enthält Informationen über die gespeicherten Zeichen
  406. class LTDSSchriftKopf
  407. {
  408. private:
  409. int ref;
  410. unsigned char schriftSize;
  411. unsigned char *zeichen;
  412. int *pos;
  413. unsigned char zeichenAnzahl;
  414. public:
  415. //! Konstruktor
  416. __declspec( dllexport ) LTDSSchriftKopf();
  417. //! Destruktor
  418. __declspec( dllexport ) ~LTDSSchriftKopf();
  419. //! Lädt den Kopf einer Schriftgröße aus der Datei
  420. //! \param inF Der geöffnete und an de richtiege Stelle zeigende ifstream der LTDS Datei
  421. __declspec( dllexport ) void laden( std::ifstream *inF );
  422. //! Setzt die Schriftgröße. Zum speichern gedacht
  423. //! \param gr Die Schriftgröße
  424. __declspec( dllexport ) void setSchriftgröße( unsigned char gr );
  425. //! Setzt das Alphabet, welches in der Schriftgröße gespeichert werden soll
  426. //! \param alphabet Das Alphabet, welches alle zu speichernden Zeichen in der Schriftgröße enthält
  427. __declspec( dllexport ) void setZeichenAlphabet( Alphabet *alphabet );
  428. //! Fügt der Schriftgröße ein Zeichen hinzu, welches gespeichert werden soll
  429. //! \param zeichen Der ASCII code des Zeichens, welches hinzugefügt werden soll
  430. __declspec( dllexport ) void addZeichen( unsigned char zeichen );
  431. //! Löscht ein Zeichen aus der Schriftgröße
  432. //! \param zeich Der ASCII code des Zeichens, welches gelöscht werden soll
  433. __declspec( dllexport ) void removeZeichen( unsigned char zeich );
  434. //! Speichert den Kopf der Schriftgröße in der LTDS Datei
  435. //! \param outF Der geöffnete und an die richtiege Stelle zeigende ofstream der LTDS Datei
  436. __declspec( dllexport ) void speichern( std::ofstream *outF ) const;
  437. //! Gibt die Schriftgröße zurück, zu der dieser Kopf gehöhrt
  438. __declspec( dllexport ) unsigned char getSchriftGröße() const;
  439. //! Gibt die Anzahl der in der Schriftgröße gespeicherten Zeichen zurück
  440. __declspec( dllexport ) unsigned char getZeichenAnzahl() const;
  441. //! Gibt einen Array mit den Positionen der ersten Bytes von den gespeicherten Zeichen aus der LTDS Datei zurück
  442. __declspec( dllexport ) int *getPositionen() const;
  443. //! Gibt einen Array mit den ASCII codes der Gespeicherten Zeichen zurück
  444. __declspec( dllexport ) unsigned char *getZeichen() const;
  445. //! Erhöht den Reference Counting Zähler.
  446. //! \return this.
  447. __declspec( dllexport ) LTDSSchriftKopf *getThis();
  448. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  449. //! \return 0.
  450. __declspec( dllexport ) LTDSSchriftKopf *release();
  451. };
  452. //! Der Kopf eines einzelnen Zeichens aus der LTDS Datei. Enthält informationen über die Pixelgröße des Zeichens
  453. class LTDSBuchstabenKopf
  454. {
  455. private:
  456. int ref;
  457. unsigned char zeichen;
  458. Punkt size;
  459. public:
  460. //! Konstruktor
  461. __declspec( dllexport ) LTDSBuchstabenKopf();
  462. //! Lädt die Daten aus der LTDS Datei
  463. //! \param inF Der geöffnete und an die richtiege Stelle zeigende ifstream der LTDS Datei
  464. __declspec( dllexport ) void laden( std::ifstream *inF );
  465. //! Setzt die Daten, die gespeichert werden sollen.
  466. //! \param zeichen Der ASCII code des Zeichens
  467. //! \param größe Die Größe des Zeichens in Pixeln
  468. __declspec( dllexport ) void init( unsigned char zeichen, const Punkt &größe );
  469. //! Setzt die Daten, die gespeichert werden sollen.
  470. //! \param zeichen Der ASCII code des Zeichens
  471. //! \param br Die Breite des Zeichens in Pixeln
  472. //! \param hö Die Höhe des Zeichens in Pixeln
  473. __declspec( dllexport ) void init( unsigned char zeichen, int br, int hö );
  474. //! Speichert die Daten in der LTDS Datei
  475. //! \param outF Der geöffnete und auf die richtiege Stelle zeigende ofstream der LTDS Datei
  476. __declspec( dllexport ) void speichern( std::ofstream *outF ) const;
  477. //! Gibt den ASCII code des Zeichens zurück
  478. __declspec( dllexport ) unsigned char getZeichen() const;
  479. //! Gibt die Breite des Zeichens in Pixeln zurück
  480. __declspec( dllexport ) int getBreite() const;
  481. //! Gibt die Höhe des Zeichens in Pixeln zurück
  482. __declspec( dllexport ) int getHöhe() const;
  483. //! Gib t die Größe des Zeichens in Pixeln zurück
  484. __declspec( dllexport ) const Punkt &getGröße() const;
  485. //! Erhöht den Reference Counting Zähler.
  486. //! \return this.
  487. __declspec( dllexport ) LTDSBuchstabenKopf *getThis();
  488. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  489. //! \return 0.
  490. __declspec( dllexport ) LTDSBuchstabenKopf *release();
  491. };
  492. //! Verwaltet die Pixeldaten eines Zeichens
  493. class LTDSBuchstabenKörper
  494. {
  495. private:
  496. int ref;
  497. Punkt size;
  498. unsigned char zeichen;
  499. Buchstabe *buchstabe;
  500. public:
  501. //! Konstruktor
  502. //! \param kopf Der Kopf des Zeichens
  503. __declspec( dllexport ) LTDSBuchstabenKörper( LTDSBuchstabenKopf *kopf );
  504. //! Destruktor
  505. __declspec( dllexport ) ~LTDSBuchstabenKörper();
  506. //! Setzt den Buchstaben, der gespeichert werden soll
  507. //! \param zeichen Der zu speichernde Buchstabe
  508. __declspec( dllexport ) void setBuchstabe( Buchstabe *zeichen );
  509. //! Lädt die Pixel aus der LTDS Datei
  510. //! \param inF Der geöffnete und auf die richtiege Stelle zeigende ifstream der LTDS Datei
  511. __declspec( dllexport ) void laden( std::ifstream *inF );
  512. //! Speichert die Pixel in die LTDS Datei
  513. //! \param outF der geöffnete und an die richtiege Stelle zeigende ofstream der LTDS Datei
  514. __declspec( dllexport ) void speichern( std::ofstream *outF ) const;
  515. //! Gibt den geladenen Buchstaben zurück
  516. __declspec( dllexport ) Buchstabe *getBuchstabe() const;
  517. //! Gibt den ASCII code des Buchstabens zurück
  518. __declspec( dllexport ) unsigned char getZeichen() const;
  519. //! Erhöht den Reference Counting Zähler.
  520. //! \return this.
  521. __declspec( dllexport ) LTDSBuchstabenKörper *getThis();
  522. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  523. //! \return 0.
  524. __declspec( dllexport ) LTDSBuchstabenKörper *release();
  525. };
  526. //! Verwaltet eine LTDS Datei
  527. class LTDSDatei
  528. {
  529. private:
  530. int ref;
  531. Text *pfad;
  532. LTDSDateiKopf *dateiKopf;
  533. public:
  534. //! Konstruktor
  535. __declspec( dllexport ) LTDSDatei();
  536. //! Destruktor
  537. __declspec( dllexport ) ~LTDSDatei();
  538. //! Setzt den Pfad zur Datei
  539. //! \param txt Der Pfad
  540. __declspec( dllexport ) void setPfad( Text *txt );
  541. //! Lädt wichtiege Informationen aus der Datei. Muss vor dem Verwenden der Datei aufgerufen werden
  542. __declspec( dllexport ) void leseDaten();
  543. //! Fügt der Datei eine Schriftgröße hinzu, fals diese noch nicht existiert
  544. //! \param alphabet Das Alphabet, welches die Zeichen in der gewünschten Schriftgrö0e enthält
  545. __declspec( dllexport ) void addSchriftgröße( Alphabet *alphabet );
  546. //! Fügt einer Schriftgröße einen Buchstaben hinzu
  547. //! \param gr Die Schriftgröße des Buchstabens
  548. //! \param zeich Der Buchstabe, der gespeichert werden soll
  549. //! \param zeichen Der ASCII code des Buchstabens
  550. __declspec( dllexport ) void addBuchstabe( int gr, Buchstabe *zeich, unsigned char zeichen );
  551. //! Löscht eine bestimmte Schriftgröße aus der Datei
  552. //! \param gr Die Schriftgröße, die entfernt werden soll
  553. __declspec( dllexport ) void löscheSchrifrGröße( int gr );
  554. //! Löscht einen Buchstaben aus einer Schriftgröße
  555. //! \param gr Die Schriftgröße, aus der der Buchstabe entfernt werden soll
  556. //! \param zeichen Der ASCII code des Zeichens, welches gelöscht werden soll
  557. __declspec( dllexport ) void löscheBuchstabe( int gr, unsigned char zeichen );
  558. //! Löscht die LTDS Datei
  559. __declspec( dllexport ) void löscheDatei();
  560. //! Erstellt die LTDS Datei
  561. __declspec( dllexport ) void erstelleDatei();
  562. //! Speichert eine gesammte Schrift in der Datei
  563. //! \param schrift Die schrift, die gespeichert werden soll
  564. __declspec( dllexport ) void speicherSchrift( Schrift *schrift );
  565. //! Lädt die gesammte Schrift aus der Datei
  566. //! \return Die geladene Schrift. 0, falls ein Fehler beim Laden aufgetreten ist
  567. __declspec( dllexport ) Schrift *ladeSchrift();
  568. //! Lädt eine einzelne Schriftgröße aus der Datei
  569. //! \param schriftgröße Die zu ladende Schriftgröße
  570. //! \return Ein Alphabet mit den Zeichen in der Schriftgröße. 0, falls die Schriftgröße nicht gefunden wurde
  571. __declspec( dllexport ) Alphabet *ladeAlphabet( int schriftgröße );
  572. //! Lädt ein bestimmtes Zeichen einer bestimmten Schriftgröße
  573. //! \param schriftgröße Die Schriftgröße, zu dem das Zeichen gehört
  574. //! \param zeichen Der ASCII code des zu ladenden Zeichens
  575. //! \return Der geladene Buchstabe. 0, falls das Zeichen nicht gefunden wurde.
  576. __declspec( dllexport ) Buchstabe *ladeBuchstabe( int schriftgröße, unsigned char zeichen );
  577. //! Gibt den Pfad zur LTDS Datei zurück
  578. __declspec( dllexport ) Text *getPfad() const;
  579. //! Gibt die Anzahl der gespeicherten Schriftgrößen zurück
  580. __declspec( dllexport ) int getAnzahlSchriftgrößen() const;
  581. //! Gibt einen Array mit den gespeicherten Schriftgrößen zurück
  582. //! Der Array sollte nicht verändert werden
  583. __declspec( dllexport ) unsigned char *getSchriftGrößen() const;
  584. //! Gibt die Anzahl an gespeicherten Zeichen in einer Schriftgröße zurück
  585. //! \param sg Die Schriftgröße, von der die Anzahl der ZEichen ermittelt werden soll
  586. //! \return Die Anzahl der Zeichen.
  587. __declspec( dllexport ) unsigned char getAnzahlBuchstaben( int sg );
  588. //! Gibt einen Array mit Buchstaben einer bestimmten Schriftgröße zurück
  589. //! \param sg Die Schriftgröße
  590. //! \return Der Array mit den ASCII codes der Zeichen. 0, falls die Schriftgröße nicht gefunden wurde.
  591. __declspec( dllexport ) unsigned char *getBuchstaben( int sg );
  592. //! Erhöht den Reference Counting Zähler.
  593. //! \return this.
  594. __declspec( dllexport ) LTDSDatei *getThis();
  595. //! Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  596. //! \return 0.
  597. __declspec( dllexport ) LTDSDatei *release();
  598. };
  599. #endif
  600. //! Bit Funktionen
  601. //! gibt 1-bits in gewinschter anzahl zurück.
  602. //! \param a Die Anzahl der Bits, die 1 sein sollen
  603. //! \return 32 Bits, wobei die einser Bits von rechts beginnen
  604. __declspec( dllexport ) int Bits( int a );
  605. //! Gibt zurück, wie viele Bits benötigt werden um eine Zahl darzustellen
  606. //! \param c Die Zahl, die dargestellt werden soll
  607. //! \return Die Anzahl der benötigten Bits
  608. __declspec( dllexport ) int getBits( char c );
  609. }
  610. #endif