summaryrefslogtreecommitdiffstats
path: root/ktouch/src/ktouchlecture.h
diff options
context:
space:
mode:
Diffstat (limited to 'ktouch/src/ktouchlecture.h')
-rw-r--r--ktouch/src/ktouchlecture.h82
1 files changed, 82 insertions, 0 deletions
diff --git a/ktouch/src/ktouchlecture.h b/ktouch/src/ktouchlecture.h
new file mode 100644
index 00000000..3c59ee08
--- /dev/null
+++ b/ktouch/src/ktouchlecture.h
@@ -0,0 +1,82 @@
+/***************************************************************************
+ * ktouchlecture.h *
+ * --------------- *
+ * Copyright (C) 2000 by Håvard Frøiland, 2003 by Andreas Nicolai *
+ * *
+ * This program is free software; you can redistribute it and/or modify *
+ * it under the terms of the GNU General Public License as published by *
+ * the Free Software Foundation; either version 2 of the License, or *
+ * (at your option) any later version. *
+ ***************************************************************************/
+
+#ifndef KTOUCHLECTURE_H
+#define KTOUCHLECTURE_H
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+class QWidget;
+class QDomDocument;
+class KURL;
+
+#include <qvaluevector.h>
+#include "ktouchleveldata.h"
+
+/// This class handles the lecture data and provides the lines to type.
+///
+/// It contains the level data (see KTouchLevelData). A lecture object
+/// contains <b>ALWAYS</b> at least one lecture.<p>
+/// The lecture data can be read and written using the member functions
+/// readLecture() and writeLecture().<p>
+/// During a training session the program will occasionally need a new
+/// line of text. You can retrieve the data of a certain level using
+/// the member function level() and then the line in this level (see
+/// KTouchLevelData).
+class KTouchLecture {
+ public:
+ /// Default Constructor
+ KTouchLecture() { createDefault(); }
+ /// Creates a default mini-lecture.
+ void createDefault();
+ /// Loads a lecture from file (returns true if successful).
+ bool load(QWidget * window, const KURL& url);
+ /// Loads a lecture (in XML format) from file (returns true if successful).
+ bool loadXML(QWidget * window, const KURL& url);
+ // /// Saves the lecture data to file (returns true if successful).
+ // bool save(QWidget * window, const KURL& url) const;
+ /// Saves the lecture data to file (returns true if successful).
+ bool saveXML(QWidget * window, const KURL& url) const;
+ /// Returns the number of levels in the lecture.
+ unsigned int levelCount() const { return m_lectureData.size(); }
+ /// Returns a reference to the data of the level.
+ /// If the level number is out of range the function will always return
+ /// the level 0.
+ const KTouchLevelData& level(unsigned int levelNum) const;
+ /// Returns the title of the lecture.
+ const QString& title() const { return m_title; }
+ /// Sets the title of the lecture.
+ void setTitle(const QString& title) { m_title = title; }
+
+ QString m_title; ///< The title of the lecture.
+ QString m_comment; ///< A comment.
+ QString m_fontSuggestions; ///< Font suggestions for this lecture.
+
+ private:
+ /// Loads a lecture from file
+ bool readLecture(QTextStream& in);
+ /// Loads a lecture from file into an XML document
+ bool readLecture(QDomDocument& doc);
+ /// Saves the lecture data to the current lecture URL
+ void writeLecture(QTextStream& out) const;
+ /// Saves the lecture data in the XML document
+ void writeLecture(QDomDocument& doc) const;
+
+ QValueVector<KTouchLevelData> m_lectureData; ///< The lecture data.
+
+ /// The editor should be able to handle the internal lecture data (it's for convenience actually).
+ friend class KTouchLectureEditor;
+};
+
+#endif // KTOUCHLECTURE_H