]> git.sesse.net Git - kdenlive/commitdiff
Apply effect when return pressed in effect list
authorJean-Baptiste Mardelle <jb@kdenlive.org>
Mon, 26 Mar 2012 18:49:17 +0000 (20:49 +0200)
committerJean-Baptiste Mardelle <jb@kdenlive.org>
Mon, 26 Mar 2012 18:49:17 +0000 (20:49 +0200)
src/customtrackview.cpp
src/effectslistview.cpp
src/effectslistwidget.cpp
src/effectslistwidget.h

index e60c83659086fff1b5ec368810e1eb5a89dbe3aa..92cc78f2b62ed59d6cefa01dd93df352a16a51de 100644 (file)
@@ -1837,12 +1837,12 @@ void CustomTrackView::slotAddEffect(QDomElement effect, GenTime pos, int track)
            for (int i = 0; i < itemList.count(); i++) {
                if (itemList.at(i)->type() == AVWIDGET) {
                    ClipItem *clip = static_cast<ClipItem *>(itemList.at(i));
+                   clip->setSelectedEffect(clip->effectsCount() - 1);
                    if (!clip->isSelected()) {
                        clearSelection(false);
                        clip->setSelected(true);
+                       emit clipItemSelected(clip, clip->selectedEffectIndex());
                    }
-                   clip->setSelectedEffect(clip->effectsCount() - 1);
-                   //emit clipItemSelected(clip, clip->selectedEffectIndex());
                    break;
                }
            }
index def04eca0f3186d1d7d4f9e7a6a8489dd36f0143..4d863095fb42b9a075e5bc6a0b81c0e451fae120 100644 (file)
 #include <QMenu>
 #include <QDir>
 
+
 EffectsListView::EffectsListView(QWidget *parent) :
         QWidget(parent)
 {
     setupUi(this);
-
     QString styleSheet = "QTreeView::branch:has-siblings:!adjoins-item{border-image:none;border:0px} \
     QTreeView::branch:has-siblings:adjoins-item {border-image: none;border:0px}      \
     QTreeView::branch:!has-children:!has-siblings:adjoins-item {border-image: none;border:0px} \
@@ -71,8 +71,9 @@ EffectsListView::EffectsListView(QWidget *parent) :
     connect(type_combo, SIGNAL(currentIndexChanged(int)), this, SLOT(filterList(int)));
     connect(buttonInfo, SIGNAL(clicked()), this, SLOT(showInfoPanel()));
     connect(m_effectsList, SIGNAL(itemSelectionChanged()), this, SLOT(slotUpdateInfo()));
-    connect(m_effectsList, SIGNAL(itemDoubleClicked(QTreeWidgetItem *, int)), this, SLOT(slotEffectSelected()));
+    connect(m_effectsList, SIGNAL(itemDoubleClicked(QTreeWidgetItem*,int)), this, SLOT(slotEffectSelected()));
     connect(search_effect, SIGNAL(hiddenChanged(QTreeWidgetItem *, bool)), this, SLOT(slotUpdateSearch(QTreeWidgetItem *, bool)));
+    connect(m_effectsList, SIGNAL(applyEffect(QDomElement)), this, SIGNAL(addEffect(QDomElement)));
     connect(search_effect, SIGNAL(textChanged(QString)), this, SLOT(slotAutoExpand(QString)));
     //m_effectsList->setCurrentRow(0);
 }
@@ -121,10 +122,10 @@ void EffectsListView::showInfoPanel()
 void EffectsListView::slotEffectSelected()
 {
     QDomElement effect = m_effectsList->currentEffect();
-       QTreeWidgetItem* item=m_effectsList->currentItem();
-       if (item &&  m_effectsList->indexOfTopLevelItem(item)!=-1){
-               item->setExpanded(!item->isExpanded());         
-       }
+    QTreeWidgetItem* item=m_effectsList->currentItem();
+    if (item &&  m_effectsList->indexOfTopLevelItem(item)!=-1){
+       item->setExpanded(!item->isExpanded());         
+    }
     if (!effect.isNull())
         emit addEffect(effect);
 }
@@ -186,7 +187,7 @@ void EffectsListView::slotUpdateSearch(QTreeWidgetItem *item, bool hidden)
 void EffectsListView::slotAutoExpand(QString text)
 {
     search_effect->updateSearch();
-
+    bool selected = false;
     for (int i = 0; i < m_effectsList->topLevelItemCount(); ++i) {
         QTreeWidgetItem *folder = m_effectsList->topLevelItem(i);
         bool expandFolder = false;
@@ -195,12 +196,18 @@ void EffectsListView::slotAutoExpand(QString text)
         if (!text.isEmpty()) {
             for (int j = 0; j < folder->childCount(); j++) {
                 QTreeWidgetItem *item = folder->child(j);
-                if (!item->isHidden())
+                if (!item->isHidden()) {
                     expandFolder = true;
+                   if (!selected) {
+                       m_effectsList->setCurrentItem(item);
+                       selected = true;
+                   }
+               }
             }
         }
         folder->setExpanded(expandFolder);
     }
+    if (!selected) m_effectsList->setCurrentItem(NULL);
 }
 
 #include "effectslistview.moc"
index d4459627e6110dac903d0a3ab876ea18614bec4d..2c51069663959beab27b5588475fa83d28b3717f 100644 (file)
@@ -283,7 +283,6 @@ const QDomElement EffectsListWidget::itemEffect(QTreeWidgetItem *item) const
     QDomElement effect;
     if (!item || item->data(0, TypeRole).toInt() == (int)EFFECT_FOLDER) return effect;
     QStringList effectInfo = item->data(0, IdRole).toStringList();
-    kDebug() << "// EFFECT SELECTED: " << effectInfo;
     switch (item->data(0, TypeRole).toInt()) {
     case 1:
         effect =  MainWindow::videoEffects.getEffectByTag(effectInfo.at(0), effectInfo.at(1)).cloneNode().toElement();
@@ -319,6 +318,15 @@ QString EffectsListWidget::currentInfo()
     return info;
 }
 
+//virtual
+void EffectsListWidget::keyPressEvent(QKeyEvent *e)
+{
+    if (e->key() == Qt::Key_Enter || e->key() == Qt::Key_Return) {
+       emit applyEffect(currentEffect());
+    }
+    QTreeWidget::keyPressEvent(e);
+}
+
 //virtual
 QMimeData * EffectsListWidget::mimeData(const QList<QTreeWidgetItem *> list) const
 {
index 9f8ac428186dc9340217e76bec6d1c7adc945d4d..3828884671f23d653c0493bcf9adaac9f09ce183 100644 (file)
@@ -45,6 +45,7 @@ protected:
     virtual void dragMoveEvent(QDragMoveEvent *event);
     virtual void contextMenuEvent(QContextMenuEvent * event);
     virtual QMimeData *mimeData(const QList<QTreeWidgetItem *> list) const;
+    virtual void keyPressEvent(QKeyEvent *e);
 
 private:
     QMenu *m_menu;
@@ -64,6 +65,9 @@ private:
 
 private slots:
     void slotExpandItem(const QModelIndex & index);
+    
+signals:
+    void applyEffect(const QDomElement);
 };
 
 #endif