From e7553eaed82a23100c73051c159eb870f53ac935 Mon Sep 17 00:00:00 2001 From: Jonathan White Date: Sun, 22 Dec 2024 10:48:03 -0500 Subject: [PATCH] WIP: Working on proper sizing and layout of the tags display --- src/gui/EntryPreviewWidget.ui | 27 ++++++++++++---- src/gui/entry/EditEntryWidgetMain.ui | 6 ++++ src/gui/tag/TagsEdit.cpp | 47 +++++++++------------------- src/gui/tag/TagsEdit.h | 4 +-- 4 files changed, 44 insertions(+), 40 deletions(-) diff --git a/src/gui/EntryPreviewWidget.ui b/src/gui/EntryPreviewWidget.ui index 92081ab18..2c7709067 100644 --- a/src/gui/EntryPreviewWidget.ui +++ b/src/gui/EntryPreviewWidget.ui @@ -7,7 +7,7 @@ 0 0 530 - 257 + 296 @@ -260,8 +260,8 @@ 0 0 - 157 - 63 + 152 + 57 @@ -481,13 +481,28 @@ - + + + + 16777215 + 80 + + - Qt::ClickFocus + Qt::NoFocus Tags list + + QFrame::NoFrame + + + 0 + + + QAbstractScrollArea::AdjustToContents + @@ -1218,7 +1233,7 @@ TagsEdit - QWidget + QScrollArea
gui/tag/TagsEdit.h
1
diff --git a/src/gui/entry/EditEntryWidgetMain.ui b/src/gui/entry/EditEntryWidgetMain.ui index 087406432..450a5bb35 100644 --- a/src/gui/entry/EditEntryWidgetMain.ui +++ b/src/gui/entry/EditEntryWidgetMain.ui @@ -144,6 +144,12 @@
+ + + 0 + 0 + + 16777215 diff --git a/src/gui/tag/TagsEdit.cpp b/src/gui/tag/TagsEdit.cpp index 8ba6ed4ce..f46c203f6 100644 --- a/src/gui/tag/TagsEdit.cpp +++ b/src/gui/tag/TagsEdit.cpp @@ -339,7 +339,8 @@ struct TagsEdit::Impl } void insertText(const QString& text) { - currentText().insert(cursor, text); + Q_ASSERT(tags.editingIndex() != tags.end()); + tags.editingIndex()->text.insert(cursor, text); moveCursor(cursor + text.size(), false); } @@ -368,7 +369,7 @@ struct TagsEdit::Impl void setCurrentText(const QString& text) { Q_ASSERT(tags.editingIndex() != tags.end()); - currentText() = text; + tags.editingIndex()->text = text; moveCursor(currentText().length(), false); updateDisplayText(); calcRectsAndUpdateScrollRanges(); @@ -391,7 +392,7 @@ struct TagsEdit::Impl // and ensures Invariant-1. void editNewTag(const iterator& i) { - currentText() = currentText().trimmed(); + tags.editingIndex()->text = currentText().trimmed(); auto inserted_at = tags.insert(i, Tag()); setEditingIndex(inserted_at); moveCursor(0, false); @@ -419,7 +420,7 @@ struct TagsEdit::Impl void removeSelection() { cursor = select_start; - currentText().remove(cursor, select_size); + tags.editingIndex()->text.remove(cursor, select_size); deselectAll(); } @@ -428,7 +429,7 @@ struct TagsEdit::Impl if (hasSelection()) { removeSelection(); } else { - currentText().remove(--cursor, 1); + tags.editingIndex()->text.remove(--cursor, 1); } } @@ -618,7 +619,6 @@ private: int select_start; int select_size; bool cross_deleter; - int hscroll{0}; QTextLayout text_layout; public: @@ -641,11 +641,8 @@ public: const auto r = currentRect(); const auto txt_p = r.topLeft() + QPoint(TAG_INNER.left(), ((r.height() - fontHeight) / 2)); - // Nothing to draw. Don't draw anything to avoid adding text margins. - if (!it->isEmpty()) { - // draw not terminated tag - text_layout.draw(&p, txt_p - scrollOffsets, formatting()); - } + // draw not terminated tag + text_layout.draw(&p, txt_p - scrollOffsets, formatting()); // draw cursor if (drawCursor) { @@ -663,19 +660,8 @@ TagsEdit::TagsEdit(QWidget* parent) , impl(new Impl(this)) , completer(new QCompleter) { - QSizePolicy size_policy(QSizePolicy::Ignored, QSizePolicy::Preferred); - size_policy.setHeightForWidth(true); - setSizePolicy(size_policy); - - setFocusPolicy(Qt::StrongFocus); - viewport()->setCursor(Qt::IBeamCursor); - setAttribute(Qt::WA_InputMethodEnabled, true); - setMouseTracking(true); - + setReadOnly(false); setupCompleter(); - setCursorVisible(hasFocus()); - impl->updateDisplayText(); - viewport()->setContentsMargins(TAG_H_SPACING, TAG_V_SPACING, TAG_H_SPACING, TAG_V_SPACING); } @@ -694,6 +680,7 @@ void TagsEdit::setReadOnly(bool readOnly) setCursor(Qt::IBeamCursor); setAttribute(Qt::WA_InputMethodEnabled, true); } + setMouseTracking(!m_readOnly); impl->setReadOnly(m_readOnly); } @@ -837,24 +824,20 @@ void TagsEdit::mousePressEvent(QMouseEvent* event) } } -QSize TagsEdit::sizeHint() const +QSize TagsEdit::viewportSizeHint() const { - return minimumSizeHint(); + return impl->updateTagRenderStates({0, 0, width(), 0}).size(); } -QSize TagsEdit::minimumSizeHint() const +bool TagsEdit::hasHeightForWidth() const { - ensurePolished(); - QFontMetrics fm = fontMetrics(); - QRect rect(0, 0, fm.maxWidth() + TAG_CROSS_PADDING + TAG_CROSS_WIDTH, fm.height() + fm.leading()); - rect += TAG_INNER + contentsMargins() + viewport()->contentsMargins() + viewportMargins(); - return rect.size(); + return true; } int TagsEdit::heightForWidth(int w) const { const auto content_width = w; - QRect contents_rect(0, 0, content_width, 100); + QRect contents_rect(0, 0, content_width, 32); contents_rect -= contentsMargins() + viewport()->contentsMargins() + viewportMargins(); contents_rect = impl->updateTagRenderStates(contents_rect); contents_rect += contentsMargins() + viewport()->contentsMargins() + viewportMargins(); diff --git a/src/gui/tag/TagsEdit.h b/src/gui/tag/TagsEdit.h index 1ee88b9f3..ae2b04a84 100644 --- a/src/gui/tag/TagsEdit.h +++ b/src/gui/tag/TagsEdit.h @@ -37,8 +37,7 @@ public: explicit TagsEdit(QWidget* parent = nullptr); ~TagsEdit() override; - QSize sizeHint() const override; - QSize minimumSizeHint() const override; + bool hasHeightForWidth() const override; int heightForWidth(int w) const override; void setReadOnly(bool readOnly); @@ -60,6 +59,7 @@ protected: void keyPressEvent(QKeyEvent* event) override; void mouseMoveEvent(QMouseEvent* event) override; void hideEvent(QHideEvent* event) override; + QSize viewportSizeHint() const override; private: bool isAcceptableInput(QKeyEvent const* event) const;