TextEditor: Add a mechanism to provide dynamic icons and tooltips

... to TextMarks more easily by allowing callbacks in addition to
fixed values.

Change-Id: Ica9e7d54dd1a53a59dc11812857402d0b7594d6c
Reviewed-by: David Schulz <david.schulz@qt.io>
This commit is contained in:
hjk
2020-09-24 10:14:57 +02:00
parent cc502e3667
commit 94df9822f9
2 changed files with 49 additions and 10 deletions

View File

@@ -125,7 +125,7 @@ int TextMark::lineNumber() const
void TextMark::paintIcon(QPainter *painter, const QRect &rect) const void TextMark::paintIcon(QPainter *painter, const QRect &rect) const
{ {
m_icon.paint(painter, rect, Qt::AlignCenter); icon().paint(painter, rect, Qt::AlignCenter);
} }
void TextMark::paintAnnotation(QPainter &painter, QRectF *annotationRect, void TextMark::paintAnnotation(QPainter &painter, QRectF *annotationRect,
@@ -180,7 +180,7 @@ TextMark::AnnotationRects TextMark::annotationRects(const QRectF &boundingRect,
rects.fadeInRect.setWidth(fadeInOffset); rects.fadeInRect.setWidth(fadeInOffset);
rects.annotationRect = boundingRect; rects.annotationRect = boundingRect;
rects.annotationRect.setLeft(rects.fadeInRect.right()); rects.annotationRect.setLeft(rects.fadeInRect.right());
const bool drawIcon = !m_icon.isNull(); const bool drawIcon = !icon().isNull();
constexpr qreal margin = 1; constexpr qreal margin = 1;
rects.iconRect = QRectF(rects.annotationRect.left(), boundingRect.top(), rects.iconRect = QRectF(rects.annotationRect.left(), boundingRect.top(),
0, boundingRect.height()); 0, boundingRect.height());
@@ -284,9 +284,10 @@ void TextMark::addToToolTipLayout(QGridLayout *target) const
// Left column: text mark icon // Left column: text mark icon
const int row = target->rowCount(); const int row = target->rowCount();
if (!m_icon.isNull()) { const QIcon icon = this->icon();
if (!icon.isNull()) {
auto iconLabel = new QLabel; auto iconLabel = new QLabel;
iconLabel->setPixmap(m_icon.pixmap(16, 16)); iconLabel->setPixmap(icon.pixmap(16, 16));
target->addWidget(iconLabel, row, 0, Qt::AlignTop | Qt::AlignHCenter); target->addWidget(iconLabel, row, 0, Qt::AlignTop | Qt::AlignHCenter);
} }
@@ -315,8 +316,10 @@ void TextMark::addToToolTipLayout(QGridLayout *target) const
bool TextMark::addToolTipContent(QLayout *target) const bool TextMark::addToolTipContent(QLayout *target) const
{ {
QString text = m_toolTip; bool useDefaultToolTip = false;
QString text = toolTip();
if (text.isEmpty()) { if (text.isEmpty()) {
useDefaultToolTip = true;
text = m_defaultToolTip; text = m_defaultToolTip;
if (text.isEmpty()) if (text.isEmpty())
return false; return false;
@@ -326,12 +329,28 @@ bool TextMark::addToolTipContent(QLayout *target) const
textLabel->setOpenExternalLinks(true); textLabel->setOpenExternalLinks(true);
textLabel->setText(text); textLabel->setText(text);
// Differentiate between tool tips that where explicitly set and default tool tips. // Differentiate between tool tips that where explicitly set and default tool tips.
textLabel->setEnabled(!m_toolTip.isEmpty()); textLabel->setDisabled(useDefaultToolTip);
target->addWidget(textLabel); target->addWidget(textLabel);
return true; return true;
} }
void TextMark::setIcon(const QIcon &icon)
{
m_icon = icon;
m_iconProvider = std::function<QIcon()>();
}
void TextMark::setIconProvider(const std::function<QIcon ()> &iconProvider)
{
m_iconProvider = iconProvider;
}
const QIcon TextMark::icon() const
{
return m_iconProvider ? m_iconProvider() : m_icon;
}
Utils::optional<Theme::Color> TextMark::color() const Utils::optional<Theme::Color> TextMark::color() const
{ {
return m_color; return m_color;
@@ -342,6 +361,22 @@ void TextMark::setColor(const Theme::Color &color)
m_color = color; m_color = color;
} }
void TextMark::setToolTipProvider(const std::function<QString()> &toolTipProvider)
{
m_toolTipProvider = toolTipProvider;
}
QString TextMark::toolTip() const
{
return m_toolTipProvider ? m_toolTipProvider() : m_toolTip;
}
void TextMark::setToolTip(const QString &toolTip)
{
m_toolTip = toolTip;
m_toolTipProvider = std::function<QString()>();
}
QVector<QAction *> TextMark::actions() const QVector<QAction *> TextMark::actions() const
{ {
return m_actions; return m_actions;

View File

@@ -97,8 +97,9 @@ public:
void addToToolTipLayout(QGridLayout *target) const; void addToToolTipLayout(QGridLayout *target) const;
virtual bool addToolTipContent(QLayout *target) const; virtual bool addToolTipContent(QLayout *target) const;
void setIcon(const QIcon &icon) { m_icon = icon; } void setIcon(const QIcon &icon);
const QIcon &icon() const { return m_icon; } void setIconProvider(const std::function<QIcon()> &iconProvider);
const QIcon icon() const;
// call this if the icon has changed. // call this if the icon has changed.
void updateMarker(); void updateMarker();
Priority priority() const { return m_priority;} Priority priority() const { return m_priority;}
@@ -121,8 +122,9 @@ public:
QString lineAnnotation() const { return m_lineAnnotation; } QString lineAnnotation() const { return m_lineAnnotation; }
void setLineAnnotation(const QString &lineAnnotation) { m_lineAnnotation = lineAnnotation; } void setLineAnnotation(const QString &lineAnnotation) { m_lineAnnotation = lineAnnotation; }
QString toolTip() const { return m_toolTip; } QString toolTip() const;
void setToolTip(const QString &toolTip) { m_toolTip = toolTip; } void setToolTip(const QString &toolTip);
void setToolTipProvider(const std::function<QString ()> &toolTipProvider);
QVector<QAction *> actions() const; QVector<QAction *> actions() const;
void setActions(const QVector<QAction *> &actions); // Takes ownership void setActions(const QVector<QAction *> &actions); // Takes ownership
@@ -135,12 +137,14 @@ private:
int m_lineNumber = 0; int m_lineNumber = 0;
Priority m_priority = LowPriority; Priority m_priority = LowPriority;
QIcon m_icon; QIcon m_icon;
std::function<QIcon()> m_iconProvider;
Utils::optional<Utils::Theme::Color> m_color; Utils::optional<Utils::Theme::Color> m_color;
bool m_visible = false; bool m_visible = false;
Utils::Id m_category; Utils::Id m_category;
double m_widthFactor = 1.0; double m_widthFactor = 1.0;
QString m_lineAnnotation; QString m_lineAnnotation;
QString m_toolTip; QString m_toolTip;
std::function<QString()> m_toolTipProvider;
QString m_defaultToolTip; QString m_defaultToolTip;
QVector<QAction *> m_actions; QVector<QAction *> m_actions;
}; };