forked from qt-creator/qt-creator
ImageViewer: Improve tool bar size and behavior
Merge the various export functionality into one tool button instead of three, for this not-so-often used functionality. Put the actions into a QToolBar, so if the editor area is made so small that not all actions fit anymore, the tool bar gets the standard extension button for accessing the "overflowing" ones. Fixes: QTCREATORBUG-28309 Change-Id: I2e1fcee9414038aca49648f18f61e1f15ecf3e5a Reviewed-by: <github-actions-qt-creator@cristianadam.eu> Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org> Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
This commit is contained in:
@@ -5,34 +5,42 @@
|
|||||||
#include "actionmanager.h"
|
#include "actionmanager.h"
|
||||||
#include "command.h"
|
#include "command.h"
|
||||||
|
|
||||||
|
|
||||||
#include <utils/proxyaction.h>
|
#include <utils/proxyaction.h>
|
||||||
|
#include <utils/qtcassert.h>
|
||||||
|
|
||||||
using namespace Core;
|
using namespace Core;
|
||||||
using namespace Utils;
|
using namespace Utils;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\class Core::CommandAction
|
||||||
|
\inheaderfile coreplugin/actionmanager/commandbutton.h
|
||||||
|
\inmodule QtCreator
|
||||||
|
|
||||||
|
\brief The CommandAction class is an action associated with one of
|
||||||
|
the registered Command objects.
|
||||||
|
|
||||||
|
It shares the icon and text of the command.
|
||||||
|
The tooltip of the action consists of toolTipBase property value and Command's
|
||||||
|
key sequence which is automatically updated when user changes it.
|
||||||
|
*/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\class Core::CommandButton
|
\class Core::CommandButton
|
||||||
\inheaderfile coreplugin/actionmanager/commandbutton.h
|
\inheaderfile coreplugin/actionmanager/commandbutton.h
|
||||||
\inmodule QtCreator
|
\inmodule QtCreator
|
||||||
|
|
||||||
\brief The CommandButton class is a tool button associated with one of
|
\brief The CommandButton class is an action associated with one of
|
||||||
the registered Command objects.
|
the registered Command objects.
|
||||||
|
|
||||||
Tooltip of this button consists of toolTipBase property value and Command's
|
The tooltip of the button consists of toolTipBase property value and Command's
|
||||||
key sequence which is automatically updated when user changes it.
|
key sequence which is automatically updated when user changes it.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*!
|
|
||||||
\property CommandButton::toolTipBase
|
|
||||||
\brief The tool tip base for the command button.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\internal
|
\internal
|
||||||
*/
|
*/
|
||||||
CommandButton::CommandButton(QWidget *parent)
|
CommandAction::CommandAction(QWidget *parent)
|
||||||
: QToolButton(parent)
|
: QAction(parent)
|
||||||
, m_command(nullptr)
|
, m_command(nullptr)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
@@ -40,8 +48,8 @@ CommandButton::CommandButton(QWidget *parent)
|
|||||||
/*!
|
/*!
|
||||||
\internal
|
\internal
|
||||||
*/
|
*/
|
||||||
CommandButton::CommandButton(Id id, QWidget *parent)
|
CommandAction::CommandAction(Id id, QWidget *parent)
|
||||||
: QToolButton(parent)
|
: QAction(parent)
|
||||||
, m_command(nullptr)
|
, m_command(nullptr)
|
||||||
{
|
{
|
||||||
setCommandId(id);
|
setCommandId(id);
|
||||||
@@ -50,12 +58,83 @@ CommandButton::CommandButton(Id id, QWidget *parent)
|
|||||||
/*!
|
/*!
|
||||||
Sets the ID of the command associated with this tool button to \a id.
|
Sets the ID of the command associated with this tool button to \a id.
|
||||||
*/
|
*/
|
||||||
void CommandButton::setCommandId(Id id)
|
void CommandAction::setCommandId(Id id)
|
||||||
{
|
{
|
||||||
if (m_command)
|
if (m_command)
|
||||||
disconnect(m_command.data(), &Command::keySequenceChanged, this, &CommandButton::updateToolTip);
|
disconnect(m_command.data(),
|
||||||
|
&Command::keySequenceChanged,
|
||||||
|
this,
|
||||||
|
&CommandAction::updateToolTip);
|
||||||
|
|
||||||
m_command = ActionManager::command(id);
|
m_command = ActionManager::command(id);
|
||||||
|
QTC_ASSERT(m_command, return);
|
||||||
|
|
||||||
|
if (m_toolTipBase.isEmpty())
|
||||||
|
m_toolTipBase = m_command->description();
|
||||||
|
|
||||||
|
setIcon(m_command->action()->icon());
|
||||||
|
setIconText(m_command->action()->iconText());
|
||||||
|
setText(m_command->action()->text());
|
||||||
|
|
||||||
|
updateToolTip();
|
||||||
|
connect(m_command.data(), &Command::keySequenceChanged, this, &CommandAction::updateToolTip);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
The base tool tip that is extended with the command's shortcut.
|
||||||
|
Defaults to the command's description.
|
||||||
|
|
||||||
|
\sa Command::description()
|
||||||
|
*/
|
||||||
|
QString CommandAction::toolTipBase() const
|
||||||
|
{
|
||||||
|
return m_toolTipBase;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Sets the base tool tip that is extended with the command's shortcut.
|
||||||
|
|
||||||
|
\sa toolTipBase()
|
||||||
|
*/
|
||||||
|
void CommandAction::setToolTipBase(const QString &toolTipBase)
|
||||||
|
{
|
||||||
|
m_toolTipBase = toolTipBase;
|
||||||
|
updateToolTip();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CommandAction::updateToolTip()
|
||||||
|
{
|
||||||
|
if (m_command)
|
||||||
|
setToolTip(Utils::ProxyAction::stringWithAppendedShortcut(m_toolTipBase,
|
||||||
|
m_command->keySequence()));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\internal
|
||||||
|
*/
|
||||||
|
CommandButton::CommandButton(QWidget *parent)
|
||||||
|
: QToolButton(parent)
|
||||||
|
{}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\internal
|
||||||
|
*/
|
||||||
|
CommandButton::CommandButton(Utils::Id id, QWidget *parent)
|
||||||
|
: QToolButton(parent)
|
||||||
|
{
|
||||||
|
setCommandId(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CommandButton::setCommandId(Utils::Id id)
|
||||||
|
{
|
||||||
|
if (m_command)
|
||||||
|
disconnect(m_command.data(),
|
||||||
|
&Command::keySequenceChanged,
|
||||||
|
this,
|
||||||
|
&CommandButton::updateToolTip);
|
||||||
|
|
||||||
|
m_command = ActionManager::command(id);
|
||||||
|
QTC_ASSERT(m_command, return);
|
||||||
|
|
||||||
if (m_toolTipBase.isEmpty())
|
if (m_toolTipBase.isEmpty())
|
||||||
m_toolTipBase = m_command->description();
|
m_toolTipBase = m_command->description();
|
||||||
@@ -64,11 +143,22 @@ void CommandButton::setCommandId(Id id)
|
|||||||
connect(m_command.data(), &Command::keySequenceChanged, this, &CommandButton::updateToolTip);
|
connect(m_command.data(), &Command::keySequenceChanged, this, &CommandButton::updateToolTip);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
The base tool tip that is extended with the command's shortcut.
|
||||||
|
Defaults to the command's description.
|
||||||
|
|
||||||
|
\sa Command::description()
|
||||||
|
*/
|
||||||
QString CommandButton::toolTipBase() const
|
QString CommandButton::toolTipBase() const
|
||||||
{
|
{
|
||||||
return m_toolTipBase;
|
return m_toolTipBase;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Sets the base tool tip that is extended with the command's shortcut.
|
||||||
|
|
||||||
|
\sa toolTipBase()
|
||||||
|
*/
|
||||||
void CommandButton::setToolTipBase(const QString &toolTipBase)
|
void CommandButton::setToolTipBase(const QString &toolTipBase)
|
||||||
{
|
{
|
||||||
m_toolTipBase = toolTipBase;
|
m_toolTipBase = toolTipBase;
|
||||||
|
@@ -15,10 +15,28 @@ namespace Core {
|
|||||||
|
|
||||||
class Command;
|
class Command;
|
||||||
|
|
||||||
|
class CORE_EXPORT CommandAction : public QAction
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
explicit CommandAction(QWidget *parent = nullptr);
|
||||||
|
explicit CommandAction(Utils::Id id, QWidget *parent = nullptr);
|
||||||
|
void setCommandId(Utils::Id id);
|
||||||
|
QString toolTipBase() const;
|
||||||
|
void setToolTipBase(const QString &toolTipBase);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void updateToolTip();
|
||||||
|
|
||||||
|
QPointer<Command> m_command;
|
||||||
|
QString m_toolTipBase;
|
||||||
|
};
|
||||||
|
|
||||||
class CORE_EXPORT CommandButton : public QToolButton
|
class CORE_EXPORT CommandButton : public QToolButton
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY(QString toolTipBase READ toolTipBase WRITE setToolTipBase)
|
|
||||||
public:
|
public:
|
||||||
explicit CommandButton(QWidget *parent = nullptr);
|
explicit CommandButton(QWidget *parent = nullptr);
|
||||||
explicit CommandButton(Utils::Id id, QWidget *parent = nullptr);
|
explicit CommandButton(Utils::Id id, QWidget *parent = nullptr);
|
||||||
@@ -32,5 +50,4 @@ private:
|
|||||||
QPointer<Command> m_command;
|
QPointer<Command> m_command;
|
||||||
QString m_toolTipBase;
|
QString m_toolTipBase;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -28,8 +28,9 @@
|
|||||||
#include <QImageReader>
|
#include <QImageReader>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QMap>
|
#include <QMap>
|
||||||
|
#include <QMenu>
|
||||||
#include <QSpacerItem>
|
#include <QSpacerItem>
|
||||||
#include <QWidget>
|
#include <QToolBar>
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
|
|
||||||
using namespace Core;
|
using namespace Core;
|
||||||
@@ -44,16 +45,17 @@ struct ImageViewerPrivate
|
|||||||
ImageView *imageView;
|
ImageView *imageView;
|
||||||
QWidget *toolbar;
|
QWidget *toolbar;
|
||||||
|
|
||||||
CommandButton *toolButtonExportImage;
|
QToolButton *shareButton;
|
||||||
CommandButton *toolButtonMultiExportImages;
|
CommandAction *actionExportImage;
|
||||||
CommandButton *toolButtonCopyDataUrl;
|
CommandAction *actionMultiExportImages;
|
||||||
CommandButton *toolButtonBackground;
|
CommandAction *actionButtonCopyDataUrl;
|
||||||
CommandButton *toolButtonOutline;
|
CommandAction *actionBackground;
|
||||||
CommandButton *toolButtonFitToScreen;
|
CommandAction *actionOutline;
|
||||||
CommandButton *toolButtonOriginalSize;
|
CommandAction *actionFitToScreen;
|
||||||
CommandButton *toolButtonZoomIn;
|
CommandAction *actionOriginalSize;
|
||||||
CommandButton *toolButtonZoomOut;
|
CommandAction *actionZoomIn;
|
||||||
CommandButton *toolButtonPlayPause;
|
CommandAction *actionZoomOut;
|
||||||
|
CommandAction *actionPlayPause;
|
||||||
QLabel *labelImageSize;
|
QLabel *labelImageSize;
|
||||||
QLabel *labelInfo;
|
QLabel *labelInfo;
|
||||||
};
|
};
|
||||||
@@ -63,12 +65,12 @@ struct ImageViewerPrivate
|
|||||||
from the current theme. Returns \c true if icon is updated, \c false
|
from the current theme. Returns \c true if icon is updated, \c false
|
||||||
otherwise.
|
otherwise.
|
||||||
*/
|
*/
|
||||||
static bool updateButtonIconByTheme(QAbstractButton *button, const QString &name)
|
static bool updateIconByTheme(QAction *action, const QString &name)
|
||||||
{
|
{
|
||||||
QTC_ASSERT(!name.isEmpty(), return false);
|
QTC_ASSERT(!name.isEmpty(), return false);
|
||||||
|
|
||||||
if (QIcon::hasThemeIcon(name)) {
|
if (QIcon::hasThemeIcon(name)) {
|
||||||
button->setIcon(QIcon::fromTheme(name));
|
action->setIcon(QIcon::fromTheme(name));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -100,135 +102,116 @@ void ImageViewer::ctor()
|
|||||||
setDuplicateSupported(true);
|
setDuplicateSupported(true);
|
||||||
|
|
||||||
// toolbar
|
// toolbar
|
||||||
d->toolbar = new QWidget;
|
d->toolbar = new StyledBar;
|
||||||
|
|
||||||
d->toolButtonExportImage = new CommandButton;
|
d->actionExportImage = new CommandAction(Constants::ACTION_EXPORT_IMAGE, d->toolbar);
|
||||||
d->toolButtonMultiExportImages = new CommandButton;
|
d->actionMultiExportImages = new CommandAction(Constants::ACTION_EXPORT_MULTI_IMAGES,
|
||||||
d->toolButtonCopyDataUrl = new CommandButton;
|
d->toolbar);
|
||||||
d->toolButtonBackground = new CommandButton;
|
d->actionButtonCopyDataUrl = new CommandAction(Constants::ACTION_COPY_DATA_URL, d->toolbar);
|
||||||
d->toolButtonOutline = new CommandButton;
|
d->shareButton = new QToolButton;
|
||||||
d->toolButtonFitToScreen = new CommandButton;
|
d->shareButton->setToolTip(Tr::tr("Export"));
|
||||||
d->toolButtonOriginalSize = new CommandButton;
|
d->shareButton->setPopupMode(QToolButton::InstantPopup);
|
||||||
d->toolButtonZoomIn = new CommandButton;
|
d->shareButton->setIcon(Icons::EXPORTFILE_TOOLBAR.icon());
|
||||||
d->toolButtonZoomOut = new CommandButton;
|
d->shareButton->setProperty("noArrow", true);
|
||||||
d->toolButtonPlayPause = new CommandButton;
|
auto shareMenu = new QMenu(d->shareButton);
|
||||||
|
shareMenu->addAction(d->actionExportImage);
|
||||||
|
shareMenu->addAction(d->actionMultiExportImages);
|
||||||
|
shareMenu->addAction(d->actionButtonCopyDataUrl);
|
||||||
|
d->shareButton->setMenu(shareMenu);
|
||||||
|
|
||||||
d->toolButtonBackground->setCheckable(true);
|
d->actionBackground = new CommandAction(Constants::ACTION_BACKGROUND, d->toolbar);
|
||||||
d->toolButtonBackground->setChecked(settings.showBackground);
|
d->actionOutline = new CommandAction(Constants::ACTION_OUTLINE, d->toolbar);
|
||||||
|
d->actionFitToScreen = new CommandAction(Constants::ACTION_FIT_TO_SCREEN, d->toolbar);
|
||||||
|
d->actionOriginalSize = new CommandAction(Core::Constants::ZOOM_RESET, d->toolbar);
|
||||||
|
d->actionZoomIn = new CommandAction(Core::Constants::ZOOM_IN, d->toolbar);
|
||||||
|
d->actionZoomOut = new CommandAction(Core::Constants::ZOOM_OUT, d->toolbar);
|
||||||
|
d->actionPlayPause = new CommandAction(Constants::ACTION_TOGGLE_ANIMATION, d->toolbar);
|
||||||
|
|
||||||
d->toolButtonOutline->setCheckable(true);
|
d->actionBackground->setCheckable(true);
|
||||||
d->toolButtonOutline->setChecked(settings.showOutline);
|
d->actionBackground->setChecked(settings.showBackground);
|
||||||
|
|
||||||
d->toolButtonFitToScreen->setCheckable(true);
|
d->actionOutline->setCheckable(true);
|
||||||
d->toolButtonFitToScreen->setChecked(settings.fitToScreen);
|
d->actionOutline->setChecked(settings.showOutline);
|
||||||
|
|
||||||
d->toolButtonZoomIn->setAutoRepeat(true);
|
d->actionFitToScreen->setCheckable(true);
|
||||||
|
d->actionFitToScreen->setChecked(settings.fitToScreen);
|
||||||
|
|
||||||
d->toolButtonZoomOut->setAutoRepeat(true);
|
d->actionZoomIn->setAutoRepeat(true);
|
||||||
|
|
||||||
d->toolButtonExportImage->setToolTipBase(Tr::tr("Export as Image"));
|
d->actionZoomOut->setAutoRepeat(true);
|
||||||
d->toolButtonMultiExportImages->setToolTipBase(Tr::tr("Export Images of Multiple Sizes"));
|
|
||||||
d->toolButtonOutline->setToolTipBase(Tr::tr("Show Outline"));
|
|
||||||
d->toolButtonFitToScreen->setToolTipBase(Tr::tr("Fit to Screen"));
|
|
||||||
d->toolButtonOriginalSize->setToolTipBase(Tr::tr("Original Size"));
|
|
||||||
d->toolButtonZoomIn->setToolTipBase(Tr::tr("Zoom In"));
|
|
||||||
d->toolButtonZoomOut->setToolTipBase(Tr::tr("Zoom Out"));
|
|
||||||
|
|
||||||
d->toolButtonExportImage->setIcon(Icons::EXPORTFILE_TOOLBAR.icon());
|
|
||||||
d->toolButtonMultiExportImages->setIcon(Icons::MULTIEXPORTFILE_TOOLBAR.icon());
|
|
||||||
d->toolButtonCopyDataUrl->setIcon(Icons::COPY_TOOLBAR.icon());
|
|
||||||
const Icon backgroundIcon({{":/utils/images/desktopdevicesmall.png", Theme::IconsBaseColor}});
|
const Icon backgroundIcon({{":/utils/images/desktopdevicesmall.png", Theme::IconsBaseColor}});
|
||||||
d->toolButtonBackground->setIcon(backgroundIcon.icon());
|
d->actionBackground->setIcon(backgroundIcon.icon());
|
||||||
d->toolButtonOutline->setIcon(Icons::BOUNDING_RECT.icon());
|
d->actionOutline->setIcon(Icons::BOUNDING_RECT.icon());
|
||||||
d->toolButtonZoomIn->setIcon(
|
d->actionZoomIn->setIcon(ActionManager::command(Core::Constants::ZOOM_IN)->action()->icon());
|
||||||
ActionManager::command(Core::Constants::ZOOM_IN)->action()->icon());
|
d->actionZoomOut->setIcon(ActionManager::command(Core::Constants::ZOOM_OUT)->action()->icon());
|
||||||
d->toolButtonZoomOut->setIcon(
|
d->actionOriginalSize->setIcon(
|
||||||
ActionManager::command(Core::Constants::ZOOM_OUT)->action()->icon());
|
ActionManager::command(Core::Constants::ZOOM_RESET)->action()->icon());
|
||||||
d->toolButtonOriginalSize->setIcon(
|
d->actionFitToScreen->setIcon(Icons::FITTOVIEW_TOOLBAR.icon());
|
||||||
ActionManager::command(Core::Constants::ZOOM_RESET)->action()->icon());
|
|
||||||
d->toolButtonFitToScreen->setIcon(Icons::FITTOVIEW_TOOLBAR.icon());
|
|
||||||
|
|
||||||
// icons update - try to use system theme
|
// icons update - try to use system theme
|
||||||
updateButtonIconByTheme(d->toolButtonFitToScreen, QLatin1String("zoom-fit-best"));
|
updateIconByTheme(d->actionFitToScreen, QLatin1String("zoom-fit-best"));
|
||||||
// a display - something is on the background
|
// a display - something is on the background
|
||||||
updateButtonIconByTheme(d->toolButtonBackground, QLatin1String("video-display"));
|
updateIconByTheme(d->actionBackground, QLatin1String("video-display"));
|
||||||
// "emblem to specify the directory where the user stores photographs"
|
// "emblem to specify the directory where the user stores photographs"
|
||||||
// (photograph has outline - piece of paper)
|
// (photograph has outline - piece of paper)
|
||||||
updateButtonIconByTheme(d->toolButtonOutline, QLatin1String("emblem-photos"));
|
updateIconByTheme(d->actionOutline, QLatin1String("emblem-photos"));
|
||||||
|
|
||||||
auto setAsDefaultButton = new QToolButton;
|
auto setAsDefault = new QAction(Tr::tr("Set as Default"), d->toolbar);
|
||||||
auto setAsDefault = new QAction(Tr::tr("Set as Default"), setAsDefaultButton);
|
|
||||||
setAsDefault->setToolTip(Tr::tr("Use the current settings for background, outline, and fitting "
|
setAsDefault->setToolTip(Tr::tr("Use the current settings for background, outline, and fitting "
|
||||||
"to screen as the default for new image viewers."));
|
"to screen as the default for new image viewers."));
|
||||||
setAsDefaultButton->setDefaultAction(setAsDefault);
|
|
||||||
|
|
||||||
d->toolButtonExportImage->setCommandId(Constants::ACTION_EXPORT_IMAGE);
|
|
||||||
d->toolButtonMultiExportImages->setCommandId(Constants::ACTION_EXPORT_MULTI_IMAGES);
|
|
||||||
d->toolButtonCopyDataUrl->setCommandId(Constants::ACTION_COPY_DATA_URL);
|
|
||||||
d->toolButtonZoomIn->setCommandId(Core::Constants::ZOOM_IN);
|
|
||||||
d->toolButtonZoomOut->setCommandId(Core::Constants::ZOOM_OUT);
|
|
||||||
d->toolButtonOriginalSize->setCommandId(Core::Constants::ZOOM_RESET);
|
|
||||||
d->toolButtonFitToScreen->setCommandId(Constants::ACTION_FIT_TO_SCREEN);
|
|
||||||
d->toolButtonBackground->setCommandId(Constants::ACTION_BACKGROUND);
|
|
||||||
d->toolButtonOutline->setCommandId(Constants::ACTION_OUTLINE);
|
|
||||||
d->toolButtonPlayPause->setCommandId(Constants::ACTION_TOGGLE_ANIMATION);
|
|
||||||
|
|
||||||
d->labelImageSize = new QLabel;
|
d->labelImageSize = new QLabel;
|
||||||
d->labelInfo = new QLabel;
|
d->labelInfo = new QLabel;
|
||||||
|
|
||||||
|
auto bar = new QToolBar;
|
||||||
|
bar->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::Minimum);
|
||||||
|
|
||||||
|
bar->addWidget(d->shareButton);
|
||||||
|
bar->addSeparator();
|
||||||
|
bar->addAction(d->actionOriginalSize);
|
||||||
|
bar->addAction(d->actionZoomIn);
|
||||||
|
bar->addAction(d->actionZoomOut);
|
||||||
|
bar->addAction(d->actionPlayPause);
|
||||||
|
bar->addAction(d->actionPlayPause);
|
||||||
|
bar->addSeparator();
|
||||||
|
bar->addAction(d->actionBackground);
|
||||||
|
bar->addAction(d->actionOutline);
|
||||||
|
bar->addAction(d->actionFitToScreen);
|
||||||
|
bar->addAction(setAsDefault);
|
||||||
|
|
||||||
auto horizontalLayout = new QHBoxLayout(d->toolbar);
|
auto horizontalLayout = new QHBoxLayout(d->toolbar);
|
||||||
horizontalLayout->setSpacing(0);
|
horizontalLayout->setSpacing(0);
|
||||||
horizontalLayout->setContentsMargins(0, 0, 0, 0);
|
horizontalLayout->setContentsMargins(0, 0, 0, 0);
|
||||||
horizontalLayout->addWidget(d->toolButtonExportImage);
|
horizontalLayout->addWidget(bar);
|
||||||
horizontalLayout->addWidget(d->toolButtonMultiExportImages);
|
horizontalLayout->addItem(
|
||||||
horizontalLayout->addWidget(d->toolButtonCopyDataUrl);
|
new QSpacerItem(315, 20, QSizePolicy::Expanding, QSizePolicy::Minimum));
|
||||||
horizontalLayout->addWidget(new StyledSeparator);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonBackground);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonOutline);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonFitToScreen);
|
|
||||||
horizontalLayout->addWidget(setAsDefaultButton);
|
|
||||||
horizontalLayout->addWidget(new StyledSeparator);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonOriginalSize);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonZoomIn);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonZoomOut);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonPlayPause);
|
|
||||||
horizontalLayout->addWidget(d->toolButtonPlayPause);
|
|
||||||
horizontalLayout->addWidget(new StyledSeparator);
|
|
||||||
horizontalLayout->addItem(new QSpacerItem(315, 20, QSizePolicy::Expanding, QSizePolicy::Minimum));
|
|
||||||
horizontalLayout->addWidget(new StyledSeparator);
|
horizontalLayout->addWidget(new StyledSeparator);
|
||||||
horizontalLayout->addWidget(d->labelImageSize);
|
horizontalLayout->addWidget(d->labelImageSize);
|
||||||
horizontalLayout->addWidget(new StyledSeparator);
|
horizontalLayout->addWidget(new StyledSeparator);
|
||||||
horizontalLayout->addWidget(d->labelInfo);
|
horizontalLayout->addWidget(d->labelInfo);
|
||||||
|
|
||||||
// connections
|
// connections
|
||||||
connect(d->toolButtonExportImage, &QAbstractButton::clicked,
|
connect(d->actionExportImage, &QAction::triggered, d->imageView, &ImageView::exportImage);
|
||||||
d->imageView, &ImageView::exportImage);
|
connect(d->actionMultiExportImages,
|
||||||
connect(d->toolButtonMultiExportImages, &QAbstractButton::clicked,
|
&QAction::triggered,
|
||||||
d->imageView, &ImageView::exportMultiImages);
|
|
||||||
connect(d->toolButtonCopyDataUrl, &QAbstractButton::clicked,
|
|
||||||
d->imageView, &ImageView::copyDataUrl);
|
|
||||||
connect(d->toolButtonZoomIn, &QAbstractButton::clicked,
|
|
||||||
d->imageView, &ImageView::zoomIn);
|
|
||||||
connect(d->toolButtonZoomOut, &QAbstractButton::clicked,
|
|
||||||
d->imageView, &ImageView::zoomOut);
|
|
||||||
connect(d->toolButtonFitToScreen,
|
|
||||||
&QAbstractButton::toggled,
|
|
||||||
d->imageView,
|
d->imageView,
|
||||||
&ImageView::setFitToScreen);
|
&ImageView::exportMultiImages);
|
||||||
|
connect(d->actionButtonCopyDataUrl, &QAction::triggered, d->imageView, &ImageView::copyDataUrl);
|
||||||
|
connect(d->actionZoomIn, &QAction::triggered, d->imageView, &ImageView::zoomIn);
|
||||||
|
connect(d->actionZoomOut, &QAction::triggered, d->imageView, &ImageView::zoomOut);
|
||||||
|
connect(d->actionFitToScreen, &QAction::triggered, d->imageView, &ImageView::setFitToScreen);
|
||||||
connect(d->imageView,
|
connect(d->imageView,
|
||||||
&ImageView::fitToScreenChanged,
|
&ImageView::fitToScreenChanged,
|
||||||
d->toolButtonFitToScreen,
|
d->actionFitToScreen,
|
||||||
&QAbstractButton::setChecked);
|
&QAction::setChecked);
|
||||||
connect(d->toolButtonOriginalSize,
|
connect(d->actionOriginalSize,
|
||||||
&QAbstractButton::clicked,
|
&QAction::triggered,
|
||||||
d->imageView,
|
d->imageView,
|
||||||
&ImageView::resetToOriginalSize);
|
&ImageView::resetToOriginalSize);
|
||||||
connect(d->toolButtonBackground, &QAbstractButton::toggled,
|
connect(d->actionBackground, &QAction::toggled, d->imageView, &ImageView::setViewBackground);
|
||||||
d->imageView, &ImageView::setViewBackground);
|
connect(d->actionOutline, &QAction::toggled, d->imageView, &ImageView::setViewOutline);
|
||||||
connect(d->toolButtonOutline, &QAbstractButton::toggled,
|
connect(d->actionPlayPause, &QAction::triggered, this, &ImageViewer::playToggled);
|
||||||
d->imageView, &ImageView::setViewOutline);
|
|
||||||
connect(d->toolButtonPlayPause, &CommandButton::clicked,
|
|
||||||
this, &ImageViewer::playToggled);
|
|
||||||
connect(d->file.data(), &ImageViewerFile::imageSizeChanged,
|
connect(d->file.data(), &ImageViewerFile::imageSizeChanged,
|
||||||
this, &ImageViewer::imageSizeUpdated);
|
this, &ImageViewer::imageSizeUpdated);
|
||||||
connect(d->file.data(), &ImageViewerFile::openFinished,
|
connect(d->file.data(), &ImageViewerFile::openFinished,
|
||||||
@@ -280,18 +263,18 @@ IEditor *ImageViewer::duplicate()
|
|||||||
void ImageViewer::exportImage()
|
void ImageViewer::exportImage()
|
||||||
{
|
{
|
||||||
if (d->file->type() == ImageViewerFile::TypeSvg)
|
if (d->file->type() == ImageViewerFile::TypeSvg)
|
||||||
d->toolButtonExportImage->click();
|
d->actionExportImage->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::exportMultiImages()
|
void ImageViewer::exportMultiImages()
|
||||||
{
|
{
|
||||||
if (d->file->type() == ImageViewerFile::TypeSvg)
|
if (d->file->type() == ImageViewerFile::TypeSvg)
|
||||||
d->toolButtonMultiExportImages->click();
|
d->actionMultiExportImages->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::copyDataUrl()
|
void ImageViewer::copyDataUrl()
|
||||||
{
|
{
|
||||||
d->toolButtonCopyDataUrl->click();
|
d->actionButtonCopyDataUrl->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::imageSizeUpdated(const QSize &size)
|
void ImageViewer::imageSizeUpdated(const QSize &size)
|
||||||
@@ -310,45 +293,45 @@ void ImageViewer::scaleFactorUpdate(qreal factor)
|
|||||||
|
|
||||||
void ImageViewer::switchViewBackground()
|
void ImageViewer::switchViewBackground()
|
||||||
{
|
{
|
||||||
d->toolButtonBackground->click();
|
d->actionBackground->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::switchViewOutline()
|
void ImageViewer::switchViewOutline()
|
||||||
{
|
{
|
||||||
d->toolButtonOutline->click();
|
d->actionOutline->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::zoomIn()
|
void ImageViewer::zoomIn()
|
||||||
{
|
{
|
||||||
d->toolButtonZoomIn->click();
|
d->actionZoomIn->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::zoomOut()
|
void ImageViewer::zoomOut()
|
||||||
{
|
{
|
||||||
d->toolButtonZoomOut->click();
|
d->actionZoomOut->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::resetToOriginalSize()
|
void ImageViewer::resetToOriginalSize()
|
||||||
{
|
{
|
||||||
d->toolButtonOriginalSize->click();
|
d->actionOriginalSize->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::fitToScreen()
|
void ImageViewer::fitToScreen()
|
||||||
{
|
{
|
||||||
d->toolButtonFitToScreen->click();
|
d->actionFitToScreen->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::updateToolButtons()
|
void ImageViewer::updateToolButtons()
|
||||||
{
|
{
|
||||||
const bool isSvg = d->file->type() == ImageViewerFile::TypeSvg;
|
const bool isSvg = d->file->type() == ImageViewerFile::TypeSvg;
|
||||||
d->toolButtonExportImage->setEnabled(isSvg);
|
d->actionExportImage->setEnabled(isSvg);
|
||||||
d->toolButtonMultiExportImages->setEnabled(isSvg);
|
d->actionMultiExportImages->setEnabled(isSvg);
|
||||||
updatePauseAction();
|
updatePauseAction();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::togglePlay()
|
void ImageViewer::togglePlay()
|
||||||
{
|
{
|
||||||
d->toolButtonPlayPause->click();
|
d->actionPlayPause->trigger();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageViewer::playToggled()
|
void ImageViewer::playToggled()
|
||||||
@@ -360,12 +343,12 @@ void ImageViewer::updatePauseAction()
|
|||||||
{
|
{
|
||||||
bool isMovie = d->file->type() == ImageViewerFile::TypeMovie;
|
bool isMovie = d->file->type() == ImageViewerFile::TypeMovie;
|
||||||
if (isMovie && !d->file->isPaused()) {
|
if (isMovie && !d->file->isPaused()) {
|
||||||
d->toolButtonPlayPause->setToolTipBase(Tr::tr("Pause Animation"));
|
d->actionPlayPause->setToolTipBase(Tr::tr("Pause Animation"));
|
||||||
d->toolButtonPlayPause->setIcon(Icons::INTERRUPT_SMALL_TOOLBAR.icon());
|
d->actionPlayPause->setIcon(Icons::INTERRUPT_SMALL_TOOLBAR.icon());
|
||||||
} else {
|
} else {
|
||||||
d->toolButtonPlayPause->setToolTipBase(Tr::tr("Play Animation"));
|
d->actionPlayPause->setToolTipBase(Tr::tr("Play Animation"));
|
||||||
d->toolButtonPlayPause->setIcon(Icons::RUN_SMALL_TOOLBAR.icon());
|
d->actionPlayPause->setIcon(Icons::RUN_SMALL_TOOLBAR.icon());
|
||||||
d->toolButtonPlayPause->setEnabled(isMovie);
|
d->actionPlayPause->setEnabled(isMovie);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user