描述
如果我理解正确,目前没有QTextDocument
使用该toHtml()
函数生成的元信息的情况下无法获取带有 HTML 标记的格式化文本。因此,我决定使用QTextCursor
该类手动完成这项工作。
代码
我有一个提供有关标签信息的结构:
struct Tag
{
Tag(const QString& openTag,
const QString& closeTag,
const std::function<bool(const QTextCursor& cursor)>& canBeOpened);
QString getOpenTag() const;
QString getCloseTag() const;
bool isOpened() const;
bool isClosed() const;
bool canBeOpened(const QTextCursor& cursor) const;
void open();
void close();
private:
std::function<bool(const QTextCursor&)> m_canBeOpened;
QString m_openTag;
QString m_closeTag;
bool m_isOpened{ false };
bool m_isClosed{ true };
};
我有一个std::vector
这样的结构,我初始化如下:
m_tags{ { "<b>", "</b>", [](const QTextCursor& cursor) { return cursor.charFormat().fontWeight() == QFont::Bold; } },
{ "<i>", "</i>", [](const QTextCursor& cursor) { return cursor.charFormat().fontItalic(); } },
{ "<u>", "</u>", [](const QTextCursor& cursor) { return cursor.charFormat().fontUnderline(); } },
{ "<s>", "</s>", [](const QTextCursor& cursor) { return cursor.charFormat().fontStrikeOut(); } } }
最重要的是getFormattedText()
使用这个Tag
对象向量返回格式化文本的函数。主要思想是在纯文本中手动放置标签,即开始标签放在格式化开始的地方,结束标签放在它结束的地方。关于文本中使用何种格式的信息可以从类中获取,我们可以基于类创建QTextCursor
哪个对象。因此,我们有以下功能:QTextDocument
QString getFormattedText()
{
QTextCursor cursor{ textCursor() };
if (!cursor.isNull())
{
QString result{ cursor.document()->toPlainText() };
for (int i{}, offset{}; i < cursor.document()->characterCount(); ++i)
{
cursor.setPosition(i)
for (auto& tag : m_tags)
{
if (tag.canBeOpened(cursor))
{
if (!tag.isOpened())
{
result.insert(i - (i > 0 ? 1 : 0) + offset, tag.getOpenTag());
offset += tag.getOpenTag().size();
tag.open();
}
}
else if (!tag.isClosed())
{
result.insert(i - (i > 0 ? 1 : 0) + offset, tag.getCloseTag());
offset += tag.getCloseTag().size();
tag.close();
}
}
}
for (int i = m_tags.size() - 1; i >= 0; --i)
{
if (!m_tags[i].isClosed())
{
result.insert(result.size(), m_tags[i].getCloseTag());
m_tags[i].close();
}
}
return result;
}
return {};
}
粗体和斜体文本将如下所示<b><i>Bold and italic text</i></b>