1 /***************************************************************************
2 * Copyright (C) 2010 by Simon Andreas Eugster (simon.eu@gmail.com) *
3 * This file is part of kdenlive. See www.kdenlive.org. *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) any later version. *
9 ***************************************************************************/
15 #include "ui_vectorscope_ui.h"
16 #include "abstractscopewidget.h"
18 class ColorPlaneExport;
23 class VectorscopeGenerator;
25 enum BACKGROUND_MODE { BG_NONE = 0, BG_YUV = 1, BG_CHROMA = 2 };
27 class Vectorscope : public AbstractScopeWidget {
31 Vectorscope(Monitor *projMonitor, Monitor *clipMonitor, QWidget *parent = 0);
34 QString widgetName() const;
37 void mouseMoveEvent(QMouseEvent *);
38 void leaveEvent(QEvent *);
41 ///// Implemented methods /////
43 QImage renderHUD(uint accelerationFactor);
44 QImage renderScope(uint accelerationFactor, QImage);
45 QImage renderBackground(uint accelerationFactor);
46 bool isHUDDependingOnInput() const;
47 bool isScopeDependingOnInput() const;
48 bool isBackgroundDependingOnInput() const;
49 virtual void readConfig();
55 Ui::Vectorscope_UI *ui;
57 ColorTools *m_colorTools;
58 ColorPlaneExport *m_colorPlaneExport;
60 QAction *m_aExportBackground;
61 QAction *m_aAxisEnabled;
64 VectorscopeGenerator *m_vectorscopeGenerator;
66 /** How to represent the pixels on the scope (green, original color, ...) */
69 /** Custom scaling of the vectorscope */
72 QPoint m_centerPoint, pR75, pG75, pB75, pCy75, pMg75, pYl75;
77 /** Updates the dimension. Only necessary when the widget has been resized. */
78 void updateDimensions();
81 /** Counts the number of frames that have been rendered in one of the monitors.
82 The frame number will be reset when the vectorscope starts calculating the
84 // QAtomicInt newFrames;
85 /** Counts the number of other changes that should cause the vectorscope to be
86 recalculated. This is for example a resizeEvent. In this case, no new frames
87 are generated, but the scope has to be updated in any case (also if auto-update
89 // QAtomicInt newChanges;
90 /** Counts the number of changes concerning the background wheel */
91 // QAtomicInt newWheelChanges;
95 void slotGainChanged(int);
96 void slotBackgroundChanged();
97 void slotExportBackground();
100 #endif // VECTORSCOPE_H