Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Hide viewer buttons when roto/tracker properties panel is minimized #748

Merged
merged 4 commits into from
Jan 11, 2022
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Documentation/source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@
version_22 = '2.2.10'
version_23 = '2.3.16'
version_24 = '2.4.3'
version_24 = '2.5.0'
version_25 = '2.5.0'
version_30 = '3.0.0'

# The version for this branch
Expand Down
40 changes: 34 additions & 6 deletions Gui/NodeGui.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -434,6 +434,8 @@ NodeGui::ensurePanelCreated(bool minimized, bool hideUnmodified)
if (_settingsPanel) {
QObject::connect( _settingsPanel, SIGNAL(nameChanged(QString)), this, SLOT(setName(QString)) );
QObject::connect( _settingsPanel, SIGNAL(closeChanged(bool)), this, SLOT(onSettingsPanelClosed(bool)) );
QObject::connect( _settingsPanel, SIGNAL(minimized()), this, SLOT(onSettingsPanelMinimized()) );
QObject::connect( _settingsPanel, SIGNAL(maximized()), this, SLOT(onSettingsPanelMaximized()) );
QObject::connect( _settingsPanel, SIGNAL(colorChanged(QColor)), this, SLOT(onSettingsPanelColorChanged(QColor)) );

_graph->getGui()->setNodeViewerInterface(thisShared);
Expand Down Expand Up @@ -497,6 +499,32 @@ NodeGui::onSettingsPanelClosed(bool closed)
Q_EMIT settingsPanelClosed(closed);
}

void
NodeGui::onSettingsPanelMinimized()
{
NodePtr internalNode = getNode();
if (internalNode && internalNode->hasAnyPersistentMessage()) {
const std::list<ViewerTab*>& viewers = getDagGui()->getGui()->getViewersList();
for (std::list<ViewerTab*>::const_iterator it = viewers.begin(); it != viewers.end(); ++it) {
(*it)->getViewer()->updatePersistentMessage();
}
}
Q_EMIT settingsPanelMinimized();
}

void
NodeGui::onSettingsPanelMaximized()
{
NodePtr internalNode = getNode();
if (internalNode && internalNode->hasAnyPersistentMessage()) {
const std::list<ViewerTab*>& viewers = getDagGui()->getGui()->getViewersList();
for (std::list<ViewerTab*>::const_iterator it = viewers.begin(); it != viewers.end(); ++it) {
(*it)->getViewer()->updatePersistentMessage();
}
}
Q_EMIT settingsPanelMaximized();
}

NodeSettingsPanel*
NodeGui::createPanel(QVBoxLayout* container,
const NodeGuiPtr& thisAsShared)
Expand Down Expand Up @@ -2102,23 +2130,23 @@ NodeGui::setVisibleSettingsPanel(bool b, bool m, bool h)
}
if (_settingsPanel) {
_settingsPanel->setClosed(!b);
if (b) {
// also maximize (but don't minimize when closing)
_settingsPanel->minimizeOrMaximize(false);
}
}
}

bool
NodeGui::isSettingsPanelVisible() const
{
if (_settingsPanel) {
return !_settingsPanel->isClosed();
} else {
return false;
}
return _settingsPanel && !_settingsPanel->isClosed() && !_settingsPanel->isMinimized();
}

bool
NodeGui::isSettingsPanelMinimized() const
{
return _settingsPanel ? _settingsPanel->isMinimized() : false;
return _settingsPanel && _settingsPanel->isMinimized();
}

void
Expand Down
8 changes: 8 additions & 0 deletions Gui/NodeGui.h
Original file line number Diff line number Diff line change
Expand Up @@ -453,6 +453,10 @@ public Q_SLOTS:

void onSettingsPanelClosed(bool closed);

void onSettingsPanelMinimized();

void onSettingsPanelMaximized();

void onSettingsPanelColorChanged(const QColor & color);

void togglePreview();
Expand Down Expand Up @@ -543,6 +547,10 @@ public Q_SLOTS:

void settingsPanelClosed(bool b);

void settingsPanelMinimized();

void settingsPanelMaximized();

void previewImageComputed();

protected:
Expand Down
2 changes: 2 additions & 0 deletions Gui/NodeSettingsPanel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,8 @@ NodeSettingsPanel::NodeSettingsPanel(const MultiInstancePanelPtr & multiPanel,


QObject::connect( this, SIGNAL(closeChanged(bool)), NodeUi.get(), SLOT(onSettingsPanelClosedChanged(bool)) );
QObject::connect( this, SIGNAL(minimized()), NodeUi.get(), SLOT(onSettingsPanelMinimized(bool)) );
QObject::connect( this, SIGNAL(maximized()), NodeUi.get(), SLOT(onSettingsPanelMaximized(bool)) );
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We might have an oopsie here (at least in Qt5)

QObject::connect: No such slot Natron::NodeGui::onSettingsPanelMinimized(bool) in ../../Gui/NodeSettingsPanel.cpp:91
QObject::connect: No such slot Natron::NodeGui::onSettingsPanelMaximized(bool) in ../../Gui/NodeSettingsPanel.cpp:92
QObject::connect: No such slot Natron::NodeGui::onSettingsPanelMinimized(bool) in ../../Gui/NodeSettingsPanel.cpp:91
QObject::connect: No such slot Natron::NodeGui::onSettingsPanelMaximized(bool) in ../../Gui/NodeSettingsPanel.cpp:92

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you! These lines are useless

const QSize mediumBSize( TO_DPIX(NATRON_MEDIUM_BUTTON_SIZE), TO_DPIY(NATRON_MEDIUM_BUTTON_SIZE) );
const QSize mediumIconSize( TO_DPIX(NATRON_MEDIUM_BUTTON_ICON_SIZE), TO_DPIY(NATRON_MEDIUM_BUTTON_ICON_SIZE) );
QPixmap pixSettings;
Expand Down
14 changes: 14 additions & 0 deletions Gui/NodeViewerContext.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -159,6 +159,8 @@ NodeViewerContext::createGui()
QObject::connect( _imp->viewer, SIGNAL(selectionCleared()), this, SLOT(onViewerSelectionCleared()), Qt::UniqueConnection );
NodeGuiPtr node = _imp->getNode();
QObject::connect( node.get(), SIGNAL(settingsPanelClosed(bool)), this, SLOT(onNodeSettingsPanelClosed(bool)), Qt::UniqueConnection );
QObject::connect( node.get(), SIGNAL(settingsPanelMinimized()), this, SLOT(onNodeSettingsPanelMinimized()), Qt::UniqueConnection );
QObject::connect( node.get(), SIGNAL(settingsPanelMaximized()), this, SLOT(onNodeSettingsPanelMaximized()), Qt::UniqueConnection );
KnobsVec knobsOrdered = node->getNode()->getEffectInstance()->getViewerUIKnobs();


Expand Down Expand Up @@ -268,6 +270,18 @@ NodeViewerContext::onNodeSettingsPanelClosed(bool closed)
}
}

void
NodeViewerContext::onNodeSettingsPanelMinimized()
{
return onNodeSettingsPanelClosed(true);
}

void
NodeViewerContext::onNodeSettingsPanelMaximized()
{
return onNodeSettingsPanelClosed(false);
}

int
NodeViewerContext::getItemsSpacingOnSameLine() const
{
Expand Down
4 changes: 4 additions & 0 deletions Gui/NodeViewerContext.h
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,10 @@ public Q_SLOTS:

void onNodeSettingsPanelClosed(bool closed);

void onNodeSettingsPanelMinimized();

void onNodeSettingsPanelMaximized();

private:

boost::scoped_ptr<NodeViewerContextPrivate> _imp;
Expand Down