diff widgets/PaneStack.cpp @ 52:f2fe98a7c57e

* Use commands for add/delete pane in main window * Add compound command collection to command history (for add pane, import file etc) * Add hide/show pane and hidden pane list to PaneStack * Various other fixes
author Chris Cannam
date Mon, 13 Mar 2006 17:55:19 +0000
parents 651e4e868bcc
children 01ab51f72e84
line wrap: on
line diff
--- a/widgets/PaneStack.cpp	Fri Mar 10 17:37:45 2006 +0000
+++ b/widgets/PaneStack.cpp	Mon Mar 13 17:55:19 2006 +0000
@@ -45,25 +45,28 @@
     layout->addWidget(currentIndicator);
     layout->setStretchFactor(currentIndicator, 1);
     currentIndicator->setScaledContents(true);
-    m_currentIndicators.push_back(currentIndicator);
 
     Pane *pane = new Pane(frame);
     pane->setViewManager(m_viewManager);
     layout->addWidget(pane);
     layout->setStretchFactor(pane, 10);
-    m_panes.push_back(pane);
 
     QWidget *properties = 0;
     if (suppressPropertyBox) {
 	properties = new QFrame();
     } else {
 	properties = new PropertyStack(frame, pane);
-	connect(properties, SIGNAL(propertyContainerSelected(PropertyContainer *)),
-		this, SLOT(propertyContainerSelected(PropertyContainer *)));
+	connect(properties, SIGNAL(propertyContainerSelected(View *, PropertyContainer *)),
+		this, SLOT(propertyContainerSelected(View *, PropertyContainer *)));
     }
     layout->addWidget(properties);
     layout->setStretchFactor(properties, 1);
-    m_propertyStacks.push_back(properties);
+
+    PaneRec rec;
+    rec.pane = pane;
+    rec.propertyStack = properties;
+    rec.currentIndicator = currentIndicator;
+    m_panes.push_back(rec);
 
     frame->setLayout(layout);
     addWidget(frame);
@@ -85,34 +88,50 @@
 Pane *
 PaneStack::getPane(int n)
 {
-    return m_panes[n];
+    return m_panes[n].pane;
+}
+
+Pane *
+PaneStack::getHiddenPane(int n)
+{
+    return m_hiddenPanes[n].pane;
 }
 
 void
 PaneStack::deletePane(Pane *pane)
 {
-    int n = 0;
-    std::vector<Pane *>::iterator i = m_panes.begin();
-    std::vector<QWidget *>::iterator j = m_propertyStacks.begin();
-    std::vector<QLabel *>::iterator k = m_currentIndicators.begin();
+    std::vector<PaneRec>::iterator i;
+    bool found = false;
 
-    while (i != m_panes.end()) {
-	if (*i == pane) break;
-	++i;
-	++j;
-	++k;
-	++n;
+    for (i = m_panes.begin(); i != m_panes.end(); ++i) {
+	if (i->pane == pane) {
+	    m_panes.erase(i);
+	    found = true;
+	    break;
+	}
     }
-    if (n >= int(m_panes.size())) return;
 
-    m_panes.erase(i);
-    m_propertyStacks.erase(j);
-    m_currentIndicators.erase(k);
-    delete widget(n);
+    if (!found) {
+
+	for (i = m_hiddenPanes.begin(); i != m_hiddenPanes.end(); ++i) {
+	    if (i->pane == pane) {
+		m_hiddenPanes.erase(i);
+		found = true;
+		break;
+	    }
+	}
+
+	if (!found) {
+	    std::cerr << "WARNING: PaneStack::deletePane(" << pane << "): Pane not found in visible or hidden panes, not deleting" << std::endl;
+	    return;
+	}
+    }
+
+    delete pane->parent();
 
     if (m_currentPane == pane) {
 	if (m_panes.size() > 0) {
-	    setCurrentPane(m_panes[0]);
+	    setCurrentPane(m_panes[0].pane);
 	} else {
 	    setCurrentPane(0);
 	}
@@ -125,13 +144,70 @@
     return m_panes.size();
 }
 
+int
+PaneStack::getHiddenPaneCount() const
+{
+    return m_hiddenPanes.size();
+}
+
+void
+PaneStack::hidePane(Pane *pane)
+{
+    std::vector<PaneRec>::iterator i = m_panes.begin();
+
+    while (i != m_panes.end()) {
+	if (i->pane == pane) {
+
+	    m_hiddenPanes.push_back(*i);
+	    m_panes.erase(i);
+
+	    QWidget *pw = dynamic_cast<QWidget *>(pane->parent());
+	    if (pw) pw->hide();
+
+	    if (m_currentPane == pane) {
+		if (m_panes.size() > 0) {
+		    setCurrentPane(m_panes[0].pane);
+		} else {
+		    setCurrentPane(0);
+		}
+	    }
+	    
+	    return;
+	}
+	++i;
+    }
+
+    std::cerr << "WARNING: PaneStack::hidePane(" << pane << "): Pane not found in visible panes" << std::endl;
+}
+
+void
+PaneStack::showPane(Pane *pane)
+{
+    std::vector<PaneRec>::iterator i = m_hiddenPanes.begin();
+
+    while (i != m_hiddenPanes.end()) {
+	if (i->pane == pane) {
+	    m_panes.push_back(*i);
+	    m_hiddenPanes.erase(i);
+	    QWidget *pw = dynamic_cast<QWidget *>(pane->parent());
+	    if (pw) pw->show();
+
+	    //!!! update current pane
+
+	    return;
+	}
+	++i;
+    }
+
+    std::cerr << "WARNING: PaneStack::showPane(" << pane << "): Pane not found in hidden panes" << std::endl;
+}
+
 void
 PaneStack::setCurrentPane(Pane *pane) // may be null
 {
     if (m_currentPane == pane) return;
     
-    std::vector<Pane *>::iterator i = m_panes.begin();
-    std::vector<QLabel *>::iterator k = m_currentIndicators.begin();
+    std::vector<PaneRec>::iterator i = m_panes.begin();
 
     // We used to do this by setting the foreground and background
     // role, but it seems the background role is ignored and the
@@ -143,18 +219,24 @@
     QPixmap unselectedMap(1, 1);
     unselectedMap.fill(QApplication::palette().color(QPalette::Background));
 
+    bool found = false;
+
     while (i != m_panes.end()) {
-	if (*i == pane) {
-	    (*k)->setPixmap(selectedMap);
+	if (i->pane == pane) {
+	    i->currentIndicator->setPixmap(selectedMap);
+	    found = true;
 	} else {
-	    (*k)->setPixmap(unselectedMap);
+	    i->currentIndicator->setPixmap(unselectedMap);
 	}
 	++i;
-	++k;
     }
-    m_currentPane = pane;
 
-    emit currentPaneChanged(m_currentPane);
+    if (found || pane == 0) {
+	m_currentPane = pane;
+	emit currentPaneChanged(m_currentPane);
+    } else {
+	std::cerr << "WARNING: PaneStack::setCurrentPane(" << pane << "): pane is not a visible pane in this stack" << std::endl;
+    }
 }
 
 void
@@ -164,13 +246,13 @@
 
     if (m_currentPane) {
 
-	std::vector<Pane *>::iterator i = m_panes.begin();
-	std::vector<QWidget *>::iterator j = m_propertyStacks.begin();
+	std::vector<PaneRec>::iterator i = m_panes.begin();
 
 	while (i != m_panes.end()) {
 
-	    if (*i == pane) {
-		PropertyStack *stack = dynamic_cast<PropertyStack *>(*j);
+	    if (i->pane == pane) {
+		PropertyStack *stack = dynamic_cast<PropertyStack *>
+		    (i->propertyStack);
 		if (stack) {
 		    if (stack->containsContainer(layer)) {
 			stack->setCurrentIndex(stack->getContainerIndex(layer));
@@ -185,7 +267,6 @@
 		break;
 	    }
 	    ++i;
-	    ++j;
 	}
     }
 }
@@ -209,19 +290,19 @@
 }
 
 void
-PaneStack::propertyContainerSelected(PropertyContainer *pc)
+PaneStack::propertyContainerSelected(View *client, PropertyContainer *pc)
 {
-    std::vector<Pane *>::iterator i = m_panes.begin();
-    std::vector<QWidget *>::iterator j = m_propertyStacks.begin();
+    std::vector<PaneRec>::iterator i = m_panes.begin();
 
     while (i != m_panes.end()) {
-	PropertyStack *stack = dynamic_cast<PropertyStack *>(*j);
-	if (stack && stack->containsContainer(pc)) {
-	    setCurrentPane(*i);
+	PropertyStack *stack = dynamic_cast<PropertyStack *>(i->propertyStack);
+	if (stack &&
+	    stack->getClient() == client &&
+	    stack->containsContainer(pc)) {
+	    setCurrentPane(i->pane);
 	    break;
 	}
 	++i;
-	++j;
     }
 
     Layer *layer = dynamic_cast<Layer *>(pc);
@@ -242,14 +323,14 @@
 {
     int maxMinWidth = 0;
 
-    for (unsigned int i = 0; i < m_propertyStacks.size(); ++i) {
-	if (!m_propertyStacks[i]) continue;
+    for (size_t i = 0; i < m_panes.size(); ++i) {
+	if (!m_panes[i].propertyStack) continue;
 	std::cerr << "PaneStack::sizePropertyStacks: " << i << ": min " 
-		  << m_propertyStacks[i]->minimumSizeHint().width() << ", current "
-		  << m_propertyStacks[i]->width() << std::endl;
+		  << m_panes[i].propertyStack->minimumSizeHint().width() << ", current "
+		  << m_panes[i].propertyStack->width() << std::endl;
 
-	if (m_propertyStacks[i]->minimumSizeHint().width() > maxMinWidth) {
-	    maxMinWidth = m_propertyStacks[i]->minimumSizeHint().width();
+	if (m_panes[i].propertyStack->minimumSizeHint().width() > maxMinWidth) {
+	    maxMinWidth = m_panes[i].propertyStack->minimumSizeHint().width();
 	}
     }
 
@@ -263,9 +344,9 @@
     int setWidth = maxMinWidth;
 #endif
 
-    for (unsigned int i = 0; i < m_propertyStacks.size(); ++i) {
-	if (!m_propertyStacks[i]) continue;
-	m_propertyStacks[i]->setMinimumWidth(setWidth);
+    for (size_t i = 0; i < m_panes.size(); ++i) {
+	if (!m_panes[i].propertyStack) continue;
+	m_panes[i].propertyStack->setMinimumWidth(setWidth);
     }
 }