]> git.sesse.net Git - kdenlive/blob - src/colorscopes/histogram.cpp
Complete rewrite of the video4linux capture to use MLT, in progress.
[kdenlive] / src / colorscopes / histogram.cpp
1 /***************************************************************************
2  *   Copyright (C) 2010 by Simon Andreas Eugster (simon.eu@gmail.com)      *
3  *   This file is part of kdenlive. See www.kdenlive.org.                  *
4  *                                                                         *
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  ***************************************************************************/
10
11 #include <QMenu>
12 #include <QTime>
13 #include "histogramgenerator.h"
14 #include "histogram.h"
15 #include "renderer.h"
16
17 Histogram::Histogram(MonitorManager *manager, QWidget *parent) :
18     AbstractGfxScopeWidget(manager, false, parent)
19 {
20     ui = new Ui::Histogram_UI();
21     ui->setupUi(this);
22
23
24     m_aUnscaled = new QAction(i18n("Unscaled"), this);
25     m_aUnscaled->setCheckable(true);
26
27     m_aRec601 = new QAction(i18n("Rec. 601"), this);
28     m_aRec601->setCheckable(true);
29     m_aRec709 = new QAction(i18n("Rec. 709"), this);
30     m_aRec709->setCheckable(true);
31     m_agRec = new QActionGroup(this);
32     m_agRec->addAction(m_aRec601);
33     m_agRec->addAction(m_aRec709);
34
35     m_menu->addSeparator();
36     m_menu->addAction(m_aUnscaled);
37     m_menu->addSeparator()->setText(i18n("Luma mode"));
38     m_menu->addAction(m_aRec601);
39     m_menu->addAction(m_aRec709);
40
41     bool b = true;
42     b &= connect(ui->cbY, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
43     b &= connect(ui->cbS, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
44     b &= connect(ui->cbR, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
45     b &= connect(ui->cbG, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
46     b &= connect(ui->cbB, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
47     b &= connect(m_aUnscaled, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
48     b &= connect(m_aRec601, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
49     b &= connect(m_aRec709, SIGNAL(toggled(bool)), this, SLOT(forceUpdateScope()));
50     Q_ASSERT(b);
51
52     init();
53 }
54
55 Histogram::~Histogram()
56 {
57     writeConfig();
58
59     delete ui;
60     delete m_aUnscaled;
61     delete m_aRec601;
62     delete m_aRec709;
63     delete m_agRec;
64 }
65
66 void Histogram::readConfig()
67 {
68     AbstractGfxScopeWidget::readConfig();
69
70     KSharedConfigPtr config = KGlobal::config();
71     KConfigGroup scopeConfig(config, configName());
72     ui->cbY->setChecked(scopeConfig.readEntry("yEnabled", true));
73     ui->cbS->setChecked(scopeConfig.readEntry("sEnabled", false));
74     ui->cbR->setChecked(scopeConfig.readEntry("rEnabled", true));
75     ui->cbG->setChecked(scopeConfig.readEntry("gEnabled", true));
76     ui->cbB->setChecked(scopeConfig.readEntry("bEnabled", true));
77     m_aRec601->setChecked(scopeConfig.readEntry("rec601", false));
78     m_aRec709->setChecked(!m_aRec601->isChecked());
79 }
80
81 void Histogram::writeConfig()
82 {
83     KSharedConfigPtr config = KGlobal::config();
84     KConfigGroup scopeConfig(config, configName());
85     scopeConfig.writeEntry("yEnabled", ui->cbY->isChecked());
86     scopeConfig.writeEntry("sEnabled", ui->cbS->isChecked());
87     scopeConfig.writeEntry("rEnabled", ui->cbR->isChecked());
88     scopeConfig.writeEntry("gEnabled", ui->cbG->isChecked());
89     scopeConfig.writeEntry("bEnabled", ui->cbB->isChecked());
90     scopeConfig.writeEntry("rec601", m_aRec601->isChecked());
91     scopeConfig.sync();
92 }
93
94 QString Histogram::widgetName() const { return QString("Histogram"); }
95
96 bool Histogram::isHUDDependingOnInput() const { return false; }
97 bool Histogram::isScopeDependingOnInput() const { return true; }
98 bool Histogram::isBackgroundDependingOnInput() const { return false; }
99
100 QRect Histogram::scopeRect()
101 {
102     //qDebug() << "According to the spacer, the top left point is " << ui->verticalSpacer->geometry().x() << "/" << ui->verticalSpacer->geometry().y();
103     QPoint topleft(offset, offset+ ui->verticalSpacer->geometry().y());
104     return QRect(topleft, this->rect().size() - QSize(topleft.x() + offset, topleft.y() + offset));
105 }
106
107 QImage Histogram::renderHUD(uint)
108 {
109     emit signalHUDRenderingFinished(0, 1);
110     return QImage();
111 }
112 QImage Histogram::renderGfxScope(uint accelFactor, const QImage qimage)
113 {
114     QTime start = QTime::currentTime();
115     start.start();
116
117     const int componentFlags =   (ui->cbY->isChecked() ? 1 : 0) * HistogramGenerator::ComponentY
118                                | (ui->cbS->isChecked() ? 1 : 0) * HistogramGenerator::ComponentSum
119                                | (ui->cbR->isChecked() ? 1 : 0) * HistogramGenerator::ComponentR
120                                | (ui->cbG->isChecked() ? 1 : 0) * HistogramGenerator::ComponentG
121                                | (ui->cbB->isChecked() ? 1 : 0) * HistogramGenerator::ComponentB;
122
123     HistogramGenerator::Rec rec = m_aRec601->isChecked() ? HistogramGenerator::Rec_601 : HistogramGenerator::Rec_709;
124
125     QImage histogram = m_histogramGenerator->calculateHistogram(m_scopeRect.size(), qimage, componentFlags,
126                                                                 rec, m_aUnscaled->isChecked(), accelFactor);
127
128     emit signalScopeRenderingFinished(start.elapsed(), accelFactor);
129     return histogram;
130 }
131 QImage Histogram::renderBackground(uint)
132 {
133     emit signalBackgroundRenderingFinished(0, 1);
134     return QImage();
135 }