Qt XML Viewer? (比如Notepad ++)

时间:2014-11-12 16:18:54

标签: c++ xml qt

我的QDialog包含QTextBrowser,此对话框功能是在QTextBrowser中显示XML文档。 QDialogstd::string作为参数,然后使用QXmlStreamReaderQXmlStreamWriter将该字符串转换为"漂亮的字体"格式化的xml字符串,然后将该字符串设置为UI上的QTextBrowser

这一切都运行正常但理想情况下我希望能够点击打开/关闭标签并让它做一些聪明的突出显示,也能够折叠和扩展标签,本质上我正在寻找的是相同的功能在XML模式下作为Notepad ++。

我想知道是否有人知道任何Qt C ++兼容库可以实现这一点,或者Qt本身是否有任何可能具有此功能的东西(虽然我有一个好看并且无法找到任何东西)。

注意:这个QTextBrowser只是显示设置为只读的XML,因此不需要编辑它我只需要这个功能只能查看(如果这有所不同)

任何欢迎欢呼的建议

2 个答案:

答案 0 :(得分:2)

你可以看看QScintilla这应该是非常强大的,但它只是Qt的一个端口。

或者例如QSyntaxHighlighter

答案 1 :(得分:1)

请查看此页面,了解如何使用QSyntaxHighlighter显示xml的示例: http://www.yasinuludag.com/blog/?p=49

这是QSyntaxHighlighter的重新实现,突出显示xmls几乎就像记事本++那样

class XMLHighlighter : public QSyntaxHighlighter
{
public:
    XMLHighlighter(QTextDocument *parent) : QSyntaxHighlighter(parent) {
        HighlightingRule rule;

        // >text<
        QTextCharFormat xmlValueElementFormat;
        xmlValueElementFormat.setForeground(Qt::black);
        xmlValueElementFormat.setFontWeight(QFont::Bold);
        rule.pattern = QRegExp(">[^\n]*<");
        rule.format = xmlValueElementFormat;
        highlightingRules.append(rule);

        // keywords
        QTextCharFormat keywordFormat;
        keywordFormat.setForeground(Qt::blue);
        keywordFormat.setFontWeight(QFont::Bold);
        QStringList keywords;
        keywords << "\\b?xml\\b" << "/>" << ">" << "<";
        foreach (const QString &keyword, keywords) {
            rule.pattern = QRegExp(keyword);
            rule.format = keywordFormat;
            highlightingRules.append(rule);
        }

        // <Text> </Text>
        QTextCharFormat xmlElementFormat;
        xmlElementFormat.setForeground(Qt::blue);
        rule.pattern = QRegExp("\\b[A-Za-z0-9_]+(?=[\/>])");
        rule.format = xmlElementFormat;
        highlightingRules.append(rule);

        // < Text= >
        QTextCharFormat xmlAttributeFormat;
        xmlAttributeFormat.setForeground(Qt::red);
        rule.pattern = QRegExp("\\b[A-Za-z0-9_]+(?=\\=)");
        rule.format = xmlAttributeFormat;
        highlightingRules.append(rule);

        // <!-- Text -->
        QTextCharFormat singleLineCommentFormat;
        singleLineCommentFormat.setForeground(Qt::gray);
        rule.pattern = QRegExp("<!--[^\n]*-->");
        rule.format = singleLineCommentFormat;
        highlightingRules.append(rule);

        // = "Text"
        QColor valueColor(128, 0, 255);
        valueFormat.setForeground(valueColor);
        valueFormat.setFontWeight(QFont::Bold);
        valueStartExpression.setPattern("\"");
        valueEndExpression.setPattern("\"(?=[\s></])");
    }

    virtual ~XMLHighlighter() {
    }

private:
    struct HighlightingRule
    {
        QRegExp pattern;
        QTextCharFormat format;
    };
    QVector<HighlightingRule> highlightingRules;

    QTextCharFormat valueFormat;
    QRegExp valueStartExpression;
    QRegExp valueEndExpression;

    void highlightBlock(const QString & text)
    {
        //for every pattern
        foreach (const HighlightingRule &rule, highlightingRules)
        {
            QRegExp expression(rule.pattern);
            int index = expression.indexIn(text);

            while(index >= 0) {
                int length = expression.matchedLength();
                this->setFormat(index, length, rule.format);
                index = expression.indexIn(text, index + length);
            }
        }

        this->setCurrentBlockState(0);
        int startIndex = 0;

        if(this->previousBlockState() != 1)
            startIndex = valueStartExpression.indexIn(text);

        while(startIndex >= 0)
        {
            int endIndex = valueEndExpression.indexIn(text, startIndex);
            int commentLength;

            if (endIndex == -1) {
                this->setCurrentBlockState(1);
                commentLength = text.length() - startIndex;
            }
            else {
                commentLength = endIndex - startIndex + valueEndExpression.matchedLength();
            }

            this->setFormat(startIndex, commentLength, valueFormat);
            startIndex = valueStartExpression.indexIn(text, startIndex + commentLength);
        }
    }
};