#include <QStylePainter>
#include <QMenu>
#include <QToolButton>
+#include <QToolBar>
#include <KDebug>
#include <KLocale>
layout->addWidget(m_ruler);
ui.ruler_frame->setLayout(layout);
- m_toolbar = new QToolBar(name, this);
+ QToolBar *toolbar = new QToolBar(name, this);
QVBoxLayout *layout2 = new QVBoxLayout;
m_playIcon = KIcon("media-playback-start");
m_pauseIcon = KIcon("media-playback-pause");
- QAction *m_rewAction = m_toolbar->addAction(KIcon("media-seek-backward"), i18n("Rewind"));
+ QAction *m_rewAction = toolbar->addAction(KIcon("media-seek-backward"), i18n("Rewind"));
connect(m_rewAction, SIGNAL(triggered()), this, SLOT(slotRewind()));
- QAction *m_rew1Action = m_toolbar->addAction(KIcon("media-skip-backward"), i18n("Rewind 1 frame"));
+ QAction *m_rew1Action = toolbar->addAction(KIcon("media-skip-backward"), i18n("Rewind 1 frame"));
connect(m_rew1Action, SIGNAL(triggered()), this, SLOT(slotRewindOneFrame()));
- QToolButton *playButton = new QToolButton(m_toolbar);
+ QToolButton *playButton = new QToolButton(toolbar);
QMenu *playMenu = new QMenu(this);
playButton->setMenu(playMenu);
playButton->setPopupMode(QToolButton::MenuButtonPopup);
- m_toolbar->addWidget(playButton);
+ toolbar->addWidget(playButton);
m_playAction = playMenu->addAction(m_playIcon, i18n("Play"));
m_playAction->setCheckable(true);
QAction *m_loopSectionAction = playMenu->addAction(m_playIcon, i18n("Loop Section"));
connect(m_loopSectionAction, SIGNAL(triggered()), this, SLOT(slotPlay()));
- QAction *m_fwd1Action = m_toolbar->addAction(KIcon("media-skip-forward"), i18n("Forward 1 frame"));
+ QAction *m_fwd1Action = toolbar->addAction(KIcon("media-skip-forward"), i18n("Forward 1 frame"));
connect(m_fwd1Action, SIGNAL(triggered()), this, SLOT(slotForwardOneFrame()));
- QAction *m_fwdAction = m_toolbar->addAction(KIcon("media-seek-forward"), i18n("Forward"));
+ QAction *m_fwdAction = toolbar->addAction(KIcon("media-seek-forward"), i18n("Forward"));
connect(m_fwdAction, SIGNAL(triggered()), this, SLOT(slotForward()));
playButton->setDefaultAction(m_playAction);
m_timePos = new KRestrictedLine(this);
m_timePos->setInputMask("99:99:99:99");
- m_toolbar->addWidget(m_timePos);
+ toolbar->addWidget(m_timePos);
- layout2->addWidget(m_toolbar);
+ layout2->addWidget(toolbar);
ui.button_frame->setLayout(layout2);
//m_ruler->setPixelPerMark(3);
#include <KDebug>
#include <KLocale>
#include <KStandardDirs>
+#include <KComboBox>
#include "gentime.h"
#include "kdenlivesettings.h"
#include "recmonitor.h"
RecMonitor::RecMonitor(QString name, QWidget *parent)
- : QWidget(parent), m_name(name), m_isActive(false), m_isCapturing(false) {
+ : QWidget(parent), m_name(name), m_isActive(false), m_isCapturing(false), m_isPlaying(false) {
ui.setupUi(this);
ui.video_frame->setAttribute(Qt::WA_PaintOnScreen);
- connect(ui.buttonConnect, SIGNAL(clicked()), this, SLOT(slotSwitchCapture()));
- connect(ui.buttonRec, SIGNAL(clicked()), this, SLOT(slotCapture()));
- ui.buttonRec->setCheckable(true);
+ ui.device_selector->setCurrentIndex(KdenliveSettings::defaultcapture());
+ connect(ui.device_selector, SIGNAL(currentIndexChanged(int)), this, SLOT(slotVideoDeviceChanged(int)));
+
+
+ QToolBar *toolbar = new QToolBar(name, this);
+ QHBoxLayout *layout = new QHBoxLayout;
+
+ m_playIcon = KIcon("media-playback-start");
+ m_pauseIcon = KIcon("media-playback-pause");
+
+ m_discAction = toolbar->addAction(KIcon("network-connect"), i18n("Connect"));
+ connect(m_discAction, SIGNAL(triggered()), this, SLOT(slotDisconnect()));
+
+ m_rewAction = toolbar->addAction(KIcon("media-seek-backward"), i18n("Rewind"));
+ connect(m_rewAction, SIGNAL(triggered()), this, SLOT(slotRewind()));
+
+ m_playAction = toolbar->addAction(m_playIcon, i18n("Play"));
+ connect(m_playAction, SIGNAL(triggered()), this, SLOT(slotStartCapture()));
+
+ m_stopAction = toolbar->addAction(KIcon("media-playback-stop"), i18n("Stop"));
+ connect(m_stopAction, SIGNAL(triggered()), this, SLOT(slotStopCapture()));
+ m_stopAction->setEnabled(false);
+ m_fwdAction = toolbar->addAction(KIcon("media-seek-forward"), i18n("Forward"));
+ connect(m_fwdAction, SIGNAL(triggered()), this, SLOT(slotForward()));
+
+ m_recAction = toolbar->addAction(KIcon("media-record"), i18n("Record"));
+ connect(m_recAction, SIGNAL(triggered()), this, SLOT(slotRecord()));
+ m_recAction->setCheckable(true);
+
+ layout->addWidget(toolbar);
+ ui.control_frame_firewire->setLayout(layout);
+
+ slotVideoDeviceChanged(ui.device_selector->currentIndex());
displayProcess = new QProcess;
captureProcess = new QProcess;
- connect(displayProcess, SIGNAL(stateChanged(QProcess::ProcessState)), this, SLOT(slotProcessStatus(QProcess::ProcessState)));
+ connect(captureProcess, SIGNAL(stateChanged(QProcess::ProcessState)), this, SLOT(slotProcessStatus(QProcess::ProcessState)));
QStringList env = QProcess::systemEnvironment();
env << "SDL_WINDOWID=" + QString::number(ui.video_frame->winId());
return m_name;
}
-void RecMonitor::slotSwitchCapture() {
+void RecMonitor::slotVideoDeviceChanged(int ix) {
+
+ if (ix == 1) {
+ m_discAction->setEnabled(false);
+ m_rewAction->setEnabled(false);
+ m_fwdAction->setEnabled(false);
+ m_recAction->setEnabled(true);
+ m_stopAction->setEnabled(false);
+ m_playAction->setEnabled(true);
+ } else {
+ m_discAction->setEnabled(true);
+ m_recAction->setEnabled(false);
+ m_stopAction->setEnabled(false);
+ m_playAction->setEnabled(false);
+ m_rewAction->setEnabled(false);
+ m_fwdAction->setEnabled(false);
+ }
+}
+
+void RecMonitor::slotDisconnect() {
+ if (captureProcess->state() == QProcess::NotRunning) {
+ slotStartCapture(false);
+ m_discAction->setIcon(KIcon("network-disconnect"));
+ m_discAction->setText(i18n("Disonnect"));
+ m_recAction->setEnabled(true);
+ m_stopAction->setEnabled(true);
+ m_playAction->setEnabled(true);
+ m_rewAction->setEnabled(true);
+ m_fwdAction->setEnabled(true);
+ } else {
+ captureProcess->write("q", 1);
+ m_discAction->setIcon(KIcon("network-connect"));
+ m_discAction->setText(i18n("Connect"));
+ m_recAction->setEnabled(false);
+ m_stopAction->setEnabled(false);
+ m_playAction->setEnabled(false);
+ m_rewAction->setEnabled(false);
+ m_fwdAction->setEnabled(false);
+ }
+}
+
+void RecMonitor::slotRewind() {
+ captureProcess->write("a", 1);
+}
+
+void RecMonitor::slotForward() {
+ captureProcess->write("z", 1);
+}
+
+void RecMonitor::slotStopCapture() {
+ // stop capture
+ if (ui.device_selector->currentIndex() == 0) {
+ captureProcess->write("\e", 2);
+ m_playAction->setIcon(m_playIcon);
+ m_isPlaying = false;
+ } else {
+ if (m_isCapturing && ui.autoaddbox->isChecked()) emit addProjectClip(m_captureFile);
+ captureProcess->kill();
+ displayProcess->kill();
+ }
+}
+
+void RecMonitor::slotStartCapture(bool play) {
/*
*captureProcess<<"dvgrab";
ui.video_frame->setScaledContents(false);
captureProcess->start("dvgrab",captureArgs);
displayProcess->start("ffplay", displayArgs);*/
- ui.buttonRec->setChecked(false);
- m_isCapturing = false;
- if (captureProcess->state() == QProcess::Starting) return;
- else if (captureProcess->state() == QProcess::NotRunning) {
- m_captureArgs.clear();
- m_displayArgs.clear();
- if (KdenliveSettings::defaultcapture() == 0) {
- m_captureArgs << "--format" << "hdv" << "-i" << "capture" << "-";
- m_displayArgs << "-f" << "mpegts" << "-x" << QString::number(ui.video_frame->width()) << "-y" << QString::number(ui.video_frame->height()) << "-";
- } else {
- if (!KdenliveSettings::video4adevice().isEmpty()) m_captureArgs << "-f" << KdenliveSettings::video4aformat() << "-i" << KdenliveSettings::video4adevice();
- m_captureArgs << "-f" << "video4linux2" << "-s" << QString::number(KdenliveSettings::video4width()) + "x" + QString::number(KdenliveSettings::video4height()) << "-r" << QString::number(KdenliveSettings::video4rate()) << "-i" << KdenliveSettings::video4vdevice() << "-f" << KdenliveSettings::video4vformat() << "-";
- m_displayArgs << "-f" << KdenliveSettings::video4vformat() << "-x" << QString::number(ui.video_frame->width()) << "-y" << QString::number(ui.video_frame->height()) << "-";
+
+ if (captureProcess->state() != QProcess::NotRunning) {
+ if (ui.device_selector->currentIndex() == 0) {
+ if (m_isPlaying) {
+ captureProcess->write("k", 1);
+ //captureProcess->write("\e", 2);
+ m_playAction->setIcon(m_playIcon);
+ m_isPlaying = false;
+ } else {
+ captureProcess->write("p", 1);
+ m_playAction->setIcon(m_pauseIcon);
+ m_isPlaying = true;
+ }
}
+ return;
+ }
+ m_captureArgs.clear();
+ m_displayArgs.clear();
+ m_isPlaying = false;
- captureProcess->setStandardOutputProcess(displayProcess);
- if (KdenliveSettings::defaultcapture() == 0) captureProcess->start("dvgrab", m_captureArgs);
- else captureProcess->start("ffmpeg", m_captureArgs);
- displayProcess->start("ffplay", m_displayArgs);
- ui.video_frame->setText(i18n("Initialising..."));
+ if (ui.device_selector->currentIndex() == 0) {
+ m_captureArgs << "--format" << "hdv" << "-i" << "capture" << "-";
+ m_displayArgs << "-f" << "mpegts" << "-x" << QString::number(ui.video_frame->width()) << "-y" << QString::number(ui.video_frame->height()) << "-";
} else {
- // stop capture
- displayProcess->kill();
- captureProcess->kill();
+ if (!KdenliveSettings::video4adevice().isEmpty()) m_captureArgs << "-f" << KdenliveSettings::video4aformat() << "-i" << KdenliveSettings::video4adevice();
+ m_captureArgs << "-f" << "video4linux2" << "-s" << QString::number(KdenliveSettings::video4width()) + "x" + QString::number(KdenliveSettings::video4height()) << "-r" << QString::number(KdenliveSettings::video4rate()) << "-i" << KdenliveSettings::video4vdevice() << "-f" << KdenliveSettings::video4vformat() << "-";
+ m_displayArgs << "-f" << KdenliveSettings::video4vformat() << "-x" << QString::number(ui.video_frame->width()) << "-y" << QString::number(ui.video_frame->height()) << "-";
}
-}
-void RecMonitor::slotCapture() {
+ captureProcess->setStandardOutputProcess(displayProcess);
+ if (ui.device_selector->currentIndex() == 0) {
+ captureProcess->setWorkingDirectory(KdenliveSettings::capturefolder());
+ captureProcess->start("dvgrab", m_captureArgs);
+ if (play) captureProcess->write(" ", 1);
+ m_discAction->setEnabled(true);
+ } else captureProcess->start("ffmpeg", m_captureArgs);
+ displayProcess->start("ffplay", m_displayArgs);
+ ui.video_frame->setText(i18n("Initialising..."));
+}
+
+void RecMonitor::slotRecord() {
+ if (captureProcess->state() == QProcess::NotRunning && ui.device_selector->currentIndex() == 0) {
+ slotStartCapture();
+ }
+ if (m_isCapturing) {
+ if (ui.device_selector->currentIndex() == 0) {
+ captureProcess->write("\e", 2);
+ m_playAction->setIcon(m_playIcon);
+ m_isCapturing = false;
+ m_isPlaying = false;
+ m_recAction->setChecked(false);
+ } else {
+ slotStopCapture();
+ QTimer::singleShot(1000, this, SLOT(slotStartCapture()));
+ }
+ return;
+ } else if (ui.device_selector->currentIndex() == 0) {
+ m_isCapturing = true;
+ captureProcess->write("c\n", 3);
+ return;
+ }
if (captureProcess->state() == QProcess::NotRunning) {
- ui.buttonConnect->setEnabled(false);
+ m_recAction->setChecked(true);
QString path = KdenliveSettings::capturefolder() + "/capture0000.mpg";
int i = 1;
else if (i < 100) num.prepend("00");
else num.prepend("0");
path = KdenliveSettings::capturefolder() + "/capture" + num + ".mpg";
- i++;
+ i++;
}
m_captureFile = KUrl(path);
m_captureArgs.clear();
m_displayArgs.clear();
- if (KdenliveSettings::defaultcapture() == 0) {
+ if (ui.device_selector->currentIndex() == 0) {
m_captureArgs << "--format" << "hdv" << "-i" << "capture" << "-";
m_displayArgs << "-f" << "mpegts" << "-x" << QString::number(ui.video_frame->width()) << "-y" << QString::number(ui.video_frame->height()) << "-";
} else {
captureProcess->setStandardOutputProcess(displayProcess);
//ui.video_frame->setScaledContents(false);
- if (KdenliveSettings::defaultcapture() == 0) captureProcess->start("dvgrab", m_captureArgs);
+ if (ui.device_selector->currentIndex() == 0) captureProcess->start("dvgrab", m_captureArgs);
else captureProcess->start("ffmpeg", m_captureArgs);
displayProcess->start("ffplay", m_displayArgs);
ui.video_frame->setText(i18n("Initialising..."));
- ui.buttonRec->setChecked(true);
} else {
// stop capture
displayProcess->kill();
captureProcess->kill();
- if (m_isCapturing) {
- QTimer::singleShot(1000, this, SLOT(slotSwitchCapture()));
- ui.buttonRec->setChecked(false);
- ui.buttonConnect->setEnabled(true);
- if (ui.autoaddbox->isChecked()) emit addProjectClip(m_captureFile);
- } else {
- QTimer::singleShot(1000, this, SLOT(slotCapture()));
- ui.buttonRec->setChecked(true);
- }
+ QTimer::singleShot(1000, this, SLOT(slotRecord()));
}
}
void RecMonitor::slotProcessStatus(QProcess::ProcessState status) {
- if (status == QProcess::Starting) ui.buttonConnect->setText(i18n("Starting..."));
- else if (status == QProcess::NotRunning) {
- ui.buttonConnect->setText(i18n("Connect"));
+ if (status == QProcess::NotRunning) {
+ m_isCapturing = false;
+ m_isPlaying = false;
+ m_playAction->setIcon(m_playIcon);
+ m_recAction->setChecked(false);
+ m_stopAction->setEnabled(false);
+ ui.device_selector->setEnabled(true);
ui.video_frame->setText(i18n("Not connected"));
- } else ui.buttonConnect->setText(i18n("Disconnect"));
+ } else {
+ m_stopAction->setEnabled(true);
+ ui.device_selector->setEnabled(false);
+ }
}
// virtual