X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderer.h;h=406e251288af080e6373bcabc989fddc65dcf4ae;hb=7d1f818376b25f793ad6e8960b73a24a39605945;hp=d13bf11166ca9e930ff37010eeed7bf0e5eafc89;hpb=8d7cacd456e882516c49a552253ca6abe9b40843;p=kdenlive diff --git a/src/renderer.h b/src/renderer.h index d13bf111..406e2512 100644 --- a/src/renderer.h +++ b/src/renderer.h @@ -15,32 +15,40 @@ * * ***************************************************************************/ -#ifndef KRENDER_H -#define KRENDER_H +#ifndef RENDERER_H +#define RENDERER_H + +#include "gentime.h" +#include "definitions.h" + +#include #include #include #include #include +#include -#include +#ifdef Q_WS_MAC +#include "videoglwidget.h" +#endif -#include "gentime.h" -#include "definitions.h" /**Render encapsulates the client side of the interface to a renderer. From Kdenlive's point of view, you treat the Render object as the renderer, and simply use it as if it was local. Calls are asyncrhonous - -you send a call out, and then recieve the return value through the +you send a call out, and then receive the return value through the relevant signal that get's emitted once the call completes. *@author Jason Wood */ class Render; -//class EffectParamDesc; + +class QTimer; class QPixmap; -namespace Mlt { +namespace Mlt +{ class Consumer; class Playlist; class Tractor; @@ -48,12 +56,25 @@ class Frame; class Producer; class Filter; class Profile; -class Multitrack; +class Service; }; +class MltErrorEvent : public QEvent +{ +public: + MltErrorEvent(QString message) : QEvent(QEvent::User), m_message(message) {} + QString message() const { + return m_message; + } + +private: + QString m_message; +}; + -class Render: public QObject { +class Render: public QObject +{ Q_OBJECT public: enum FailStates { OK = 0, @@ -66,7 +87,8 @@ Q_OBJECT public: /** Seeks the renderer clip to the given time. */ void seek(GenTime time); void seekToFrame(int pos); - bool m_isBlocked; + void seekToFrameDiff(int diff); + int m_isBlocked; //static QPixmap getVideoThumbnail(char *profile, QString file, int frame, int width, int height); QPixmap getImageThumbnail(KUrl url, int width, int height); @@ -88,11 +110,11 @@ Q_OBJECT public: /** Wraps the VEML command of the same name. Sets the current scene list to be list. */ - void setSceneList(QDomDocument list, int position = 0); - void setSceneList(QString playlist, int position = 0); - void setProducer(Mlt::Producer *producer, int position); - QString sceneList(); - void saveSceneList(QString path, QDomElement kdenliveData = QDomElement()); + int setSceneList(QDomDocument list, int position = 0); + int setSceneList(QString playlist, int position = 0); + int setProducer(Mlt::Producer *producer, int position); + const QString sceneList(); + bool saveSceneList(QString path, QDomElement kdenliveData = QDomElement()); /** Wraps the VEML command of the same name. Tells the renderer to play the current scene at the speed specified, relative to normal @@ -124,6 +146,7 @@ Q_OBJECT public: double playSpeed(); /** Returns the current seek position of the renderer. */ GenTime seekPosition() const; + int seekFramePosition() const; void emitFrameNumber(double position); void emitConsumerStopped(); @@ -131,7 +154,6 @@ Q_OBJECT public: /** Gives the aspect ratio of the consumer */ double consumerRatio() const; - void askForRefresh(); void doRefresh(); /** Save current producer frame as image */ @@ -140,24 +162,26 @@ Q_OBJECT public: /** Turn on or off on screen display */ void refreshDisplay(); int resetProfile(); - const double fps() const; - const int renderWidth() const; - const int renderHeight() const; + double fps() const; + int renderWidth() const; + int renderHeight() const; /** get display aspect ratio */ - const double dar() const; + double dar() const; /** Playlist manipulation */ - void mltInsertClip(ItemInfo info, QDomElement element, Mlt::Producer *prod); + int mltInsertClip(ItemInfo info, QDomElement element, Mlt::Producer *prod); void mltUpdateClip(ItemInfo info, QDomElement element, Mlt::Producer *prod); void mltCutClip(int track, GenTime position); void mltInsertSpace(QMap trackClipStartList, QMap trackTransitionStartList, int track, const GenTime duration, const GenTime timeOffset); int mltGetSpaceLength(const GenTime pos, int track, bool fromBlankStart); + int mltTrackDuration(int track); bool mltResizeClipEnd(ItemInfo info, GenTime clipDuration); bool mltResizeClipStart(ItemInfo info, GenTime diff); + bool mltResizeClipCrop(ItemInfo info, GenTime diff); bool mltMoveClip(int startTrack, int endTrack, GenTime pos, GenTime moveStart, Mlt::Producer *prod); bool mltMoveClip(int startTrack, int endTrack, int pos, int moveStart, Mlt::Producer *prod); bool mltRemoveClip(int track, GenTime position); - bool mltRemoveEffect(int track, GenTime position, QString index, bool doRefresh = true); + bool mltRemoveEffect(int track, GenTime position, QString index, bool updateIndex, bool doRefresh = true); bool mltAddEffect(int track, GenTime position, EffectsParameterList params, bool doRefresh = true); bool mltEditEffect(int track, GenTime position, EffectsParameterList params); void mltMoveEffect(int track, GenTime position, int oldPos, int newPos); @@ -180,18 +204,21 @@ Q_OBJECT public: to the clip and 0.6 is the speed in percents. The newly created producer will have it's "id" parameter set to: "slowmotion:parentid:speed", where parentid is the id of the original clip in the ClipManager list and speed is the current speed */ - int mltChangeClipSpeed(ItemInfo info, double speed, double oldspeed, Mlt::Producer *prod); + int mltChangeClipSpeed(ItemInfo info, double speed, double oldspeed, int strobe, Mlt::Producer *prod); - QList producersList(); + const QList producersList(); void updatePreviewSettings(); + void setDropFrames(bool show); + QString updateSceneListFps(double current_fps, double new_fps, QString scene); +#ifdef Q_WS_MAC + void showFrame(Mlt::Frame&); +#endif private: // Private attributes & methods /** The name of this renderer - useful to identify the renderes by what they do - e.g. background rendering, workspace monitor, etc... */ QString m_name; Mlt::Consumer * m_mltConsumer; Mlt::Producer * m_mltProducer; - Mlt::Producer *m_mltTextProducer; - Mlt::Filter *m_osdInfo; Mlt::Profile *m_mltProfile; double m_framePosition; double m_fps; @@ -200,26 +227,27 @@ private: // Private attributes & methods bool m_isZoneMode; bool m_isLoopMode; GenTime m_loopStart; + int m_originalOut; /** true when monitor is in split view (several tracks at the same time) */ bool m_isSplitView; Mlt::Producer *m_blackClip; - /** Holds the path to on screen display profile */ - QString m_osdProfile; QString m_activeProfile; - QTimer *refreshTimer; - QTimer *osdTimer; - KUrl m_exportedFile; + QTimer *m_osdTimer; /** A human-readable description of this renderer. */ int m_winid; - int m_externalwinid; + +#ifdef Q_WS_MAC + VideoGLWidget *m_glWidget; +#endif /** Sets the description of this renderer to desc. */ void closeMlt(); - void mltCheckLength(); + void mltCheckLength(Mlt::Tractor *tractor); + void mltPasteEffects(Mlt::Producer *source, Mlt::Producer *dest); QMap mltGetTransitionParamsFromXml(QDomElement xml); QMap m_slowmotionProducers; void buildConsumer(); @@ -230,16 +258,15 @@ private slots: // Private slots /** refresh monitor display */ void refresh(); void slotOsdTimeout(); - void connectPlaylist(); + int connectPlaylist(); //void initSceneList(); signals: // Signals /** emitted when the renderer recieves a reply to a getFileProperties request. */ - void replyGetFileProperties(const QString &clipId, Mlt::Producer*, const QMap < QString, QString > &, const QMap < QString, QString > &); + void replyGetFileProperties(const QString &clipId, Mlt::Producer*, const QMap < QString, QString > &, const QMap < QString, QString > &, bool); /** emitted when the renderer recieves a reply to a getImage request. */ - void replyGetImage(const QString & , int, const QPixmap &, int, int); - void replyGetImage(const QString &, const QPixmap &, int, int); + void replyGetImage(const QString &, const QPixmap &); /** Emitted when the renderer stops, either playing or rendering. */ void stopped(); @@ -256,14 +283,17 @@ signals: // Signals void durationChanged(int); void rendererPosition(int); void rendererStopped(int); - void removeInvalidClip(const QString &); + void removeInvalidClip(const QString &, bool replaceProducer); + void refreshDocumentProducers(); + void blockMonitors(); + /** Used on OS X - emitted when a frame's image is to be shown. */ + void showImageSignal(QImage); public slots: // Public slots /** Start Consumer */ void start(); /** Stop Consumer */ void stop(); - void clear(); int getLength(); /** If the file is readable by mlt, return true, otherwise false */ bool isValid(KUrl url); @@ -271,7 +301,7 @@ public slots: // Public slots /** Wraps the VEML command of the same name. Requests the file properties for the specified url from the renderer. Upon return, the result will be emitted via replyGetFileProperties(). */ - void getFileProperties(const QDomElement &xml, const QString &clipId); + void getFileProperties(const QDomElement xml, const QString &clipId, bool replaceProducer = true); void exportFileToFirewire(QString srcFileName, int port, GenTime startTime, GenTime endTime); static char *decodedString(QString str);