DateiSystem.h 28 KB

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