X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fdvdwizardchapters.cpp;h=d95da170b8bae5f7061e9f8554752e52c72244bb;hb=f610a587d31f1cc4f3b5b4339ab1047d815a9fdb;hp=ac7793beeccb6813759ca605ee7f9a5c7e90d26f;hpb=2950bfaa74c8dbc91e72634a8c2efbc107f571ae;p=kdenlive diff --git a/src/dvdwizardchapters.cpp b/src/dvdwizardchapters.cpp index ac7793be..d95da170 100644 --- a/src/dvdwizardchapters.cpp +++ b/src/dvdwizardchapters.cpp @@ -23,10 +23,11 @@ #include -DvdWizardChapters::DvdWizardChapters(bool isPal, QWidget *parent) : +DvdWizardChapters::DvdWizardChapters(MonitorManager *manager, DVDFORMAT format, QWidget *parent) : QWizardPage(parent), - m_isPal(isPal), - m_monitor(NULL) + m_format(format), + m_monitor(NULL), + m_manager(manager) { m_view.setupUi(this); @@ -37,21 +38,18 @@ DvdWizardChapters::DvdWizardChapters(bool isPal, QWidget *parent) : // Build monitor for chapters - if (m_isPal) m_tc.setFormat(25); - else m_tc.setFormat(30000.0 / 1001, true); - - m_manager = new MonitorManager(this); - m_manager->resetProfiles(m_tc); + if (m_format == PAL || m_format == PAL_WIDE) m_tc.setFormat(25); + else m_tc.setFormat(30000.0 / 1001); //m_view.monitor_frame->setVisible(false); } DvdWizardChapters::~DvdWizardChapters() { if (m_monitor) { + m_manager->removeMonitor(m_monitor); m_monitor->stop(); delete m_monitor; } - delete m_manager; } // virtual @@ -66,6 +64,11 @@ void DvdWizardChapters::stopMonitor() if (m_monitor) m_monitor->stop(); } +void DvdWizardChapters::refreshMonitor() +{ + if (m_monitor) m_monitor->refreshMonitor(); +} + void DvdWizardChapters::slotUpdateChaptersList() { m_monitor->slotOpenFile(m_view.vob_list->currentText()); @@ -75,7 +78,7 @@ void DvdWizardChapters::slotUpdateChaptersList() // insert chapters QStringList chaptersString; for (int i = 0; i < currentChaps.count(); i++) { - chaptersString.append(Timecode::getStringTimecode(currentChaps.at(i).toInt(), m_tc.fps())); + chaptersString.append(Timecode::getStringTimecode(currentChaps.at(i).toInt(), m_tc.fps(), true)); } m_view.chapters_list->clear(); m_view.chapters_list->addItems(chaptersString); @@ -98,7 +101,7 @@ void DvdWizardChapters::slotAddChapter() QStringList chaptersString; currentChaps.clear(); for (int i = 0; i < chapterTimes.count(); i++) { - chaptersString.append(Timecode::getStringTimecode(chapterTimes.at(i), m_tc.fps())); + chaptersString.append(Timecode::getStringTimecode(chapterTimes.at(i), m_tc.fps(), true)); currentChaps.append(QString::number(chapterTimes.at(i))); } // Save item chapters @@ -123,7 +126,7 @@ void DvdWizardChapters::slotRemoveChapter() // rebuild chapters QStringList chaptersString; for (int i = 0; i < currentChaps.count(); i++) { - chaptersString.append(Timecode::getStringTimecode(currentChaps.at(i).toInt(), m_tc.fps())); + chaptersString.append(Timecode::getStringTimecode(currentChaps.at(i).toInt(), m_tc.fps(), true)); } m_view.chapters_list->clear(); m_view.chapters_list->addItems(chaptersString); @@ -131,40 +134,50 @@ void DvdWizardChapters::slotRemoveChapter() void DvdWizardChapters::slotGoToChapter() { - m_monitor->setTimePos(m_view.chapters_list->currentItem()->text() + ":00"); + if (m_view.chapters_list->currentItem()) m_monitor->setTimePos(m_tc.reformatSeparators(m_view.chapters_list->currentItem()->text())); } -void DvdWizardChapters::setVobFiles(bool isPal, bool isWide, const QStringList movies, const QStringList durations, const QStringList chapters) +void DvdWizardChapters::createMonitor(DVDFORMAT format) { - m_isPal = isPal; - QString profile; - if (m_isPal) { + QString profile = DvdWizardVob::getDvdProfile(format); + if (m_monitor == NULL) { + m_monitor = new Monitor(Kdenlive::dvdMonitor, m_manager, profile, this); + //m_monitor->start(); + QVBoxLayout *vbox = new QVBoxLayout; + vbox->addWidget(m_monitor); + m_view.video_frame->setLayout(vbox); + m_monitor->setSizePolicy(QSizePolicy ( QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding)); + m_manager->appendMonitor(m_monitor); + vbox->insertWidget(0, m_monitor, 10); + } +} + +void DvdWizardChapters::setVobFiles(DVDFORMAT format, const QStringList &movies, const QStringList &durations, const QStringList &chapters) +{ + m_format = format; + QString profile = DvdWizardVob::getDvdProfile(format); + if (m_format == PAL || m_format == PAL_WIDE) { m_tc.setFormat(25); - profile = "dv_pal"; } else { - m_tc.setFormat(30000.0 / 1001, true); - profile = "dv_ntsc"; + m_tc.setFormat(30000.0 / 1001); } - if (isWide) profile.append("_wide"); - m_manager->resetProfiles(m_tc); - if (m_monitor == NULL) { - - m_monitor = new Monitor("chapter", m_manager, profile, this); - m_monitor->start(); - QVBoxLayout *vbox = new QVBoxLayout; - vbox->addWidget(m_monitor); - m_view.monitor_frame->setLayout(vbox); - /*updateGeometry(); - adjustSize();*/ - } else m_monitor->resetProfile(profile); + if (m_monitor == NULL) createMonitor(format); + m_monitor->setCustomProfile(profile, m_tc); + m_view.vob_list->blockSignals(true); m_view.vob_list->clear(); for (int i = 0; i < movies.count(); i++) { m_view.vob_list->addItem(movies.at(i), durations.at(i)); m_view.vob_list->setItemData(i, chapters.at(i).split(';'), Qt::UserRole + 1); } + m_view.vob_list->blockSignals(false); slotUpdateChaptersList(); + setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding); + adjustSize(); + updateGeometry(); + m_manager->activateMonitor(Kdenlive::dvdMonitor); + m_monitor->refreshMonitor(); } QMap DvdWizardChapters::chaptersData() const @@ -186,7 +199,7 @@ QStringList DvdWizardChapters::selectedTitles() const result.append(m_view.vob_list->itemText(i)); QStringList chapters = m_view.vob_list->itemData(i, Qt::UserRole + 1).toStringList(); for (int j = 0; j < chapters.count(); j++) { - result.append(Timecode::getStringTimecode(chapters.at(j).toInt(), m_tc.fps())); + result.append(Timecode::getStringTimecode(chapters.at(j).toInt(), m_tc.fps(), true)); } } return result; @@ -197,7 +210,7 @@ QStringList DvdWizardChapters::chapters(int ix) const QStringList result; QStringList chapters = m_view.vob_list->itemData(ix, Qt::UserRole + 1).toStringList(); for (int j = 0; j < chapters.count(); j++) { - result.append(Timecode::getStringTimecode(chapters.at(j).toInt(), m_tc.fps())); + result.append(Timecode::getStringTimecode(chapters.at(j).toInt(), m_tc.fps(), true)); } return result; } @@ -207,10 +220,11 @@ QStringList DvdWizardChapters::selectedTargets() const QStringList result; int max = m_view.vob_list->count(); for (int i = 0; i < max; i++) { - result.append("jump title " + QString::number(i + 1)); + // rightJustified: fill with 0s to make menus with more than 9 buttons work (now up to 99 buttons possible) + result.append("jump title " + QString::number(i + 1).rightJustified(2, '0')); QStringList chapters = m_view.vob_list->itemData(i, Qt::UserRole + 1).toStringList(); for (int j = 0; j < chapters.count(); j++) { - result.append("jump title " + QString::number(i + 1) + " chapter " + QString::number(j + 1)); + result.append("jump title " + QString::number(i + 1).rightJustified(2, '0') + " chapter " + QString::number(j + 1).rightJustified(2, '0')); } } return result;