DateiSystem.h 28 KB

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