+ m_view.clip_force_out->setHidden(true);
+ m_view.clip_out->setHidden(true);
+
+ // New display aspect ratio support
+ if (props.contains("force_aspect_num") && props.value("force_aspect_num").toInt() > 0 &&
+ props.contains("force_aspect_den") && props.value("force_aspect_den").toInt() > 0) {
+ m_view.clip_force_ar->setChecked(true);
+ m_view.clip_ar_num->setEnabled(true);
+ m_view.clip_ar_den->setEnabled(true);
+ m_view.clip_ar_num->setValue(props.value("force_aspect_num").toInt());
+ m_view.clip_ar_den->setValue(props.value("force_aspect_den").toInt());
+ }
+ // Legacy support for pixel aspect ratio
+ else if (props.contains("force_aspect_ratio") && props.value("force_aspect_ratio").toDouble() > 0) {
+ m_view.clip_force_ar->setChecked(true);
+ m_view.clip_ar_num->setEnabled(true);
+ m_view.clip_ar_den->setEnabled(true);
+ if (props.contains("frame_size")) {
+ int width = props.value("force_aspect_ratio").toDouble() * props.value("frame_size").section('x', 0, 0).toInt();
+ int height = props.value("frame_size").section('x', 1, 1).toInt();
+ if (width > 0 && height > 0) {
+ if ((width / height * 100) == 133) {
+ width = 4;
+ height = 3;
+ }
+ else if (int(width / height * 100) == 177) {
+ width = 16;
+ height = 9;
+ }
+ m_view.clip_ar_num->setValue(width);
+ m_view.clip_ar_den->setValue(height);
+ }
+ }
+ }
+ connect(m_view.clip_force_ar, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_ar_num, SIGNAL(valueChanged(int)), this, SLOT(slotModified()));
+ connect(m_view.clip_ar_den, SIGNAL(valueChanged(int)), this, SLOT(slotModified()));
+
+ if (props.contains("force_fps") && props.value("force_fps").toDouble() > 0) {
+ m_view.clip_force_framerate->setChecked(true);
+ m_view.clip_framerate->setEnabled(true);
+ m_view.clip_framerate->setValue(props.value("force_fps").toDouble());
+ }
+ connect(m_view.clip_force_framerate, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_framerate, SIGNAL(valueChanged(double)), this, SLOT(slotModified()));
+
+ if (props.contains("force_progressive")) {
+ m_view.clip_force_progressive->setChecked(true);
+ m_view.clip_progressive->setEnabled(true);
+ m_view.clip_progressive->setValue(props.value("force_progressive").toInt());
+ }
+ connect(m_view.clip_force_progressive, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_progressive, SIGNAL(valueChanged(int)), this, SLOT(slotModified()));
+
+ m_view.clip_fieldorder->addItem(i18n("Bottom first"), 0);
+ m_view.clip_fieldorder->addItem(i18n("Top first"), 1);
+ if (props.contains("force_tff")) {
+ m_view.clip_force_fieldorder->setChecked(true);
+ m_view.clip_fieldorder->setEnabled(true);
+ m_view.clip_fieldorder->setCurrentIndex(props.value("force_tff").toInt());
+ }
+ connect(m_view.clip_force_fieldorder, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_fieldorder, SIGNAL(currentIndexChanged(int)), this, SLOT(slotModified()));
+
+ if (props.contains("threads") && props.value("threads").toInt() != 1) {
+ m_view.clip_force_threads->setChecked(true);
+ m_view.clip_threads->setEnabled(true);
+ m_view.clip_threads->setValue(props.value("threads").toInt());
+ }
+ connect(m_view.clip_force_threads, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_threads, SIGNAL(valueChanged(int)), this, SLOT(slotModified()));
+
+ if (props.contains("video_index") && props.value("video_index").toInt() != 0) {
+ m_view.clip_force_vindex->setChecked(true);
+ m_view.clip_vindex->setEnabled(true);
+ m_view.clip_vindex->setValue(props.value("video_index").toInt());
+ }
+ connect(m_view.clip_force_vindex, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_vindex, SIGNAL(valueChanged(int)), this, SLOT(slotModified()));
+
+ if (props.contains("audio_index") && props.value("audio_index").toInt() != 0) {
+ m_view.clip_force_aindex->setChecked(true);
+ m_view.clip_aindex->setEnabled(true);
+ m_view.clip_aindex->setValue(props.value("audio_index").toInt());
+ }
+ connect(m_view.clip_force_aindex, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_aindex, SIGNAL(valueChanged(int)), this, SLOT(slotModified()));
+
+ if (props.contains("audio_max")) {
+ m_view.clip_aindex->setMaximum(props.value("audio_max").toInt());
+ }
+
+ if (props.contains("video_max")) {
+ m_view.clip_vindex->setMaximum(props.value("video_max").toInt());
+ }
+
+ m_view.clip_colorspace->addItem(ProfilesDialog::getColorspaceDescription(601), 601);
+ m_view.clip_colorspace->addItem(ProfilesDialog::getColorspaceDescription(709), 709);
+ m_view.clip_colorspace->addItem(ProfilesDialog::getColorspaceDescription(240), 240);
+ if (props.contains("force_colorspace")) {
+ m_view.clip_force_colorspace->setChecked(true);
+ m_view.clip_colorspace->setEnabled(true);
+ m_view.clip_colorspace->setCurrentIndex(m_view.clip_colorspace->findData(props.value("force_colorspace").toInt()));
+ } else if (props.contains("colorspace")) {
+ m_view.clip_colorspace->setCurrentIndex(m_view.clip_colorspace->findData(props.value("colorspace").toInt()));
+ }
+ connect(m_view.clip_force_colorspace, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+ connect(m_view.clip_colorspace, SIGNAL(currentIndexChanged(int)), this, SLOT(slotModified()));
+
+ if (props.contains("full_luma")) {
+ m_view.clip_full_luma->setChecked(true);
+ }
+ connect(m_view.clip_full_luma, SIGNAL(toggled(bool)), this, SLOT(slotModified()));
+
+ // Check for Metadata
+ QMap<QString, QString> meta = m_clip->metadata();
+ QMap<QString, QString>::const_iterator i = meta.constBegin();
+ while (i != meta.constEnd()) {
+ QTreeWidgetItem *metaitem = new QTreeWidgetItem(m_view.metadata_list);
+ metaitem->setText(0, i.key()); //i18n(i.key().section('.', 2, 3).toUtf8().data()));
+ metaitem->setText(1, i.value());
+ ++i;
+ }
+
+ connect(m_view.clip_force_ar, SIGNAL(toggled(bool)), m_view.clip_ar_num, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_ar, SIGNAL(toggled(bool)), m_view.clip_ar_den, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_framerate, SIGNAL(toggled(bool)), m_view.clip_framerate, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_progressive, SIGNAL(toggled(bool)), m_view.clip_progressive, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_fieldorder, SIGNAL(toggled(bool)), m_view.clip_fieldorder, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_threads, SIGNAL(toggled(bool)), m_view.clip_threads, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_vindex, SIGNAL(toggled(bool)), m_view.clip_vindex, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_aindex, SIGNAL(toggled(bool)), m_view.clip_aindex, SLOT(setEnabled(bool)));
+ connect(m_view.clip_force_colorspace, SIGNAL(toggled(bool)), m_view.clip_colorspace, SLOT(setEnabled(bool)));