QWidget(parent),
m_scale(1.0),
m_projectTracks(0),
- m_doc(doc)
+ m_doc(doc),
+ m_verticalZoom(1)
{
m_view.setupUi(this);
m_view.ruler_frame->setLayout(layout);
layout->addWidget(m_ruler);
+
+ QHBoxLayout *sizeLayout = new QHBoxLayout;
+ sizeLayout->setContentsMargins(0, 0, 0, 0);
+ sizeLayout->setSpacing(0);
+ m_view.size_frame->setLayout(sizeLayout);
+
+ QString style1 = "QToolButton {border-style: none;margin: 0px 3px;padding: 0px;} QToolButton:pressed:hover { background-color: rgba(224, 224, 0, 100); border-style: inset; border:1px solid #cc6666;border-radius: 3px;} QToolButton:hover { background-color: rgba(255, 255, 255, 100); border-style: inset; border:1px solid #cc6666;border-radius: 3px;}";
+
+ QToolButton *butSmall = new QToolButton(this);
+ butSmall->setIcon(KIcon("kdenlive-zoom-small"));
+ butSmall->setToolTip(i18n("Smaller tracks"));
+ connect(butSmall, SIGNAL(clicked()), this, SLOT(slotVerticalZoomDown()));
+ sizeLayout->addWidget(butSmall);
+
+ QToolButton *butLarge = new QToolButton(this);
+ butLarge->setIcon(KIcon("kdenlive-zoom-large"));
+ butLarge->setToolTip(i18n("Bigger tracks"));
+ connect(butLarge, SIGNAL(clicked()), this, SLOT(slotVerticalZoomUp()));
+ sizeLayout->addWidget(butLarge);
+ m_view.size_frame->setStyleSheet(style1);
+
+
QHBoxLayout *tracksLayout = new QHBoxLayout;
tracksLayout->setContentsMargins(0, 0, 0, 0);
tracksLayout->setSpacing(0);
slotSetZone(m_doc->zone());
}
+TrackView::~TrackView()
+{
+ delete m_ruler;
+ delete m_trackview;
+}
int TrackView::duration() const
{
m_trackview->loadGroups(groups);
m_trackview->setDuration(duration);
kDebug() << "/////////// TOTAL PROJECT DURATION: " << duration;
-
+
// Remove Kdenlive extra info from xml doc before sending it to MLT
QDomElement mlt = doc.firstChildElement("mlt");
QDomElement infoXml = mlt.firstChildElement("kdenlivedoc");
mlt.removeChild(infoXml);
-
+
slotRebuildTrackHeaders();
if (!m_documentErrors.isNull()) KMessageBox::sorry(this, m_documentErrors);
//m_trackview->setCursorPos(cursorPos);
m_doc->setZoom(factor);
m_ruler->setPixelPerMark(factor);
m_scale = (double) FRAME_SIZE / m_ruler->comboScale[factor]; // m_ruler->comboScale[m_currentZoom] /
- m_trackview->setScale(m_scale);
+ m_trackview->setScale(m_scale, m_scene->scale().y());
}
int TrackView::fitZoom() const
QList <TrackInfo> list = m_doc->tracksList();
QLayoutItem *child;
while ((child = m_headersLayout->takeAt(0)) != 0) {
+ if (child->widget()) delete child->widget();
delete child;
}
int max = list.count();
+ int height = KdenliveSettings::trackheight() * m_scene->scale().y();
for (int i = 0; i < max; i++) {
- HeaderTrack *header = new HeaderTrack(i, list.at(max - i - 1), this);
+ HeaderTrack *header = new HeaderTrack(i, list.at(max - i - 1), height, this);
connect(header, SIGNAL(switchTrackVideo(int)), m_trackview, SLOT(slotSwitchTrackVideo(int)));
connect(header, SIGNAL(switchTrackAudio(int)), m_trackview, SLOT(slotSwitchTrackAudio(int)));
connect(header, SIGNAL(switchTrackLock(int)), m_trackview, SLOT(slotSwitchTrackLock(int)));
connect(header, SIGNAL(changeTrack(int)), this, SIGNAL(changeTrack(int)));
m_headersLayout->addWidget(header);
}
- m_view.headers_container->adjustSize();
}
+void TrackView::adjustTrackHeaders()
+{
+ int height = KdenliveSettings::trackheight() * m_scene->scale().y();
+ QLayoutItem *child;
+ for (int i = 0; i < m_headersLayout->count(); i++) {
+ child = m_headersLayout->itemAt(i);
+ if (child->widget())(static_cast <HeaderTrack *>(child->widget()))->adjustSize(height);
+ }
+}
+
int TrackView::slotAddProjectTrack(int ix, QDomElement xml, bool locked)
{
// parse track
widgets.at(ix)->setLock(lock);
}
+void TrackView::slotVerticalZoomDown()
+{
+ if (m_verticalZoom == 0) return;
+ m_verticalZoom--;
+ if (m_verticalZoom == 0) m_trackview->setScale(m_scene->scale().x(), 0.5);
+ else m_trackview->setScale(m_scene->scale().x(), 1);
+ adjustTrackHeaders();
+ /*KdenliveSettings::setTrackheight(KdenliveSettings::trackheight() / 2);
+ m_trackview->checkTrackHeight(false);*/
+}
+
+void TrackView::slotVerticalZoomUp()
+{
+ if (m_verticalZoom == 2) return;
+ m_verticalZoom++;
+ /*KdenliveSettings::setTrackheight(KdenliveSettings::trackheight() * 2);
+ m_trackview->checkTrackHeight(false);*/
+ if (m_verticalZoom == 2) m_trackview->setScale(m_scene->scale().x(), 2);
+ else m_trackview->setScale(m_scene->scale().x(), 1);
+ adjustTrackHeaders();
+}
#include "trackview.moc"