class DocClipBase;
class Render;
class Transition;
+class Vectorscope;
+class KActionCollection;
class MainWindow : public KXmlGuiWindow
{
QDockWidget *m_recMonitorDock;
RecMonitor *m_recMonitor;
+ QDockWidget *m_vectorscopeDock;
+ Vectorscope *m_vectorscope;
+
QDockWidget *m_undoViewDock;
QUndoView *m_undoView;
QUndoGroup *m_commandStack;
KAction *m_buttonVideoThumbs;
KAction *m_buttonShowMarkers;
KAction *m_buttonFitZoom;
+ KAction *m_buttonAutomaticSplitAudio;
KAction *m_normalEditTool;
KAction *m_overwriteEditTool;
KAction *m_insertEditTool;
KAction *m_playZone;
StatusBarMessageLabel *m_messageLabel;
QActionGroup *m_clipTypeGroup;
+ KActionCollection *m_effectsActionCollection;
bool m_findActivated;
QString m_findString;
void findAhead();
void doOpenFile(const KUrl &url, KAutoSaveFile *stale);
void recoverFiles(QList<KAutoSaveFile *> staleFiles);
+
+ /** @brief Loads static and dynamic plugins.
+ *
+ * It scans static plugins as well as the filesystem: it doesn't load more
+ * than one plugin per file name, to avoid duplication due to conflicting
+ * installations. */
void loadPlugins();
void populateMenus(QObject *plugin);
void addToMenu(QObject *plugin, const QStringList &texts,
QByteArray m_timelineState;
void loadTranscoders();
QPixmap createSchemePreviewIcon(const KSharedConfigPtr &config);
+
/** @brief Checks that the Kdenlive mime type is correctly installed.
* @return The mimetype */
QString getMimeType();
public slots:
+ /** @brief Prepares opening @param url.
+ *
+ * Checks if already open and whether backup exists */
void openFile(const KUrl &url);
void slotGotProgressInfo(const QString &message, int progress);
Q_SCRIPTABLE void setRenderingProgress(const QString &url, int progress);
void queryQuit();
void activateDocument();
void connectDocument(TrackView*, KdenliveDoc*);
+
+ /** @brief Shows file open dialog. */
void openFile();
void openLastFile();
+
/** @brief Checks whether a URL is available to save to.
* @return Whether the file was saved. */
bool saveFile();
+
/** @brief Shows a save file dialog for saving the project.
* @return Whether the file was saved. */
bool saveFileAs();
+
/** @brief Set properties to match outputFileName and save the document.
* @param outputFileName The URL to save to / The document's URL.
* @return Whether we had success. */
bool saveFileAs(const QString &outputFileName);
+
+ /** @brief Shows the shortcut dialog. */
+ void slotEditKeys();
void slotPreferences(int page = -1, int option = -1);
+
+ /** @brief Reflects setting changes to the GUI. */
void updateConfiguration();
void slotConnectMonitors();
void slotRaiseMonitor(bool clipMonitor);
void slotDetectAudioDriver();
void slotEditProjectSettings();
void slotDisplayActionMessage(QAction *a);
+
+ /** @brief Turns automatic splitting of audio and video on/off. */
+ void slotSwitchSplitAudio();
void slotSwitchVideoThumbs();
void slotSwitchAudioThumbs();
void slotSwitchMarkersComments();
void slotFitZoom();
/** @brief Updates the zoom slider tooltip to fit @param zoomlevel. */
void slotUpdateZoomSliderToolTip(int zoomlevel);
+
/** @brief Displays the zoom slider tooltip.
- * @param zoomlevel (optional) The zoom level to show in the tooltip.
+ * @param zoomlevel (optional) The zoom level to show in the tooltip.
*
* Adopted from Dolphin (src/statusbar/dolphinstatusbar.cpp) */
void slotShowZoomSliderToolTip(int zoomlevel = -1);
void configureNotifications();
void slotInsertTrack(int ix = 0);
void slotDeleteTrack(int ix = 0);
- void slotChangeTrack(int ix = 0);
+ /** @brief Shows the configure tracks dialog and updates transitions afterwards. */
+ void slotConfigTrack(int ix = -1);
void slotGetNewLumaStuff();
void slotGetNewTitleStuff();
void slotGetNewRenderStuff();
void slotGetNewMltProfileStuff();
void slotAutoTransition();
void slotRunWizard();
+ /** @brief Lets the sampleplugin create a generator. */
void generateClip();
void slotZoneMoved(int start, int end);
void slotUpdatePreviewSettings();
void slotTranscodeClip();
void slotSetDocumentRenderProfile(const QString &dest, const QString &group, const QString &name, const QString &file);
void slotPrepareRendering(bool scriptExport, bool zoneOnly, const QString &chapterFile);
+
+ /** @brief Switches between displaying frames or timecode.
+ * @param ix 0 = display timecode, 1 = display frames. */
void slotUpdateTimecodeFormat(int ix);
+
/** @brief Removes the focus of anything. */
void slotRemoveFocus();
void slotCleanProject();
void slotCheckRenderStatus();
void slotInsertZoneToTree();
void slotInsertZoneToTimeline();
+
/** @brief Deletes items from timeline and document.
* @param ids The ids of the clips to delete.
* @param folderids The names and ids of the folders to delete. */