前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Qt官方示例-语法高亮器

Qt官方示例-语法高亮器

作者头像
Qt君
发布于 2019-11-11 15:35:20
发布于 2019-11-11 15:35:20
2.3K00
代码可运行
举报
文章被收录于专栏:跟Qt君学编程跟Qt君学编程
运行总次数:0
代码可运行

语法高亮显示示例展示了如何执行简单的语法高亮显示(对C ++文件语法高亮)。

该示例主要使用QTextEdit和QSyntaxHighlighter实现。

  要提供自定义的语法突出显示,您必须子类QSyntaxHighlighter和重新实现highlightBlock函数,并定义自己的突出显示规则。

  使用QVector<HighlightingRule>存储高亮显示规则:规则由QRegularExpression模式和QTextCharFormat实例组成,然后配置好的highlightingRules,用于当文本块更新时自动调用highlightBlock函数刷新高亮显示文本。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
struct HighlightingRule
{
    QRegularExpression pattern;
    QTextCharFormat format;
};
QVector<HighlightingRule> highlightingRules;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
void Highlighter::highlightBlock(const QString &text)
{
    foreach (const HighlightingRule &rule, highlightingRules) {
        QRegularExpressionMatchIterator matchIterator = rule.pattern.globalMatch(text);
        while (matchIterator.hasNext()) {
            QRegularExpressionMatch match = matchIterator.next();
            setFormat(match.capturedStart(), match.capturedLength(), rule.format);
        }
    }
    ...
}

  高亮显示文本格式有:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
QTextCharFormat keywordFormat; // 关键词
QTextCharFormat classFormat; // 类名
QTextCharFormat singleLineCommentFormat; // 单行注释
QTextCharFormat multiLineCommentFormat; // 多行注释
QTextCharFormat quotationFormat; // 头文件引用
QTextCharFormat functionFormat; // 函数

  以添加类名高亮语法为例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
HighlightingRule rule;

classFormat.setFontWeight(QFont::Bold);
classFormat.setForeground(Qt::darkMagenta);
rule.pattern = QRegularExpression("\\bQ[A-Za-z]+\\b"); // 配置"类名"正则模式
rule.format = classFormat; // 配置"类名"的文本格式
highlightingRules.append(rule); // 添加到高亮显示规则容器,用于文本刷新
关于更多
  • 在QtCreator软件可以找到:
  • 或在以下Qt安装目录找到
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
C:\Qt\{你的Qt版本}\Examples\{你的Qt版本}\widgets\richtext\syntaxhighlighter
  • 相关链接
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
https://doc.qt.io/qt-5/qtwidgets-richtext-syntaxhighlighter-example.html
  • Qt君公众号回复『Qt示例』获取更多内容。
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-11-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Qt君 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验