Mercurial > hg > svgui
changeset 108:4772fc75ac7c
* Some work on switching property box layout between one-box-per-pane
and one-box-overall layouts. Not enabled in GUI yet.
author | Chris Cannam |
---|---|
date | Mon, 26 Jun 2006 16:08:57 +0000 |
parents | bf196d6e8998 |
children | 12340cb6e6cb |
files | widgets/PaneStack.cpp widgets/PaneStack.h widgets/PropertyBox.cpp |
diffstat | 3 files changed, 94 insertions(+), 15 deletions(-) [+] |
line wrap: on
line diff
--- a/widgets/PaneStack.cpp Mon Jun 19 16:14:16 2006 +0000 +++ b/widgets/PaneStack.cpp Mon Jun 26 16:08:57 2006 +0000 @@ -26,16 +26,32 @@ #include <QPainter> #include <QPalette> #include <QLabel> +#include <QSplitter> +#include <QStackedWidget> #include <iostream> PaneStack::PaneStack(QWidget *parent, ViewManager *viewManager) : - QSplitter(parent), + QFrame(parent), m_currentPane(0), - m_viewManager(viewManager) + m_splitter(new QSplitter), + m_propertyStackStack(new QStackedWidget), + m_viewManager(viewManager), + m_layoutStyle(PropertyStackPerPaneLayout) { - setOrientation(Qt::Vertical); - setOpaqueResize(false); + QHBoxLayout *layout = new QHBoxLayout; + layout->setMargin(0); + layout->setSpacing(0); + + m_splitter->setOrientation(Qt::Vertical); + m_splitter->setOpaqueResize(false); + + layout->addWidget(m_splitter); + layout->setStretchFactor(m_splitter, 1); + layout->addWidget(m_propertyStackStack); + m_propertyStackStack->hide(); + + setLayout(layout); } Pane * @@ -65,17 +81,24 @@ connect(properties, SIGNAL(propertyContainerSelected(View *, PropertyContainer *)), this, SLOT(propertyContainerSelected(View *, PropertyContainer *))); } - layout->addWidget(properties); + if (m_layoutStyle == PropertyStackPerPaneLayout) { + layout->addWidget(properties); + } else { + properties->setParent(m_propertyStackStack); + m_propertyStackStack->addWidget(properties); + } layout->setStretchFactor(properties, 1); PaneRec rec; rec.pane = pane; rec.propertyStack = properties; rec.currentIndicator = currentIndicator; + rec.frame = frame; + rec.layout = layout; m_panes.push_back(rec); frame->setLayout(layout); - addWidget(frame); + m_splitter->addWidget(frame); connect(pane, SIGNAL(propertyContainerAdded(PropertyContainer *)), this, SLOT(propertyContainerAdded(PropertyContainer *))); @@ -93,6 +116,39 @@ return pane; } +void +PaneStack::setLayoutStyle(LayoutStyle style) +{ + if (style == m_layoutStyle) return; + m_layoutStyle = style; + + std::vector<PaneRec>::iterator i; + + switch (style) { + + case SinglePropertyStackLayout: + + for (i = m_panes.begin(); i != m_panes.end(); ++i) { + i->layout->removeWidget(i->propertyStack); + i->propertyStack->setParent(m_propertyStackStack); + m_propertyStackStack->addWidget(i->propertyStack); + } + m_propertyStackStack->show(); + break; + + case PropertyStackPerPaneLayout: + + for (i = m_panes.begin(); i != m_panes.end(); ++i) { + m_propertyStackStack->removeWidget(i->propertyStack); + i->propertyStack->setParent(i->frame); + i->layout->addWidget(i->propertyStack); + i->propertyStack->show(); + } + m_propertyStackStack->hide(); + break; + } +} + Pane * PaneStack::getPane(int n) { @@ -139,7 +195,7 @@ if (m_currentPane == pane) { if (m_panes.size() > 0) { - setCurrentPane(m_panes[0].pane); + setCurrentPane(m_panes[0].pane); } else { setCurrentPane(0); } @@ -232,6 +288,9 @@ while (i != m_panes.end()) { if (i->pane == pane) { i->currentIndicator->setPixmap(selectedMap); + if (m_layoutStyle == SinglePropertyStackLayout) { + m_propertyStackStack->setCurrentWidget(i->propertyStack); + } found = true; } else { i->currentIndicator->setPixmap(unselectedMap); @@ -360,6 +419,8 @@ int setWidth = maxMinWidth; #endif + m_propertyStackStack->setMaximumWidth(setWidth + 10); + for (size_t i = 0; i < m_panes.size(); ++i) { if (!m_panes[i].propertyStack) continue; m_panes[i].propertyStack->setMinimumWidth(setWidth);
--- a/widgets/PaneStack.h Mon Jun 19 16:14:16 2006 +0000 +++ b/widgets/PaneStack.h Mon Jun 26 16:08:57 2006 +0000 @@ -17,10 +17,13 @@ #ifndef _PANESTACK_H_ #define _PANESTACK_H_ -#include <QSplitter> +#include <QFrame> class QWidget; class QLabel; +class QStackedWidget; +class QSplitter; +class QHBoxLayout; class View; class Pane; class Layer; @@ -28,7 +31,7 @@ class PropertyContainer; class PropertyStack; -class PaneStack : public QSplitter +class PaneStack : public QFrame { Q_OBJECT @@ -51,6 +54,14 @@ void setCurrentLayer(Pane *pane, Layer *layer); Pane *getCurrentPane(); + enum LayoutStyle { + SinglePropertyStackLayout = 1, + PropertyStackPerPaneLayout = 2 + }; + + LayoutStyle getLayoutStyle() const { return m_layoutStyle; } + void setLayoutStyle(LayoutStyle style); + signals: void currentPaneChanged(Pane *pane); void currentLayerChanged(Pane *pane, Layer *layer); @@ -68,16 +79,23 @@ struct PaneRec { - Pane *pane; - QWidget *propertyStack; - QLabel *currentIndicator; + Pane *pane; + QWidget *propertyStack; + QLabel *currentIndicator; + QFrame *frame; + QHBoxLayout *layout; }; std::vector<PaneRec> m_panes; std::vector<PaneRec> m_hiddenPanes; + QSplitter *m_splitter; + QStackedWidget *m_propertyStackStack; + ViewManager *m_viewManager; // I don't own this void sizePropertyStacks(); + + LayoutStyle m_layoutStyle; }; #endif
--- a/widgets/PropertyBox.cpp Mon Jun 19 16:14:16 2006 +0000 +++ b/widgets/PropertyBox.cpp Mon Jun 26 16:08:57 2006 +0000 @@ -284,7 +284,7 @@ connect(cb, SIGNAL(stateChanged(int)), this, SLOT(propertyControllerChanged(int))); if (inGroup) { - cb->setToolTip(name); + cb->setToolTip(propertyLabel); m_groupLayouts[groupName]->addWidget(cb); } else { m_layout->addWidget(cb, row, 1, 1, 2); @@ -324,7 +324,7 @@ if (inGroup) { dial->setFixedWidth(24); dial->setFixedHeight(24); - dial->setToolTip(name); + dial->setToolTip(propertyLabel); m_groupLayouts[groupName]->addWidget(dial); } else { dial->setFixedWidth(32); @@ -382,7 +382,7 @@ this, SLOT(propertyControllerChanged(int))); if (inGroup) { - cb->setToolTip(name); + cb->setToolTip(propertyLabel); m_groupLayouts[groupName]->addWidget(cb); } else { m_layout->addWidget(cb, row, 1, 1, 2);