X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fclipproperties.h;h=e3a93702a4492e9ba9d69abb39708381c10aeb97;hb=56aee6aedeeed3efd10ada8fe3c229eddc01ef05;hp=23c1f4d749e9c8f135ad011340ef0b4fbbe465d3;hpb=5363c29035bb35f968e85953bac22ac5dd79cf74;p=kdenlive diff --git a/src/clipproperties.h b/src/clipproperties.h index 23c1f4d7..e3a93702 100644 --- a/src/clipproperties.h +++ b/src/clipproperties.h @@ -21,34 +21,69 @@ #ifndef CLIPPROPERTIES_H #define CLIPPROPERTIES_H - #include "definitions.h" #include "timecode.h" #include "docclipbase.h" #include "ui_clipproperties_ui.h" +#include + +class PropertiesViewDelegate : public QStyledItemDelegate +{ + Q_OBJECT +public: + PropertiesViewDelegate(QWidget *parent) + : QStyledItemDelegate(parent) + { + m_height = parent->fontMetrics().height() * 1.2; + } +protected: + QSize sizeHint(const QStyleOptionViewItem &option, const QModelIndex &index) const { + return QSize(QStyledItemDelegate::sizeHint(option, index).width(), m_height); + } +private: + int m_height; +}; + class ClipProperties : public QDialog { Q_OBJECT public: - ClipProperties(DocClipBase *clip, Timecode tc, double fps, QWidget * parent = 0); - ClipProperties(QList cliplist, Timecode tc, QMap commonproperties, QWidget * parent); + ClipProperties(DocClipBase *clip, const Timecode &tc, double fps, QWidget * parent = 0); + ClipProperties(const QList &cliplist, const Timecode &tc, const QMap &commonproperties, QWidget * parent); + virtual ~ClipProperties(); QMap properties(); const QString &clipId() const; bool needsTimelineRefresh() const; bool needsTimelineReload() const; + void disableClipId(const QString &id); +public slots: + void slotFillMarkersList(DocClipBase *clip); + void slotUpdateAnalysisData(DocClipBase *clip); + private slots: - void parseFolder(); + void parseFolder(bool reloadThumb = true); void slotAddMarker(); void slotEditMarker(); void slotDeleteMarker(); - void slotFillMarkersList(); void slotCheckMaxLength(); void slotEnableLuma(int state); void slotEnableLumaFile(int state); void slotUpdateDurationFormat(int ix); + void slotApplyProperties(); + void slotModified(); + void slotDeleteProxy(); + void slotOpenUrl(const QString &url); + void slotSaveMarkers(); + void slotLoadMarkers(); + void slotDeleteAnalysis(); + void slotGotThumbnail(const QString &id, const QImage &img); + void slotSaveAnalysis(); + void slotLoadAnalysis(); + void slotReloadVideoProperties(); + void slotReloadVideoThumb(); private: Ui::ClipProperties_UI m_view; @@ -62,9 +97,18 @@ private: bool m_clipNeedsRefresh; /** clip resource changed, reload it */ bool m_clipNeedsReLoad; + /** Frame with proxy info / delete button */ + QFrame* m_proxyContainer; + void loadVideoProperties(const QMap &props); signals: - void addMarker(const QString &, GenTime, QString); + void addMarkers(const QString &, const QList &); + void deleteProxy(const QString&); + void applyNewClipProperties(const QString&, const QMap &, const QMap &, bool, bool); + void saveMarkers(const QString &id); + void loadMarkers(const QString &id); + void editAnalysis(const QString &id, const QString &name, const QString &value); + void requestThumb(const QString &id, const QList & frames); };