]> git.sesse.net Git - kdenlive/blob - src/kdenlivedoc.h
Small cleanup + comment
[kdenlive] / src / kdenlivedoc.h
1 /***************************************************************************
2  *   Copyright (C) 2007 by Jean-Baptiste Mardelle (jb@kdenlive.org)        *
3  *                                                                         *
4  *   This program is free software; you can redistribute it and/or modify  *
5  *   it under the terms of the GNU General Public License as published by  *
6  *   the Free Software Foundation; either version 2 of the License, or     *
7  *   (at your option) any later version.                                   *
8  *                                                                         *
9  *   This program is distributed in the hope that it will be useful,       *
10  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
11  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
12  *   GNU General Public License for more details.                          *
13  *                                                                         *
14  *   You should have received a copy of the GNU General Public License     *
15  *   along with this program; if not, write to the                         *
16  *   Free Software Foundation, Inc.,                                       *
17  *   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA          *
18  ***************************************************************************/
19
20
21 #ifndef KDENLIVEDOC_H
22 #define KDENLIVEDOC_H
23
24 #include <qdom.h>
25 #include <QString>
26 #include <QMap>
27 #include <QList>
28 #include <QDir>
29 #include <QObject>
30 #include <QUndoGroup>
31 #include <QUndoStack>
32 #include <QTimer>
33
34 #include <KUrl>
35 #include <kautosavefile.h>
36
37 #include "gentime.h"
38 #include "timecode.h"
39 #include "definitions.h"
40 #include "guide.h"
41
42 class Render;
43 class ClipManager;
44 class DocClipBase;
45 class MainWindow;
46 class TrackInfo;
47
48 class KTextEdit;
49 class KProgressDialog;
50
51 class KdenliveDoc: public QObject
52 {
53 Q_OBJECT public:
54
55     KdenliveDoc(const KUrl &url, const KUrl &projectFolder, QUndoGroup *undoGroup, QString profileName, const QPoint tracks, Render *render, KTextEdit *notes, MainWindow *parent = 0, KProgressDialog *progressDialog = 0);
56     ~KdenliveDoc();
57     QDomNodeList producersList();
58     double fps() const;
59     int width() const;
60     int height() const;
61     KUrl url() const;
62     KAutoSaveFile *m_autosave;
63     Timecode timecode() const;
64     QDomDocument toXml();
65     //void setRenderer(Render *render);
66     QUndoStack *commandStack();
67     QString producerName(const QString &id);
68     Render *renderer();
69     QDomDocument m_guidesXml;
70     QDomElement guidesXml() const;
71     ClipManager *clipManager();
72
73     /** @brief Adds a clip to the project tree.
74      * @return false if the user aborted the operation, true otherwise */
75     bool addClip(QDomElement elem, QString clipId, bool createClipItem = true);
76
77     /** @brief Updates information about a clip.
78      * @param elem the <kdenlive_producer />
79      * @param orig the potential <producer />
80      * @param clipId the producer id
81      * @return false if the user aborted the operation (in case the clip wasn't
82      *     there yet), true otherwise
83      *
84      * If the clip wasn't added before, it tries to add it to the project. */
85     bool addClipInfo(QDomElement elem, QDomElement orig, QString clipId);
86     void slotAddClipFile(const KUrl url, const QString group, const QString &groupId = QString());
87     void slotAddClipList(const KUrl::List urls, const QString group, const QString &groupId = QString());
88     void deleteClip(const QString &clipId);
89     int getFramePos(QString duration);
90     DocClipBase *getBaseClip(const QString &clipId);
91     void updateClip(const QString id);
92
93     /** @brief Informs Kdenlive of the audio thumbnails generation progress. */
94     void setThumbsProgress(const QString &message, int progress);
95     const QString &profilePath() const;
96     MltVideoProfile mltProfile() const;
97     const QString description() const;
98     void setUrl(KUrl url);
99
100     /** @brief Updates the project profile.
101      * @return true if frame rate was changed */
102     bool setProfilePath(QString path);
103     const QString getFreeClipId();
104
105     /** @brief Defines whether the document needs to be saved. */
106     bool isModified() const;
107
108     /** @brief Returns the project folder, used to store project files. */
109     KUrl projectFolder() const;
110     void syncGuides(QList <Guide *> guides);
111     void setZoom(int horizontal, int vertical);
112     QPoint zoom() const;
113     double dar() const;
114     double projectDuration() const;
115     bool saveSceneList(const QString &path, const QString &scene);
116     int tracksCount() const;
117     TrackInfo trackInfoAt(int ix) const;
118     void insertTrack(int ix, TrackInfo type);
119     void deleteTrack(int ix);
120     void setTrackType(int ix, TrackInfo type);
121     const QList <TrackInfo> tracksList() const;
122
123     /** @brief Gets the number of audio and video tracks and returns them as a QPoint with x = video, y = audio. */
124     QPoint getTracksCount() const;
125
126     void switchTrackVideo(int ix, bool hide);
127     void switchTrackAudio(int ix, bool hide);
128     void switchTrackLock(int ix, bool lock);
129     void cachePixmap(const QString &fileId, const QPixmap &pix) const;
130     void setProjectFolder(KUrl url);
131     QString getLadspaFile() const;
132     void setZone(int start, int end);
133     QPoint zone() const;
134     int setSceneList();
135     bool isTrackLocked(int ix) const;
136     void setDocumentProperty(const QString &name, const QString &value);
137     const QString getDocumentProperty(const QString &name) const;
138
139     /** @brief Gets the list of renderer properties saved into the document. */
140     QMap <QString, QString> getRenderProperties() const;
141     void addTrackEffect(int ix, QDomElement effect);
142     void removeTrackEffect(int ix, QDomElement effect);
143     void setTrackEffect(int trackIndex, int effectIndex, QDomElement effect);
144     const EffectsList getTrackEffects(int ix);
145     QDomElement getTrackEffect(int trackIndex, int effectIndex) const;
146
147 private:
148     KUrl m_url;
149     QDomDocument m_document;
150     double m_fps;
151     int m_width;
152     int m_height;
153     Timecode m_timecode;
154     Render *m_render;
155     KTextEdit *m_notesWidget;
156     QUndoStack *m_commandStack;
157     ClipManager *m_clipManager;
158     MltVideoProfile m_profile;
159     QTimer *m_autoSaveTimer;
160     QString m_searchFolder;
161
162     /** @brief Tells whether the current document has been changed after being saved. */
163     bool m_modified;
164
165     /** @brief The project folder, used to store project files (titles, effects...). */
166     KUrl m_projectFolder;
167     QMap <QString, QString> m_documentProperties;
168
169     QList <TrackInfo> m_tracksList;
170     void setNewClipResource(const QString &id, const QString &path);
171     QString searchFileRecursively(const QDir &dir, const QString &matchSize, const QString &matchHash) const;
172     void moveProjectData(KUrl url);
173     bool checkDocumentClips(QDomNodeList infoproducers);
174
175     /** @brief Creates a new project. */
176     QDomDocument createEmptyDocument(int videotracks, int audiotracks);
177     QDomDocument createEmptyDocument(QList <TrackInfo> tracks);
178     /** @brief Saves effects embedded in project file.
179     *   @return True if effects were imported.  */
180     bool saveCustomEffects(QDomNodeList customeffects);
181
182     /** @brief Updates the project folder location entry in the kdenlive file dialogs to point to the current project folder. */
183     void updateProjectFolderPlacesEntry();
184
185 public slots:
186     void slotCreateXmlClip(const QString &name, const QDomElement xml, QString group, const QString &groupId);
187     void slotCreateColorClip(const QString &name, const QString &color, const QString &duration, QString group, const QString &groupId);
188     void slotCreateSlideshowClipFile(const QString name, const QString path,
189                                      int count, const QString duration,
190                                      const bool loop, const bool crop,
191                                      const bool fade, const QString &luma_duration,
192                                      const QString &luma_file, const int softness,
193                                      const QString &animation, QString group,
194                                      const QString &groupId);
195     void slotCreateTextClip(QString group, const QString &groupId, const QString &templatePath = QString());
196     void slotCreateTextTemplateClip(QString group, const QString &groupId, KUrl path);
197
198     /** @brief Sets the document as modified or up to date.
199      * @param mod (optional) true if the document has to be saved */
200     void setModified(bool mod = true);
201     void checkProjectClips();
202
203 private slots:
204     void slotAutoSave();
205
206 signals:
207     void resetProjectList();
208     void addProjectClip(DocClipBase *, bool getInfo = true);
209     void signalDeleteProjectClip(const QString &);
210     void updateClipDisplay(const QString&);
211     void deleteTimelineClip(const QString&);
212     void progressInfo(const QString &, int);
213
214     /** @brief Informs that the document status has been changed.
215      *
216      * If the document has been modified, it's called with true as an argument. */
217     void docModified(bool);
218     void selectLastAddedClip(const QString &);
219     void guidesUpdated();
220 };
221
222 #endif